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

rust-musl-cross是一套用于使用musl-cross工具链编译静态Rust二进制文件的Docker镜像。该镜像旨在简化Rust应用程序的静态编译流程,解决跨平台静态链接时的系统依赖问题,生成可在多种Linux环境中直接运行、无动态库依赖的可执行文件。通过预配置musl libc及对应交叉编译工具链,开发者无需在本地系统手动配置复杂依赖,即可快速构建跨架构的静态二进制文件。
1.75.0-x86_64-unknown-linux-musl),便于选择特定版本工具链。build、test、run),无需修改现有项目配置即可实现静态编译。根据目标架构和Rust版本选择对应标签,从Docker Hub拉取镜像:
docker pull messense/rust-musl-cross:1.75.0-x86_64-unknown-linux-musl
在Rust项目根目录下,通过docker run挂载项目目录并执行编译命令。例如构建x86_64架构静态二进制:
docker run --rm -v "$(pwd)":/workspace -w /workspace messense/rust-musl-cross:1.75.0-x86_64-unknown-linux-musl cargo build --release
编译产物将位于宿主机项目的target/x86_64-unknown-linux-musl/release/目录。
镜像标签格式为${RUST_VERSION}-${TARGET},其中:
${RUST_VERSION}:Rust编译器版本(如1.75.0)${TARGET}:目标架构三元组,常见支持目标包括:
x86_64-unknown-linux-musl(x86_64架构Linux)aarch64-unknown-linux-musl(ARM64架构Linux)armv7-unknown-linux-musleabihf(ARMv7架构Linux,硬浮点)i686-unknown-linux-musl(x86 32位架构Linux)riscv64gc-unknown-linux-musl(RISC-V 64位架构Linux)完整目标列表可参考项目GitHub仓库。
可通过-e参数传递环境变量自定义编译行为:
RUSTFLAGS:传递额外Rust编译器标志,如-C opt-level=3 -C target-cpu=nativeCARGO_ARGS:额外cargo命令参数,如--no-default-features --features=staticUSER_ID:指定容器内运行用户UID(默认使用当前用户UID),解决宿主机文件权限问题GROUP_ID:指定容器内运行用户GID(默认使用当前用户GID)示例:传递自定义编译参数并保持文件权限
docker run --rm -v "$(pwd)":/workspace -w /workspace \ -e RUSTFLAGS="-C lto=thin" \ -e USER_ID=$(id -u) -e GROUP_ID=$(id -g) \ messense/rust-musl-cross:1.75.0-x86_64-unknown-linux-musl \ cargo build --release --features=static
如需自定义cargo配置(如镜像源、依赖路径),可将宿主机~/.cargo/config.toml挂载至容器对应目录:
docker run --rm \ -v "$(pwd)":/workspace \ -v "$HOME/.cargo/config.toml":/root/.cargo/config.toml \ -w /workspace \ messense/rust-musl-cross:1.75.0-x86_64-unknown-linux-musl \ cargo build --release
对于依赖未预安装系统库的项目,可通过Alpine包管理器apk在容器内安装(需以root用户运行):
docker run --rm -v "$(pwd)":/workspace -w /workspace --user root \ messense/rust-musl-cross:1.75.0-x86_64-unknown-linux-musl \ sh -c "apk add libpng-dev && cargo build --release"
USER_ID和GROUP_ID环境变量指定宿主机用户ID,避免文件权限冲突。免费版仅支持 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