专属域名
文档搜索
轩辕助手
Run助手
邀请有礼
返回顶部
快速返回页面顶部
收起
收起工具栏
轩辕镜像 官方专业版
轩辕镜像 官方专业版轩辕镜像 官方专业版官方专业版
首页个人中心搜索镜像

交易
充值流量我的订单
工具
提交工单镜像收录一键安装
Npm 源Pip 源Homebrew 源
帮助
常见问题
其他
关于我们网站地图

官方QQ群: 1072982923

messense/cargo-zigbuild Docker 镜像 - 轩辕镜像 | Docker 镜像高效稳定拉取服务

热门搜索:openclaw🔥nginx🔥redis🔥mysqlopenjdkcursorweb2apimemgraphzabbixetcdubuntucorednsjdk
cargo-zigbuild
messense/cargo-zigbuild
messense
使用zig作为链接器编译Cargo项目,简化交叉编译过程。
2 次收藏下载次数: 0状态:社区镜像维护者:messense仓库类型:镜像最近更新:1 个月前
使用轩辕镜像,把时间还给真正重要的事。点击查看
中文简介版本下载
使用轩辕镜像,把时间还给真正重要的事。点击查看

cargo-zigbuild

![CI]([] ![Crates.io]([] ![docs.rs]([] ![PyPI]([] ![Docker Image]([***]

🚀 支持我成为全职开源开发者:在GitHub上赞助我

使用zig作为链接器编译Cargo项目,实现更简单的交叉编译。

安装

bash
cargo install --locked cargo-zigbuild

也可通过pip安装,会自动安装ziglang:

bash
pip install cargo-zigbuild

我们还提供Docker镜像,除cargo-zigbuild和Rust外,预安装了macOS SDK。例如,构建x86_64 macOS目标:

  • Linux Docker镜像(ghcr.io、Docker Hub):
bash
docker run --rm -it -v $(pwd):/io -w /io ghcr.io/rust-cross/cargo-zigbuild \
  cargo zigbuild --release --target x86_64-apple-darwin

![打包状态]([***]

使用方法

  1. 按照官方文档安装zig,在macOS、Windows和Linux上也可通过pip3 install ziglang从PyPI安装zig
  2. 通过rustup安装Rust目标,例如:rustup target add aarch64-unknown-linux-gnu
  3. 运行cargo zigbuild,例如:cargo zigbuild --target aarch64-unknown-linux-gnu
指定glibc版本

默认情况下,*-gnu的--target会让Zig隐式构建基于Zig版本的默认glibc版本(v12到v14版本默认glibc 2.28)。

要为特定最低glibc版本构建,可在--target值后添加版本后缀。例如,为glibc 2.17编译--target aarch64-unknown-linux-gnu:

bash
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失败(需额外配置)的常见情况:

console
# 无法找到构建所需的头文件:
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的错误:

rust
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'。

提示 - 验证所需最低GLIBC版本

若未剥离构建二进制文件的符号,在Linux上可运行以下脚本扫描glibc版本化符号,找到最高版本(运行所需最低版本):

  1. 创建文件**/usr/local/bin/get-min-glibc:**

    bash
    #!/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
    
  2. 使脚本可执行:

    bash
    chmod +x /usr/local/bin/get-min-glibc
    
  3. 使用可执行文件/库路径运行命令:

    console
    $ get-min-glibc target/x86_64-unknown-linux-gnu/release/hello-world
    2.28
    
macOS universal2目标

cargo-zigbuild支持特殊的universal2-apple-darwin目标,在Rust 1.64.0及更高版本上构建macOS universal2二进制文件/库。

bash
rustup target add x86_64-apple-darwin
rustup target add aarch64-apple-darwin
cargo zigbuild --target universal2-apple-darwin

注意

目前Cargo的--message-format选项在universal2目标上不工作。

注意事项

  1. 目前仅支持Linux和macOS目标,其他目标平台若可正常工作可添加,欢迎提交PR
  2. CI仅定期测试当前Ruststable和nightly版本,其他版本可能不工作

上游zig的已知问题:

  1. zig cc: 根据clang解析-target和-mcpu/-march/-mtune标志: 某些Rust目标不被zig cc识别(如armv7-unknown-linux-gnueabihf),在#58中通过使用-mcpu=generic和显式传递目标功能作为 workaround
  2. 交叉编译时链接darwin框架(如CoreFoundation)的能力: 设置SDKROOT环境变量为macOS SDK路径作为 workaround
  3. zig缺少某些compiler_rt函数,可能导致某些目标出现未定义符号错误。另见:zig compiler-rt状态
  4. CPU功能未传递给clang

许可证

本作品以MIT许可证发布。许可证副本见LICENSE文件。

查看更多 cargo-zigbuild 相关镜像 →
lukemathwalker/cargo-chef logo
lukemathwalker/cargo-chef
lukemathwalker
在Rust工具链基础上预安装cargo-chef的CI镜像,用于优化Rust Docker构建中的层缓存,加速依赖处理流程。
19 次收藏100万+ 次下载
11 天前更新
cargogenerate/cargo-generate-action logo
cargogenerate/cargo-generate-action
cargogenerate
此GitHub Action用于运行cargo-generate工具,以扩展项目模板。
5万+ 次下载
1 年前更新
paketocommunity/cargo logo
paketocommunity/cargo
paketocommunity
暂无描述
10万+ 次下载
4 个月前更新
messense/cargo-xwin logo
messense/cargo-xwin
messense
cargo-xwin 是帮助Cargo项目轻松交叉编译到Windows msvc目标的工具,使用xwin或windows-msvc-sysroot,提供含wine和Rust的Docker镜像,简化跨平台构建与测试流程。
1 次收藏1万+ 次下载
6 天前更新
jollygoodhorsepower/cargo-chef logo
jollygoodhorsepower/cargo-chef
jollygoodhorsepower
用于镜像上游仓库的Docker镜像,提供与原始仓库完全一致的源代码,确保代码获取的一致性和可靠性。
1万+ 次下载
7 个月前更新
foresterre/cargo-msrv logo
foresterre/cargo-msrv
foresterre
提供cargo-msrv工具的Docker镜像,用于查找和验证Rust项目的最低支持Rust版本(MSRV),支持容器化快速运行,无需本地配置Rust环境。
1万+ 次下载
10 天前更新

轩辕镜像配置手册

探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式

Docker 配置

登录仓库拉取

通过 Docker 登录认证访问私有仓库

专属域名拉取

无需登录使用专属域名

K8s Containerd

Kubernetes 集群配置 Containerd

K3s

K3s 轻量级 Kubernetes 镜像加速

Dev Containers

VS Code Dev Containers 配置

Podman

Podman 容器引擎配置

Singularity/Apptainer

HPC 科学计算容器配置

其他仓库配置

ghcr、Quay、nvcr 等镜像仓库

系统配置

Linux

在 Linux 系统配置镜像服务

Windows/Mac

在 Docker Desktop 配置镜像

MacOS OrbStack

MacOS OrbStack 容器配置

Docker Compose

Docker Compose 项目配置

NAS 设备

群晖

Synology 群晖 NAS 配置

飞牛

飞牛 fnOS 系统配置镜像

绿联

绿联 NAS 系统配置镜像

威联通

QNAP 威联通 NAS 配置

极空间

极空间 NAS 系统配置服务

网络设备

爱快路由

爱快 iKuai 路由系统配置

宝塔面板

在宝塔面板一键配置镜像

需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单

镜像拉取常见问题

使用与功能问题

docker search 报错:专属域名下仅支持 Docker Hub 查询

docker search 报错问题

网页搜不到镜像:Docker Hub 有但轩辕镜像搜索无结果

镜像搜索不到

离线传输镜像:无法直连时用 docker save/load 迁移

离线传输镜像

Docker 插件安装错误:application/vnd.docker.plugin.v1+json

Docker 插件安装错误

WSL 下 Docker 拉取慢:网络与挂载目录影响及优化

WSL 拉取镜像慢

轩辕镜像是否安全?镜像完整性校验(digest)说明

镜像安全性

如何用轩辕镜像拉取镜像?登录方式与专属域名配置

如何拉取镜像

错误码与失败问题

manifest unknown 错误:镜像不存在或标签错误

manifest unknown 错误

TLS/SSL 证书验证失败:Docker pull 时 HTTPS 证书错误

TLS 证书验证失败

DNS 解析超时:无法解析镜像仓库地址或连接超时

DNS 解析超时

410 Gone 错误:Docker 版本过低导致协议不兼容

410 错误:版本过低

402 Payment Required 错误:流量耗尽错误提示

402 错误:流量耗尽

401 UNAUTHORIZED 错误:身份认证失败或登录信息错误

身份认证失败错误

429 Too Many Requests 错误:请求频率超出专业版限制

429 限流错误

Docker login 凭证保存错误:Cannot autolaunch D-Bus(不影响登录)

凭证保存错误

账号 / 计费 / 权限

免费版与专业版区别:功能、限额与使用场景对比

免费版与专业版区别

支持的镜像仓库:Docker Hub、GCR、GHCR、K8s 等列表

轩辕镜像支持的镜像仓库

拉取失败是否扣流量?计费规则说明

拉取失败流量计费

KYSEC 权限不够:麒麟 V10/统信 UOS 下脚本执行被拦截

KYSEC 权限错误

如何申请开具发票?(增值税普票/专票)

开具发票

如何修改网站与仓库登录密码?

修改网站和仓库密码

配置与原理类

registry-mirrors 未生效:仍访问官方仓库或报错的原因

registry-mirrors 未生效

如何去掉镜像名称中的轩辕域名前缀?(docker tag)

去掉域名前缀

如何拉取指定架构镜像?(ARM64/AMD64 等多架构)

拉取指定架构镜像

查看全部问题→

用户好评

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

用户头像

oldzhang

运维工程师

Linux服务器

5

"Docker访问体验非常流畅,大镜像也能快速完成下载。"

轩辕镜像
镜像详情
...
messense/cargo-zigbuild
博客公告Docker 镜像公告与技术博客
热门镜像查看热门 Docker 镜像推荐
一键安装一键安装 Docker 并配置镜像源
镜像拉取问题咨询请 提交工单,官方技术交流群:1072982923。轩辕镜像所有镜像均来源于原始仓库,本站不存储、不修改、不传播任何镜像内容。
镜像拉取问题咨询请提交工单,官方技术交流群:。轩辕镜像所有镜像均来源于原始仓库,本站不存储、不修改、不传播任何镜像内容。
商务合作:点击复制邮箱
©2024-2026 源码跳动
商务合作:点击复制邮箱Copyright © 2024-2026 杭州源码跳动科技有限公司. All rights reserved.