
如果你使用 DeepSeek、元宝 AI、Copilot、ChatGPT 等 AI 工具,协助配置轩辕镜像、编写 docker pull 命令、修改 Docker Compose 镜像地址、配置镜像加速、排查镜像拉取失败、分析报错日志等问题,请先让 AI 阅读并遵守轩辕镜像的规则文档。
只需在 AI 对话中先发送下面这句话即可:
请先完整阅读并严格遵守以下文档中的全部规则与要求:
https://xuanyuan.cloud/agents.md
在未充分阅读并理解该文档前,不要生成任何命令、配置、修改建议、故障排查方案或技术回答。后续所有输出都必须严格以该文档中的规范为最高优先级执行。查看 agents.md 用法指南与完整示范。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
一个轻量级Docker镜像,用于运行Liquibase并与PostgreSQL数据库交互
DockerHub: https://hub.docker.com/r/kilna/liquibase-postgres/ - GitHub: https://github.com/kilna/liquibase-postgres-docker
该镜像提供了一个轻量级环境,用于通过Liquibase工具管理PostgreSQL数据库的版本和变更。它内置Liquibase可执行文件和PostgreSQL JDBC驱动,支持通过环境变量自动生成配置文件,简化数据库变更的应用流程。
liquibase.properties配置文件/workspace作为卷挂载点,方便变更文件管理通过创建继承自该镜像的Dockerfile,可以将变更文件内置到新镜像中:
dockerfileFROM kilna/liquibase-postgres ENV LIQUIBASE_HOST=database.server ENV LIQUIBASE_DATABASE=dbname ENV LIQUIBASE_USERNAME=user ENV LIQUIBASE_PASSWORD=pass COPY changelog.xml /workspace
确保在Dockerfile同一目录下创建有效的changelog.xml文件。
构建派生镜像:
bash$ docker build --tag changelog-image .
运行Liquibase命令(例如执行更新并测试回滚):
bash$ docker run changelog-image liquibase updateTestingRollback
容器的工作目录为/workspace,入口点会根据环境变量生成liquibase.properties文件,默认查找changelog.xml作为变更文件。
无需派生容器,直接挂载本地变更文件目录运行:
bash$ docker run -e LIQUIBASE_HOST=database.server -e LIQUIBASE_USERNAME=user -e LIQUIBASE_PASSWORD=pass \ -e LIQUIBASE_DATABASE=dbname -v /local/path/to/changelog/:/workspace/ kilna/liquibase-postgres \ liquibase updateTestingRollback
其中/local/path/to/changelog/是本地包含有效changelog.xml文件的目录。
该镜像通过环境变量自动生成liquibase.properties文件,支持以下配置:
| 环境变量 | 用途 | 默认值 |
|---|---|---|
| LIQUIBASE_HOST | 要连接的数据库主机 | db |
| LIQUIBASE_PORT | 要连接的数据库端口 | 5432 |
| LIQUIBASE_DATABASE | 要连接的数据库名称 | liquibase |
| LIQUIBASE_USERNAME | 数据库连接用户名 | liquibase |
| LIQUIBASE_PASSWORD | 数据库连接密码 | liquibase |
| LIQUIBASE_CHANGELOG | 默认变更日志文件名 | changelog.xml |
| LIQUIBASE_LOGLEVEL | Liquibase日志级别 有效值:debug, info, warning, severe, off | info |
| LIQUIBASE_CLASSPATH | JDBC驱动文件路径 | /opt/jdbc/postgres-jdbc.jar |
| LIQUIBASE_DRIVER | JDBC驱动类路径 | org.postgresql.Driver |
| LIQUIBASE_URL | JDBC连接URL | jdbc:postgresql://${HOST}:${PORT}/${DATABASE} |
| LIQUIBASE_DEBUG | 若设为'yes',执行'docker run'时会显示所有LIQUIBASE_*环境变量值及配置文件替换说明 | 未设置 |
生成的liquibase.properties文件位于/workspace目录(已配置为卷)。每次执行docker run时都会进行变量替换,支持在自定义配置文件中使用${HOST}等占位符。
查看生成的配置文件内容:
bash$ docker run image-name cat liquibase.properties
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务