
如果你使用 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 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
本镜像专为aarch64(ARM64)架构设计,提供标准化的构建环境。其核心用途是在aarch64平台或跨平台场景中,为应用程序、库文件或其他软件制品提供编译、链接及打包能力,集成必要的工具链和依赖,简化目标架构下的构建流程。
docker用户组或使用sudo)。假设镜像名称为aarch64-build-env,默认标签为latest,通过以下命令拉取:
bashdocker pull aarch64-build-env:latest
如需指定工具链版本(如GCC 12),可使用版本化标签:
bashdocker pull aarch64-build-env:gcc-12
4.3.1 本地项目构建
挂载本地项目目录至容器工作区,执行构建命令(以Make为例):
bashdocker run -it --rm \ -v /本地项目路径:/workspace \ # 挂载本地项目到容器内/workspace -w /workspace \ # 设置工作目录为/workspace -e CC=gcc \ # 指定C编译器 -e CXX=g++ \ # 指定C++编译器 aarch64-build-env:latest \ make -j4 # 执行Make构建(-j4启用4线程并行)
4.3.2 跨平台构建(x86主机)
在x86主机上启用QEMU模拟后运行(需先配置QEMU):
bash# 步骤1:在x86主机上安装QEMU模拟器(一次性操作) docker run --rm --privileged multiarch/qemu-user-static --reset -p yes # 步骤2:运行aarch64构建容器 docker run -it --rm \ -v $(pwd):/workspace \ # 挂载当前目录到/workspace -w /workspace \ aarch64-build-env:latest \ cmake --build . # 执行CMake构建
创建docker-compose.yml文件,定义构建服务:
yamlversion: '3.8' services: aarch64-builder: image: aarch64-build-env:latest volumes: - ./src:/workspace/src # 挂载源代码目录 - ./build:/workspace/build # 挂载构建产物目录(持久化输出) - ./cache:/root/.cache # 挂载工具链缓存(加速重复构建) working_dir: /workspace/src environment: - CMAKE_BUILD_TYPE=Release # CMake构建类型 - TOOLCHAIN_VERSION=12 # 指定GCC版本为12 - BUILD_ARGS=--enable-optimizations # 自定义构建参数 command: > sh -c "cmake -S . -B ../build && cmake --build ../build" # 执行CMake配置与构建
启动服务:
bashdocker-compose up
4.5.1 环境变量
| 环境变量名 | 说明 | 默认值 |
|---|---|---|
CC | C编译器路径或名称 | gcc |
CXX | C++编译器路径或名称 | g++ |
CMAKE_BUILD_TYPE | CMake构建类型(Debug/Release) | Release |
TOOLCHAIN_VERSION | 工具链版本(如GCC版本) | 11 |
BUILD_ARGS | 传递给构建命令的自定义参数 | 空 |
WORKSPACE | 容器内工作目录路径 | /workspace |
4.5.2 卷挂载
| 挂载路径(容器内) | 用途 | 建议挂载方式 |
|---|---|---|
/workspace | 构建工作目录,存放源代码 | 挂载本地项目目录至该路径 |
/workspace/build | 构建产物输出目录 | 挂载本地空目录,持久化产物 |
/root/.cache | 工具链缓存(如CMake、npm缓存) | 挂载本地缓存目录,加速构建 |
4.5.3 常用容器运行参数
-it:分配交互式终端,支持手动输入命令(如调试构建过程)。--rm:容器退出后自动删除,避免残留未使用容器。-u $(id -u):$(id -g):指定容器内用户ID/组ID(Linux主机),解决挂载目录权限问题(避免构建产物归属root)。aarch64-build-env:clang-14),避免通过环境变量强制指定非兼容版本。-u参数时,容器内默认使用root用户,可能导致本地挂载目录下的构建产物归属root,建议通过-u $(id -u):$(id -g)指定当前用户ID/组ID。您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务