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

:/io -w /io ghcr.io/rust-cross/cargo-zigbuild \ cargo zigbuild --release --target x86_64-apple-darwin
。
要为特定最低glibc版本构建,可在--target值后添加版本后缀。例如,为glibc 2.17编译--target aarch64-unknown-linux-gnu:
cargo zigbuild --target aarch64-unknown-linux-gnu.2.17
[!NOTE] glibc版本目标功能存在各种注意事项:
- 若未提供
--target,则不使用Zig,命令实际运行常规cargo build- 若指定无效glibc版本,
cargo-zigbuild不会转发zig cc关于所选回退版本的警告- 此功能不一定与在构建主机上动态链接到特定glibc版本的行为匹配
- 可指定版本2.32,但在仅提供2.31的主机上运行时应报错却未报错
- 而指定2.33在glibc 2.31主机上会正确检测为不兼容
- 某些
RUSTFLAGS(如-C linker)会退出使用Zig,而-L path/to/files会让Zig忽略-C target-feature=+crt-static-C target-feature=+crt-static用于静态链接glibc版本不受支持(上游zig cc缺乏支持)
cargo zigbuild找不到已存在的头文件(*.h)或库可能需要在cargo zigbuild命令前添加以下环境变量,包含系统路径:
CFLAGS='-isystem /usr/include'RUSTFLAGS='-L /usr/lib64'cargo zigbuild始终使用zig cc的-nostdinc选项,排除标准头文件位置(如/usr/include)。当Zig配置了--target时,这也是默认行为,此外还会退出标准系统搜索路径。
这可能导致cargo build成功而cargo zigbuild失败(需额外配置)的常见情况:
# 无法找到构建所需的头文件: fatal error: 'libelf.h' file not found # 无法找到要链接的共享库: error: unable to find dynamic system library 'elf' using strategy 'no_fallback'. searched paths
有多种解决方法,但对于/usr/include等系统路径,需注意避免将系统glibc头文件与Zig自身提供的glibc头文件混合,否则会产生类似CPATH=/usr/include的错误:
In file included from /usr/local/lib64/python3.13/site-packages/ziglang/lib/libunwind/src/gcc_personality_v0.c:21: In file included from /usr/local/lib64/python3.13/site-packages/ziglang/lib/libunwind/include/unwind.h:18: In file included from /usr/include/stdint.h:26: In file included from /usr/include/bits/libc-header-start.h:33: /usr/include/features.h:516:9: warning: '__GLIBC_MINOR__' macro redefined [-Wmacro-redefined] 516 | #define __GLIBC_MINOR__ 41 | ^ <command line>:2:9: note: previous definition is here 2 | #define __GLIBC_MINOR__ 37 |
当系统包将项目构建所需的头文件添加到/usr/include时,需让Zig仅对这些头文件回退到/usr/include,同时使用自身的glibc头文件。可通过zig cc -isystem /usr/include实现,对于cargo zigbuild,可通过环境变量CFLAGS='-isystem /usr/include'配置。
对于共享库的类似问题,若包将系统库安装在/usr/lib64,通常使用LDFLAGS='-L /usr/lib64',但rustc和cargo不读取此环境变量,需为带有build.rs的 crate 配置搜索路径以链接动态/静态库。此时需使用RUSTFLAGS='-L /usr/lib64'。
若未剥离构建二进制文件的符号,在Linux上可运行以下脚本扫描glibc版本化符号,找到最高版本(运行所需最低版本):
创建文件**/usr/local/bin/get-min-glibc:**
#!/bin/bash FILE_NAME=$1 readelf -W --version-info --dyn-syms ${FILE_NAME} \ | grep 'Name: GLIBC' \ | sed -re 's/.*GLIBC_(.+) Flags.*/\1/g' \ | sort -t . -k1,1n -k2,2n \ | tail -n 1
使脚本可执行:
chmod +x /usr/local/bin/get-min-glibc
使用可执行文件/库路径运行命令:
$ get-min-glibc target/x86_64-unknown-linux-gnu/release/hello-world 2.28
cargo-zigbuild支持特殊的universal2-apple-darwin目标,在Rust 1.64.0及更高版本上构建macOS universal2二进制文件/库。
rustup target add x86_64-apple-darwin rustup target add aarch64-apple-darwin cargo zigbuild --target universal2-apple-darwin
注意
目前Cargo的
--message-format选项在universal2目标上不工作。
上游zig的已知问题:
-target和-mcpu/-march/-mtune标志:
某些Rust目标不被zig cc识别(如armv7-unknown-linux-gnueabihf),在#58中通过使用-mcpu=generic和显式传递目标功能作为 workaroundSDKROOT环境变量为macOS SDK路径作为 workaroundcompiler_rt函数,可能导致某些目标出现未定义符号错误。另见:zig compiler-rt状态本作品以MIT许可证发布。许可证副本见LICENSE文件。
免费版仅支持 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