Database migrations. CLI and Golang library.
Go to file
Jens Rantil 701bd68731 style(cassandra): whitespace fixes
According to `gofmt`.
2017-09-17 13:26:30 +02:00
cli style: order imports lexicographically 2017-09-17 13:26:23 +02:00
database style(cassandra): whitespace fixes 2017-09-17 13:26:30 +02:00
source Update README.md 2017-07-03 15:45:57 +02:00
testing Merge port mapping helper functions into one 2017-07-07 23:12:07 -07:00
.gitignore add .godoc.pid to gitignore 2017-02-09 13:47:28 -08:00
.travis.yml remove deprecated group from Travis file 2017-07-08 13:49:23 +03:00
CONTRIBUTING.md Update documentation 2017-02-11 11:13:27 -08:00
FAQ.md FAQ: add required extension 2017-07-28 14:30:10 +02:00
LICENSE initial version 3.0.0 preview 2017-02-07 22:01:29 -08:00
MIGRATIONS.md Fill out MIGRATIONS.md with migration format and best practice notes 2017-07-19 00:18:02 -07:00
Makefile Merge branch 'master' into master 2017-07-08 13:50:51 +03:00
README.md Merge branch 'master' into master 2017-07-08 13:50:51 +03:00
log.go add some more comments 2017-02-09 18:23:08 -08:00
migrate.go Fixed a couple of typos 2017-08-14 17:55:33 +05:30
migrate_test.go explain dirty version error 2017-02-19 15:51:12 -08:00
migration.go fix old ref to LogString 2017-02-09 18:26:58 -08:00
migration_test.go rename Migration.LongString to LogString 2017-02-09 18:06:38 -08:00
util.go drop custom query params 2017-02-17 16:59:47 -08:00
util_test.go drop custom query params 2017-02-17 16:59:47 -08:00

README.md

Build Status GoDoc Coverage Status packagecloud.io

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.

Looking for v1?

Databases

Database drivers run migrations. Add a new database?

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

(brew todo #156)

$ brew install migrate --with-postgres
$ migrate -database postgres://localhost:5432/database up 2

Use in your Go project

  • API is stable and frozen for this release (v3.x).
  • Package migrate has no external dependencies.
  • Only import the drivers you need. (check dependency_tree.txt for each driver)
  • 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/mattes/migrate"
    _ "github.com/mattes/migrate/database/postgres"
    _ "github.com/mattes/migrate/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/mattes/migrate"
    "github.com/mattes/migrate/database/postgres"
    _ "github.com/mattes/migrate/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)
}

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.

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.