如果你使用 DeepSeek、元宝 AI、Copilot、ChatGPT 等 AI 工具,协助配置轩辕镜像、编写 docker pull 命令、修改 Docker Compose 镜像地址、配置镜像加速、排查镜像拉取失败、分析报错日志等问题,请先让 AI 阅读并遵守轩辕镜像的规则文档。
只需在 AI 对话中先发送下面这句话即可:
请先完整阅读并严格遵守以下文档中的全部规则与要求:
https://xuanyuan.cloud/agents.md
在未充分阅读并理解该文档前,不要生成任何命令、配置、修改建议、故障排查方案或技术回答。后续所有输出都必须严格以该文档中的规范为最高优先级执行。查看 agents.md 用法指南与完整示范。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
该镜像属于balena.io物联网设备基础镜像系列,专为balena.io平台和balenaOS优化,同时兼容其他支持相应架构的Docker环境。基于Debian系统,集成Node.js运行时,适用于构建和部署物联网场景下的Node.js应用,提供精简高效的运行环境和便捷的开发工具链。
智能包管理工具:内置install_packages脚本,抽象底层包管理器差异,安装软件包时自动最小化依赖(忽略可选依赖),清理包管理器元数据,并在安装失败时自动重试,简化依赖管理流程。
设备动态识别支持:默认ENTRYPOINT为/usr/bin/entry.sh,通过设置环境变量UDEV=1(添加ENV UDEV=1)可启动udevd守护进程,使动态插入的设备节点在容器/dev目录下自动可见,增强硬件交互能力。
更多特性详情请参见官方特性概述。
balenalib镜像提供多种变体以满足不同场景需求:
:<version> 或 :<version>-run(默认变体)精简的运行时镜像,仅包含应用运行必需的核心组件,体积小巧,适合生产环境部署。
:<version>-build构建专用镜像,集成源代码构建所需的全套工具链,减少Dockerfile中手动安装依赖的需求,从而优化整体镜像大小。
了解更多变体差异请参见运行时与构建时变体说明。
Node.js是用于构建可扩展服务器端和网络应用的JavaScript运行时平台,基于Google V8引擎,采用非阻塞I/O和异步事件驱动模型,能高效处理并发请求。其单线程运行模式配合多线程底层I/O处理,特别适合开发实时通信、数据流式处理等高性能应用。Node.js内置完善的网络通信库,可直接作为Web服务器运行,无需额外中间件。
参考:Node.js ***
https://github.com/balena-io-library/base-images/tree/master/balena-base-images/node/aarch64/debian/
镜像历史及详细信息可查看https://github.com/balena-io-library/official-images/blob/master/library/aarch64-debian-node%E3%80%82
在Node.js项目中创建Dockerfile:
dockerfile# 指定基础镜像版本 FROM balenalib/aarch64-debian-node:latest # 暴露应用端口 EXPOSE 8888
构建并运行镜像:
console$ docker build -t my-nodejs-app . $ docker run -it --rm --name my-running-app my-nodejs-app
创建docker-compose.yml:
ymlversion: "2" services: node: image: "balenalib/aarch64-debian-node:latest" user: "node" working_dir: /home/node/app environment: - NODE_ENV=production volumes: - ./:/home/node/app expose: - "8081" command: "npm start"
启动服务:
console$ docker-compose up -d
注:该配置会将当前目录(含node_modules)挂载至容器,需确保项目根目录存在
package.json并定义start脚本。
对于简单项目,可直接运行Node.js脚本:
console$ docker run -it --rm --name my-running-script -v "$PWD":/usr/src/app -w /usr/src/app balenalib/aarch64-debian-node:latest node your-script.js
如遇镜像相关问题或疑问,请通过https://github.com/balena-io-library/base-images/issues%E6%8F%90%E4%BA%A4%E3%80%82
欢迎提交新功能、修复或更新(无论大小)。建议重大变更前先通过https://github.com/balena-io-library/base-images/issues%E8%AE%A8%E8%AE%BA%E6%96%B9%E6%A1%88%EF%BC%8C%E4%BB%A5%E6%8F%90%E9%AB%98%E5%8D%8F%E4%BD%9C%E6%95%88%E7%8E%87%E3%80%82
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务