本站支持搜索的镜像仓库:Docker Hub、gcr.io、ghcr.io、quay.io、k8s.gcr.io、registry.gcr.io、elastic.co、mcr.microsoft.com

本Docker镜像封装了从 mstorsjo/llvm-mingw 项目构建的预编译LLVM-based MinGW工具链,旨在为Linux环境提供便捷的Windows应用交叉编译环境。该工具链整合了LLVM编译器基础设施与MinGW运行时,可简化跨平台开发流程,避免手动配置工具链的复杂性。
clang(C/C++编译器)、lld(链接器)、llvm-ar(归档工具)、llvm-ranlib等LLVM生态工具strip、objcopy、windres(资源编译器)等二进制处理工具/opt/llvm-mingw,二进制路径已添加至PATH环境变量假设镜像名称为llvm-mingw-toolchain(实际使用时需替换为实际镜像标签,如版本号):
# 拉取镜像(若使用远程仓库) docker pull [镜像仓库地址]/llvm-mingw-toolchain:latest # 或本地构建(基于mstorsjo/llvm-mingw项目) git clone [***] cd llvm-mingw docker build -t llvm-mingw-toolchain -f Dockerfile . # 若项目提供Dockerfile
将宿主机源代码目录挂载至容器内,执行编译命令:
# 假设当前目录为源代码目录,编译main.c为x86_64 Windows可执行文件 docker run --rm -v "$PWD:/src" -w /src llvm-mingw-toolchain \ x86_64-w64-mingw32-clang main.c -o main.exe
通过工具链前缀指定目标架构(如32位x86):
docker run --rm -v "$PWD:/src" -w /src llvm-mingw-toolchain \ i686-w64-mingw32-clang main.c -o main_32.exe
使用make或cmake进行项目构建(需确保Makefile/CMakeLists.txt配置交叉编译参数):
# CMake项目示例(需在CMakeLists.txt中设置CMAKE_TOOLCHAIN_FILE) docker run --rm -v "$PWD:/src" -w /src llvm-mingw-toolchain \ sh -c "cmake -DCMAKE_TOOLCHAIN_FILE=/opt/llvm-mingw/cmake/llvm-mingw.cmake . && make"
-v [宿主机目录]:/src将本地代码映射至容器内/src目录(推荐工作目录)-v $PWD/output:/out),将编译产物直接输出至宿主机通过不同架构的工具链前缀指定编译目标,格式为<arch>-w64-mingw32-<tool>,例如:
x86_64-w64-mingw32-clang(x86_64架构编译器)aarch64-w64-mingw32-lld(ARM64架构链接器)| 变量名 | 说明 | 默认值 |
|---|---|---|
LLVM_MINGW_PREFIX | 工具链安装根目录 | /opt/llvm-mingw |
TARGET_TRIPLE | 默认目标架构三元组(可覆盖) | x86_64-w64-mingw32 |
PATH | 系统路径,已包含工具链二进制目录 | /opt/llvm-mingw/bin:$PATH |
# 宿主机准备源代码main.c cat > main.c << EOF #include <stdio.h> int main() { printf("Hello Windows from Linux!\n"); return 0; } EOF # 运行容器编译 docker run --rm -v "$PWD:/src" -w /src llvm-mingw-toolchain \ clang main.c -o hello.exe # 输出产物:当前目录生成hello.exe(Windows可执行文件)
创建docker-compose.yml:
version: '3.8' services: builder: image: llvm-mingw-toolchain:latest volumes: - ./src:/src # 源代码目录 - ./build:/build # 构建输出目录 environment: - TARGET_TRIPLE=armv7-w64-mingw32 # 指定ARM32目标架构 command: > sh -c "cd /build && cmake -DCMAKE_TOOLCHAIN_FILE=/opt/llvm-mingw/cmake/llvm-mingw.cmake /src && make -j\$$(nproc)"
启动构建:
docker-compose up
lib目录(/opt/llvm-mingw/<arch>-w64-mingw32/lib)-static编译选项生成静态链接可执行文件(避免依赖系统dll):20231002),避免因工具链更新导致构建异常免费版仅支持 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 登录方式配置轩辕镜像加速服务,包含7个详细步骤
在 Linux 系统上配置轩辕镜像源,支持主流发行版
在 Docker Desktop 中配置轩辕镜像加速,适用于桌面系统
在 Docker Compose 中使用轩辕镜像加速,支持容器编排
在 k8s 中配置 containerd 使用轩辕镜像加速
在宝塔面板中配置轩辕镜像加速,提升服务器管理效率
在 Synology 群晖NAS系统中配置轩辕镜像加速
在飞牛fnOS系统中配置轩辕镜像加速
在极空间NAS中配置轩辕镜像加速
在爱快ikuai系统中配置轩辕镜像加速
在绿联NAS系统中配置轩辕镜像加速
在威联通NAS系统中配置轩辕镜像加速
在 Podman 中配置轩辕镜像加速,支持多系统
配置轩辕镜像加速9大主流镜像仓库,包含详细配置步骤
无需登录即可使用轩辕镜像加速服务,更加便捷高效
需要其他帮助?请查看我们的 常见问题 或 官方QQ群: 13763429