balenalib/jetson-xavier-nx-devkit-seeed-2mic-hat-alpine-golangbalenalib Go镜像是balena.io IoT设备基础镜像系列的一部分,专为在IoT设备上开发和运行Go语言应用而设计。该镜像经过优化,可无缝集成balena.io平台和balenaOS操作系统,同时兼容任何支持相应架构的Docker环境。主要用途是为Go应用提供轻量级、高效的运行时环境和功能丰富的构建环境,满足IoT场景下对资源优化和设备兼容性的需求。
install_packages/usr/bin/entry.sh,负责初始化容器环境。ENV UDEV=1 启用udevd守护进程,使容器内 /dev 目录能动态识别并创建外部插入设备的节点,适用于需要访问IoT设备硬件的场景(如传感器、外设等)。更多特性详情可参考 balena基础镜像特性概述。
-build 变体进行源码编译,减少手动安装构建工具的需求,降低镜像总大小。-run 变体部署已编译的Go应用,仅包含运行时必需组件,优化资源占用。UDEV=1 启用设备动态识别,适用于需要访问GPIO、传感器等外设的IoT应用。balenalib Go镜像提供多种变体,满足不同开发和部署需求:
:<version> 或 :<version>-run(默认变体):<version>-build更多关于变体的说明可参考 balena基础镜像:Run vs Build。
如需在balena.io平台上使用该镜像,可参考 快速入门指南,或查看 示例项目 获取实践参考。
创建 Dockerfile:
dockerfileFROM balenalib/jetson-xavier-nx-devkit-seeed-2mic-hat-alpine-golang:latest # 使用默认run变体 WORKDIR /go/src/app COPY . . RUN go get -d -v ./... # 获取依赖 RUN go install -v ./... # 编译并安装应用 CMD ["app"] # 运行编译后的可执行文件
构建并运行镜像:
console$ docker build -t my-golang-iot-app . $ docker run -it --rm --name my-running-app my-golang-iot-app
如需在容器内编译应用但不在容器内运行,可使用以下命令:
console$ docker run --rm -v "$PWD":/usr/src/myapp -w /usr/src/myapp \ balenalib/jetson-xavier-nx-devkit-seeed-2mic-hat-alpine-golang:latest \ go build -v # 编译当前目录下的Go项目,输出可执行文件到当前目录
-v "$PWD":/usr/src/myapp:将本地当前目录挂载到容器内 /usr/src/myapp。-w /usr/src/myapp:设置工作目录为挂载目录。go build -v:编译项目,生成与目录名同名的可执行文件。如需容器识别动态插入的设备,需在Dockerfile中设置 UDEV=1 环境变量:
dockerfileFROM balenalib/jetson-xavier-nx-devkit-seeed-2mic-hat-alpine-golang:latest ENV UDEV=1 # 启用udevd守护进程 # ... 其他配置 ...
运行容器时需挂载 /dev 目录并添加特权(可选,视设备权限需求):
console$ docker run -it --rm --name my-udev-app -v /dev:/dev --privileged my-golang-iot-app
采用多阶段构建优化镜像体积,使用 -build 变体编译, -run 变体运行:
dockerfile# 第一阶段:使用build变体编译应用 FROM balenalib/jetson-xavier-nx-devkit-seeed-2mic-hat-alpine-golang:1.19-build AS builder WORKDIR /go/src/app COPY . . RUN go get -d -v ./... RUN go build -o app . # 编译输出到app # 第二阶段:使用run变体运行应用 FROM balenalib/jetson-xavier-nx-devkit-seeed-2mic-hat-alpine-golang:1.19-run WORKDIR /app COPY --from=builder /go/src/app/app . # 仅复制编译产物 CMD ["./app"]
| 环境变量 | 说明 | 默认值 |
|---|---|---|
UDEV | 是否启用udevd守护进程(1=启用,0=禁用) | 0 |
当前支持的Go版本及对应的Dockerfile链接:
1.19(latest)、1.18.15、1.17.12:Dockerfile源码更多镜像信息可参考 官方镜像清单。
如遇镜像使用问题,可通过 GitHub Issues 提交反馈。
欢迎提交新功能、修复或更新。建议先通过 GitHub Issues 讨论计划,以确保贡献方向一致。

探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录认证访问私有仓库
在 Linux 系统配置镜像服务
在 Docker Desktop 配置镜像
Docker Compose 项目配置
Kubernetes 集群配置 Containerd
K3s 轻量级 Kubernetes 镜像加速
VS Code Dev Containers 配置
MacOS OrbStack 容器配置
在宝塔面板一键配置镜像
Synology 群晖 NAS 配置
飞牛 fnOS 系统配置镜像
极空间 NAS 系统配置服务
爱快 iKuai 路由系统配置
绿联 NAS 系统配置镜像
QNAP 威联通 NAS 配置
Podman 容器引擎配置
HPC 科学计算容器配置
ghcr、Quay、nvcr 等镜像仓库
无需登录使用专属域名
需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单
免费版仅支持 Docker Hub 访问,不承诺可用性和速度;专业版支持更多镜像源,保证可用性和稳定速度,提供优先客服响应。
专业版支持 docker.io、gcr.io、ghcr.io、registry.k8s.io、nvcr.io、quay.io、mcr.microsoft.com、docker.elastic.co 等;免费版仅支持 docker.io。
当返回 402 Payment Required 错误时,表示流量已耗尽,需要充值流量包以恢复服务。
通常由 Docker 版本过低导致,需要升级到 20.x 或更高版本以支持 V2 协议。
先检查 Docker 版本,版本过低则升级;版本正常则验证镜像信息是否正确。
使用 docker tag 命令为镜像打上新标签,去掉域名前缀,使镜像名称更简洁。
来自真实用户的反馈,见证轩辕镜像的优质服务