
golang-migrate是一个基于Go语言实现的数据库迁移工具,旨在提供简单、可靠的数据库结构版本化管理方案。该工具支持多种主流数据库(如PostgreSQL、MySQL、SQLite等),通过迁移脚本(通常为SQL文件)实现数据库结构的创建、修改、删除等变更,并支持版本控制、向上迁移(执行变更)和向下迁移(回滚变更),适用于开发、测试及生产环境的数据库管理。
up(升级)和down(回滚)脚本)1. 安装与启动
通过Docker直接运行镜像,无需本地安装依赖:
bash# 拉取镜像(可选,运行时会自动拉取) docker pull migrate/migrate # 查看帮助命令 docker run --rm migrate/migrate --help
2. 核心命令示例
创建迁移脚本
创建一个新的迁移版本(包含up和down脚本):
bash# 格式:docker run --rm -v [本地脚本目录]:/migrations migrate/migrate create -ext sql -dir /migrations -seq [迁移名称] docker run --rm -v $(pwd)/migrations:/migrations migrate/migrate create -ext sql -dir /migrations -seq add_users_table
执行后,在./migrations目录下生成两个文件:
[版本号]_add_users_table.up.sql(升级脚本,如创建表)[版本号]_add_users_table.down.sql(回滚脚本,如删除表)执行迁移(升级数据库)
执行所有未应用的up脚本,升级数据库结构:
bash# 格式:docker run --rm -v [脚本目录]:/migrations migrate/migrate -database [数据库连接URL] -path /migrations up [可选:迁移步数,默认全部] docker run --rm -v $(pwd)/migrations:/migrations migrate/migrate -database "postgres://user:password@host:port/dbname?sslmode=disable" -path /migrations up
回滚迁移(降级数据库)
执行最近的down脚本,回滚数据库结构:
bash# 回滚最近1步迁移 docker run --rm -v $(pwd)/migrations:/migrations migrate/migrate -database "mysql://user:password@tcp(host:port)/dbname" -path /migrations down 1 # 回滚所有迁移(谨慎使用) docker run --rm -v $(pwd)/migrations:/migrations migrate/migrate -database "sqlite3://./test.db" -path /migrations down -all
通过环境变量简化数据库连接参数配置(避免命令行暴露敏感信息):
| 环境变量 | 说明 | 示例值 |
|---|---|---|
DB_URL | 数据库连接URL(优先于命令行参数) | postgres://user:pass@localhost:5432/db |
MIGRATIONS_DIR | 迁移脚本目录(默认/migrations) | /app/migrations |
在多服务环境中,可通过Docker Compose集成数据库与迁移工具:
yamlversion: '3.8' services: db: image: postgres:15 environment: POSTGRES_USER: user POSTGRES_PASSWORD: password POSTGRES_DB: appdb ports: - "5432:5432" healthcheck: test: ["CMD-SHELL", "pg_isready -U user -d appdb"] interval: 5s timeout: 5s retries: 5 migrate: image: migrate/migrate volumes: - ./migrations:/migrations # 挂载本地迁移脚本目录 environment: DB_URL: "postgres://user:password@db:5432/appdb?sslmode=disable" depends_on: db: condition: service_healthy # 确保数据库就绪后执行迁移 command: ["-path", "/migrations", "-database", "${DB_URL}", "up"]
执行docker-compose up migrate即可自动完成数据库迁移。
down)需谨慎,建议先备份数据您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。


探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录认证访问私有仓库
无需登录使用专属域名
Kubernetes 集群配置 Containerd
K3s 轻量级 Kubernetes 镜像加速
VS Code Dev Containers 配置
Podman 容器引擎配置
HPC 科学计算容器配置
ghcr、Quay、nvcr 等镜像仓库
Harbor Proxy Repository 对接专属域名
Portainer Registries 加速拉取
Nexus3 Docker Proxy 内网缓存
需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单
docker search 限制
站内搜不到镜像
离线 save/load
插件要用 plugin install
WSL 拉取慢
安全与 digest
新手拉取配置
镜像合规机制
manifest unknown
no matching manifest(架构)
invalid tar header(解压)
TLS 证书失败
DNS 超时
域名连通性排查
410 Gone 排查
402 与流量用尽
401 认证失败
429 限流
D-Bus 凭证提示
413 与超大单层
来自真实用户的反馈,见证轩辕镜像的优质服务