
如果你使用 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 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
该镜像为https://github.com/artcom/acms-compose%E6%8F%90%E4%BE%9B%E5%9F%BA%E7%A1%80Git%E4%BB%93%E5%BA%93%EF%BC%8C%E5%88%9D%E5%A7%8B%E5%8C%96%E5%8C%85%E5%90%AB%E6%BC%94%E7%A4%BA%E5%86%85%E5%AE%B9%EF%BC%8C%E7%94%A8%E4%BA%8EACMS%E7%B3%BB%E7%BB%9F%E7%9A%84%E9%85%8D%E7%BD%AE%E7%AE%A1%E7%90%86%E3%80%82%E5%AE%83%E6%94%AF%E6%8C%81Git%E7%89%88%E6%9C%AC%E6%8E%A7%E5%88%B6%E3%80%81%E9%BB%98%E8%AE%A4%E5%88%86%E6%94%AF%E8%87%AA%E5%AE%9A%E4%B9%89%E5%8F%8A%E9%85%8D%E7%BD%AE%E5%8F%98%E6%9B%B4%E7%9A%84MQTT%E4%BA%8B%E4%BB%B6%E9%80%9A%E7%9F%A5%EF%BC%8C%E6%98%AFACMS%E7%94%9F%E6%80%81%E4%B8%AD%E9%85%8D%E7%BD%AE%E7%AE%A1%E7%90%86%E7%9A%84%E6%A0%B8%E5%BF%83%E7%BB%84%E4%BB%B6%E3%80%82
默认分支已从 master 更改为 main。如果依赖之前的默认分支,构建镜像时需传递 DEFAULT_BRANCH 构建参数:
bashdocker build --build-arg DEFAULT_BRANCH=master -t artcom/acms-config .
仅当镜像构建时未使用正确的构建参数时,才需要通过运行时环境变量 -e DEFAULT_BRANCH=master 进行覆盖。
适用于ACMS系统的配置管理场景,特别是需要:
构建镜像
bashdocker build -t artcom/acms-config .
运行容器
bashdocker run artcom/acms-config
| 参数名 | 默认值 | 描述 |
|---|---|---|
DEFAULT_BRANCH | main | 构建时在裸仓库中创建的Git分支名称 |
示例:使用自定义默认分支构建
bashdocker build --build-arg DEFAULT_BRANCH=master -t artcom/acms-config .
裸Git仓库在构建时会初始化一个以 DEFAULT_BRANCH 构建参数命名的分支(默认:main)。
容器启动时,入口脚本 50-set-default-branch.sh 会将仓库分支名称与 DEFAULT_BRANCH 环境变量进行协调。如果名称不同,脚本会原地重命名分支(通过移动引用和更新 HEAD),确保客户端始终将配置的名称视为默认分支,无论构建时嵌入的分支名称是什么。
当裸Git仓库接收到推送时,post-receive 钩子会向 <BASE_TOPIC>/onConfigurationChange 发布MQTT事件。
该钩子在Docker构建期间通过 core.hooksPath 全局安装,无需每个仓库单独创建符号链接。
事件 payload
每个更新的引用会发布一条消息:
json{ "refName": "refs/heads/master", "changedFiles": [ "config/content/pages/page001/index.json", "config/content/pages/page002/index.json" ] }
| 字段名 | 类型 | 描述 |
|---|---|---|
refName | string | 被更新的完整Git引用(例如 refs/heads/master) |
changedFiles | string[] | 新旧提交之间差异的文件路径,通过 git diff --name-only 命令返回 |
环境变量
| 环境变量名 | 默认值 | 描述 |
|---|---|---|
DEFAULT_BRANCH | main | 默认Git分支名称。在构建时初始化;如果运行时覆盖,会在容器启动时协调 |
TCP_BROKER_URI | null | MQTT代理URI(例如 mqtt://10.0.0.1)。设为 null 可完全禁用钩子 |
BASE_TOPIC | root | 基础MQTT主题。变更事件会发布到 <BASE_TOPIC>/onConfigurationChange |
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务