golang-migrate是一个基于Go语言实现的数据库迁移工具,旨在提供简单、可靠的数据库结构版本化管理方案。该工具支持多种主流数据库(如PostgreSQL、MySQL、SQLite等),通过迁移脚本(通常为SQL文件)实现数据库结构的创建、修改、删除等变更,并支持版本控制、向上迁移(执行变更)和向下迁移(回滚变更),适用于开发、测试及生产环境的数据库管理。
up(升级)和down(回滚)脚本)通过Docker直接运行镜像,无需本地安装依赖:
bash# 拉取镜像(可选,运行时会自动拉取) docker pull migrate/migrate # 查看帮助命令 docker run --rm migrate/migrate --help
创建一个新的迁移版本(包含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 Hub 加速,不承诺可用性和速度;专业版支持更多镜像源,保证可用性和稳定速度,提供优先客服响应。
免费版仅支持 docker.io;专业版支持 docker.io、gcr.io、ghcr.io、registry.k8s.io、nvcr.io、quay.io、mcr.microsoft.com、docker.elastic.co 等。
当返回 402 Payment Required 错误时,表示流量已耗尽,需要充值流量包以恢复服务。
通常由 Docker 版本过低导致,需要升级到 20.x 或更高版本以支持 V2 协议。
先检查 Docker 版本,版本过低则升级;版本正常则验证镜像信息是否正确。
使用 docker tag 命令为镜像打上新标签,去掉域名前缀,使镜像名称更简洁。
探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录认证访问私有仓库
在 Linux 系统配置镜像加速服务
在 Docker Desktop 配置镜像加速
Docker Compose 项目配置加速
Kubernetes 集群配置 Containerd
在宝塔面板一键配置镜像加速
Synology 群晖 NAS 配置加速
飞牛 fnOS 系统配置镜像加速
极空间 NAS 系统配置加速服务
爱快 iKuai 路由系统配置加速
绿联 NAS 系统配置镜像加速
QNAP 威联通 NAS 配置加速
Podman 容器引擎配置加速
HPC 科学计算容器配置加速
ghcr、Quay、nvcr 等镜像仓库
无需登录使用专属域名加速
需要其他帮助?请查看我们的 常见问题 或 官方QQ群: 13763429