Database migrations. CLI and Golang library.
Go to file
Peter Dotchev 3dc81826fd Improve error message in case no migration is found (#158)
* Improve error message in case no migration is found

* Return similar error

* Just log the error

* Fix error message
2019-08-29 20:09:02 -07:00
.github/ISSUE_TEMPLATE Add Go version to but report template 2018-09-19 03:10:08 -07:00
cli Clean up CLI docs 2019-06-13 01:30:58 -07:00
cmd/migrate Fix typo in README for CLI 2019-06-23 18:46:05 +09:00
database Remove debug output 2019-08-28 18:36:44 +08:00
dktesting Update dktest from v0.2.0 to v0.3.0 2019-01-08 22:39:26 -08:00
internal Let database.Open() use schemeFromURL as well (#271) 2019-08-20 09:59:15 -07:00
source Github Enterprise support (#234) 2019-06-16 12:48:01 -07:00
testing Docker: restore "from env" behavior, and perform API version negotiation (#270) 2019-08-20 08:42:07 -07:00
.dockerignore add dockerization Fix #23 2018-05-09 09:48:20 +02:00
.gitignore finish implementing mssql db and add tests 2019-05-19 13:37:40 +01:00
.golangci.yml Enabled maligned, staticcheck and errcheck linters (#206) 2019-04-26 15:47:16 -07:00
.travis.yml Update golangci-lint from v1.16.0 to v1.17.1 2019-08-17 10:50:42 -07:00
CONTRIBUTING.md Remove spurious list item 2019-03-28 21:35:54 -07:00
Dockerfile Reduce docker binary size by stripping symbols 2019-07-12 10:54:42 -07:00
FAQ.md FAQ: Add question regarding non-Go project usage 2019-08-09 18:50:24 +02:00
GETTING_STARTED.md Use different word 2019-08-13 16:40:03 +02:00
LICENSE Update copyright in LICENSE 2018-11-08 01:45:19 -08:00
MIGRATIONS.md Update migration docs 2019-07-11 23:05:33 -07:00
Makefile Run tests so that coverage profiles don't need to be manually concatenated 2019-06-20 23:07:47 -07:00
README.md Put tutorial specific info into a separate file 2019-08-11 22:06:04 +02:00
docker-deploy.sh Add latest tag to docker image during build 2018-07-03 14:09:26 -07:00
go.mod Run `go mod tidy` 2019-08-22 00:00:09 -07:00
go.sum Run `go mod tidy` 2019-08-22 00:00:09 -07:00
log.go add some more comments 2017-02-09 18:23:08 -08:00
migrate.go Improve error message in case no migration is found (#158) 2019-08-29 20:09:02 -07:00
migrate_test.go Enabled maligned, staticcheck and errcheck linters (#206) 2019-04-26 15:47:16 -07:00
migration.go Enabled maligned, staticcheck and errcheck linters (#206) 2019-04-26 15:47:16 -07:00
migration_test.go rename Migration.LongString to LogString 2017-02-09 18:06:38 -08:00
util.go Let database.Open() use schemeFromURL as well (#271) 2019-08-20 09:59:15 -07:00
util_test.go Let database.Open() use schemeFromURL as well (#271) 2019-08-20 09:59:15 -07:00

README.md

Build Status GoDoc Coverage Status packagecloud.io Docker Pulls Supported Go Versions GitHub Release Go Report Card

migrate

Database migrations written in Go. Use as CLI or import as library.

  • Migrate reads migrations from sources and applies them in correct order to a database.
  • Drivers are "dumb", migrate glues everything together and makes sure the logic is bulletproof. (Keeps the drivers lightweight, too.)
  • Database drivers don't assume things or try to correct user input. When in doubt, fail.

Forked from mattes/migrate

Databases

Database drivers run migrations. Add a new database?

Database URLs

Database connection strings are specified via URLs. The URL format is driver dependent but generally has the form: dbdriver://username:password@host:port/dbname?option1=true&option2=false

Any reserved URL characters need to be escaped. Note, the % character also needs to be escaped

Explicitly, the following characters need to be escaped: !, #, $, %, &, ', (, ), *, +, ,, /, :, ;, =, ?, @, [, ]

It's easiest to always run the URL parts of your DB connection URL (e.g. username, password, etc) through an URL encoder. See the example Python snippets below:

$ python3 -c 'import urllib.parse; print(urllib.parse.quote(input("String to encode: "), ""))'
String to encode: FAKEpassword!#$%&'()*+,/:;=?@[]
FAKEpassword%21%23%24%25%26%27%28%29%2A%2B%2C%2F%3A%3B%3D%3F%40%5B%5D
$ python2 -c 'import urllib; print urllib.quote(raw_input("String to encode: "), "")'
String to encode: FAKEpassword!#$%&'()*+,/:;=?@[]
FAKEpassword%21%23%24%25%26%27%28%29%2A%2B%2C%2F%3A%3B%3D%3F%40%5B%5D
$

Migration Sources

Source drivers read migrations from local or remote sources. Add a new source?

CLI usage

  • Simple wrapper around this library.
  • Handles ctrl+c (SIGINT) gracefully.
  • No config search paths, no config files, no magic ENV var injections.

CLI Documentation

Basic usage

$ migrate -source file://path/to/migrations -database postgres://localhost:5432/database up 2

Docker usage

$ docker run -v {{ migration dir }}:/migrations --network host migrate/migrate
    -path=/migrations/ -database postgres://localhost:5432/database up 2

Use in your Go project

  • API is stable and frozen for this release (v3 & v4).
  • Uses Go modules to manage dependencies.
  • To help prevent database corruptions, it supports graceful stops via GracefulStop chan bool.
  • Bring your own logger.
  • Uses io.Reader streams internally for low memory overhead.
  • Thread-safe and no goroutine leaks.

Go Documentation

import (
    "github.com/golang-migrate/migrate/v4"
    _ "github.com/golang-migrate/migrate/v4/database/postgres"
    _ "github.com/golang-migrate/migrate/v4/source/github"
)

func main() {
    m, err := migrate.New(
        "github://mattes:personal-access-token@mattes/migrate_test",
        "postgres://localhost:5432/database?sslmode=enable")
    m.Steps(2)
}

Want to use an existing database client?

import (
    "database/sql"
    _ "github.com/lib/pq"
    "github.com/golang-migrate/migrate/v4"
    "github.com/golang-migrate/migrate/v4/database/postgres"
    _ "github.com/golang-migrate/migrate/v4/source/file"
)

func main() {
    db, err := sql.Open("postgres", "postgres://localhost:5432/database?sslmode=enable")
    driver, err := postgres.WithInstance(db, &postgres.Config{})
    m, err := migrate.NewWithDatabaseInstance(
        "file:///migrations",
        "postgres", driver)
    m.Steps(2)
}

Getting started

Go to getting started

Tutorials

(more tutorials to come)

Migration files

Each migration has an up and down migration. Why?

1481574547_create_users_table.up.sql
1481574547_create_users_table.down.sql

Best practices: How to write migrations.

Versions

Version Supported? Import Notes
master import "github.com/golang-migrate/migrate/v4" New features and bug fixes arrive here first
v4 import "github.com/golang-migrate/migrate/v4" Used for stable releases
v3 import "github.com/golang-migrate/migrate" (with package manager) or import "gopkg.in/golang-migrate/migrate.v3" (not recommended) DO NOT USE - No longer supported

Development and Contributing

Yes, please! Makefile is your friend, read the development guide.

Also have a look at the FAQ.


Looking for alternatives? https://awesome-go.com/#database.