modulepackage
3.0.1+incompatible
Repository: https://github.com/mattes/migrate.git
Documentation: pkg.go.dev
# README
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?
- PostgreSQL
- Redshift
- Ql
- Cassandra (todo #164)
- SQLite (todo #165)
- MySQL/ MariaDB
- Neo4j (todo #167)
- MongoDB (todo #169)
- CrateDB (todo #170)
- Shell (todo #171)
- Google Cloud Spanner (todo #172)
Migration Sources
Source drivers read migrations from local or remote sources. Add a new source?
- Filesystem - read from fileystem (always included)
- Go-Bindata - read from embedded binary data (jteeuwen/go-bindata)
- Github - read from remote Github repositories
- AWS S3 - read from Amazon Web Services S3
- Google Cloud Storage - read from Google Cloud Platform Storage
CLI usage
- Simple wrapper around this library.
- Handles ctrl+c (SIGINT) gracefully.
- No config search paths, no config files, no magic ENV var injections.
$ 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.
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.
Alternatives
https://bitbucket.org/liamstask/goose, https://github.com/tanel/dbmigrate,
https://github.com/BurntSushi/migration, https://github.com/DavidHuie/gomigrate,
https://github.com/rubenv/sql-migrate
# Functions
FilterCustomQuery filters all query values starting with `x-`.
New returns a new Migrate instance from a source URL and a database URL.
NewMigration returns a new Migration and sets the body, identifier, version and targetVersion.
NewMultiError returns an error type holding multiple errors.
NewWithDatabaseInstance returns a new Migrate instance from a source URL and an existing database instance.
NewWithInstance returns a new Migrate instance from an existing source and database instance.
NewWithSourceInstance returns a new Migrate instance from an existing source instance and a database URL.
# Variables
DefaultBufferSize sets the in memory buffer size (in Bytes) for every pre-read migration (see DefaultPrefetchMigrations).
DefaultLockTimeout sets the max time a database driver has to acquire a lock.
DefaultPrefetchMigrations sets the number of migrations to pre-read from the source.
# Structs
ErrShortLimit is an error returned when not enough migrations can be returned by a source for a given limit.
Migration holds information about a migration.
MultiError holds multiple errors.
# Interfaces
Logger is an interface so you can pass in your own logging implementation.