如果你使用 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 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
GCC Docker 镜像是包含 GNU Compiler Collection (GCC) 的容器化环境,提供跨平台的编译工具链。GCC 是一套支持多种编程语言的开源编译器集合,该镜像旨在简化编译环境配置,确保开发、测试和生产环境的一致性,避免系统级依赖冲突。
gcc、g++、gfortran、gnat 等)。libc、libstdc++)、链接器(ld)、汇编器(as)及调试工具(gdb)。gcc:13、gcc:12、gcc:latest),适配不同项目的编译器版本需求。apt/apk 安装额外依赖(如开发库、工具)。arm64v8/gcc),测试多平台兼容性。从 Docker Hub 拉取指定版本的 GCC 镜像(默认拉取 latest 标签,即最新稳定版):
bash# 拉取最新版 docker pull gcc # 拉取指定版本(如 GCC 13) docker pull gcc:13 # 拉取 Alpine 基础的轻量版(需注意部分功能可能受限) docker pull gcc:13-alpine
通过 docker run 启动容器,执行编译命令。核心是通过 -v 挂载宿主机源代码目录到容器内,并指定工作目录(-w)。
编译 C 程序
假设宿主机当前目录下有 main.c(源代码):
c// main.c #include <stdio.h> int main() { printf("Hello, GCC Docker!\n"); return 0; }
编译命令:
bashdocker run --rm \ -v $(pwd):/app \ # 挂载当前目录到容器内 /app -w /app \ # 设置工作目录为 /app gcc \ # 使用 GCC 镜像 gcc main.c -o main # 执行编译:将 main.c 编译为可执行文件 main
编译完成后,宿主机当前目录会生成 main 可执行文件。
编译 C++ 程序
类似地,编译 main.cpp:
cpp// main.cpp #include <iostream> int main() { std::cout << "Hello, G++ Docker!" << std::endl; return 0; }
编译命令(使用 g++):
bashdocker run --rm \ -v $(pwd):/app \ -w /app \ gcc \ g++ main.cpp -o main_cpp
若需编译多文件项目,将整个项目目录挂载到容器内,通过 -w 指定项目根目录:
bash# 假设项目目录为 ./my-project,包含多个 .c/.cpp 文件 docker run --rm \ -v $(pwd)/my-project:/app \ -w /app \ gcc \ make # 执行项目中的 Makefile
通过环境变量或直接传递参数,指定编译选项(如优化级别、警告选项、宏定义等)。
通过命令行参数传递
bash# 启用 O2 优化、Wall 警告,链接数学库(-lm) docker run --rm -v $(pwd):/app -w /app gcc \ gcc main.c -o main -O2 -Wall -lm
通过环境变量传递
常用环境变量(容器内生效):
CC:指定 C 编译器路径(默认 gcc)。CXX:指定 C++ 编译器路径(默认 g++)。CFLAGS:C 编译选项(如 -O2 -Wall)。CXXFLAGS:C++ 编译选项。LDFLAGS:链接选项(如 -lm -lpthread)。示例:通过 CFLAGS 传递全局编译选项
bashdocker run --rm \ -v $(pwd):/app \ -w /app \ -e CFLAGS="-O3 -ffast-math" \ # 启用 O3 优化和快速数学计算 gcc \ gcc main.c -o main # 实际编译命令中无需重复指定 CFLAGS
若项目依赖系统库(如 libssl-dev、zlib1g-dev),可在容器启动时通过 apt(Debian 基础镜像)或 apk(Alpine 基础镜像)安装:
bash# Debian 基础镜像安装依赖(需 root 权限,默认已启用) docker run --rm -it \ -v $(pwd):/app \ -w /app \ gcc \ bash -c "apt update && apt install -y libssl-dev && gcc main.c -o main -lssl"
场景:编译一个依赖 pthread 的多线程 C 程序
源代码 thread.c:
c#include <stdio.h> #include <pthread.h> void* print(void* arg) { printf("Thread %d\n", *(int*)arg); return NULL; } int main() { pthread_t t1, t2; int a=1, b=2; pthread_create(&t1, NULL, print, &a); pthread_create(&t2, NULL, print, &b); pthread_join(t1, NULL); pthread_join(t2, NULL); return 0; }
编译命令(需链接 pthread 库):
bashdocker run --rm \ -v $(pwd):/app \ -w /app \ -e LDFLAGS="-lpthread" \ # 链接 pthread 库 gcc \ gcc thread.c -o thread $LDFLAGS # 使用环境变量中的链接选项
适用于需要固定配置的项目(如编译命令、挂载目录、环境变量固定),创建 docker-compose.yml:
yamlversion: '3' services: compiler: image: gcc:13 volumes: - ./src:/app # 宿主机源代码目录 ./src 挂载到容器 /app working_dir: /app environment: - CFLAGS="-O2 -Wall" # 全局 C 编译选项 - CXX=g++ # 指定 C++ 编译器 command: gcc main.c -o main # 默认编译命令(可通过 docker-compose run 覆盖)
使用方法:
bash# 启动并执行编译 docker-compose up # 如需执行其他命令(如 make),覆盖默认 command docker-compose run compiler make
| 标签格式 | 说明 | 示例 |
|---|---|---|
gcc:latest | 最新稳定版 GCC | docker pull gcc |
gcc:<version> | 指定 GCC 主版本(如 13、12) | gcc:13 |
gcc:<version>-alpine | 基于 Alpine 的轻量版(体积更小) | gcc:13-alpine |
gcc:<version>-slim | 基于 Debian Slim 的精简版 | gcc:13-slim |
| 环境变量 | 作用 | 默认值 |
|---|---|---|
CC | C 编译器路径 | /usr/bin/gcc |
CXX | C++ 编译器路径 | /usr/bin/g++ |
CFLAGS | C 编译选项(如 -O2 -I/include) | 空 |
CXXFLAGS | C++ 编译选项(如 -std=c++20 -Wall) | 空 |
LDFLAGS | 链接选项(如 -lm -L/lib) | 空 |
CPPFLAGS | 预处理器选项(如 -DDEBUG) | 空 |
root 用户,编译生成的文件可能会被赋予 root 权限,需通过 --user $(id -u):$(id -g) 调整用户权限(如 docker run --user $(id -u):$(id -g) ...)。alpine/slim 标签镜像体积小,但可能缺少部分系统库,复杂项目建议使用完整版(gcc:<version>)。您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。


来自真实用户的反馈,见证轩辕镜像的优质服务