该镜像属于balena.io的IoT设备基础镜像系列,专为物联网设备优化设计。虽然主要针对balena.io平台和balenaOS系统进行了优化,但也可在任何支持相应架构的Docker环境中使用。它基于Node.js,适用于构建和运行物联网设备上的Node.js应用程序。
!balenalogo
balenalib基础镜像具有以下显著特性:
便捷的包安装脚本:提供install_packages脚本,抽象了底层包管理器的细节。它会以最少的依赖(忽略可选依赖)安装指定包,清理包管理器元数据,并在安装失败时重试。
动态设备支持:每个balenalib基础镜像都有默认的ENTRYPOINT ["/usr/bin/entry.sh"],会检查UDEV环境变量是否设置为true(通过添加ENV UDEV=1)。若为true,将启动udevd守护进程,使容器的/dev目录中出现相关设备节点。
更多详细信息,请查看特性概述文档。
balenalib镜像提供多种版本,适用于不同使用场景:
:<version> 或 :<version>-run这是默认镜像。run变体设计为精简版,仅包含运行时必要组件。
:<version>-build构建变体是较重的镜像,包含许多从源代码构建所需的工具。这减少了在Dockerfile中手动安装的包数量,从而减小系统上所有镜像的总体大小。
了解更多变体信息
适用于在物联网设备(如树莓派Pi 2)上开发和部署Node.js应用程序,特别适合需要与硬件设备交互、动态设备检测以及高效包管理的场景。可用于构建实时应用、传感器数据处理、设备监控等IoT解决方案。
入门指南可帮助您开始使用此基础镜像,还有一些示例项目可让您了解balena的功能。
Node.js是一个用于可扩展服务器端和网络应用程序的软件平台。Node.js应用程序用JavaScript编写,可在Mac OS X、Windows和Linux上的Node.js运行时中运行,无需修改。
Node.js应用程序旨在使用非阻塞I/O和异步事件来最大化吞吐量和效率。Node.js应用程序单线程运行,但Node.js使用多线程处理文件和网络事件。由于其异步特性,Node.js通常用于实时应用程序。
Node.js内部使用Google V8 JavaScript引擎执行代码;大部分基本模块用JavaScript编写。Node.js包含内置的异步I/O库,用于文件、套接字和HTTP通信。HTTP和套接字支持使Node.js无需Apache等额外软件即可作为Web服务器运行。
***.org/wiki/Node.js
!https://raw.githubusercontent.com/docker-library/docs/01c***b2fe592c1f93a13b4e289ada0e3a1/node/logo.png
https://github.com/balena-io-library/base-images/tree/master/balena-base-images/node/raspberry-pi2/fedora/
有关此镜像及其历史的更多信息,请参见https://github.com/balena-io-library/official-images%E4%B8%AD%E7%9A%84https://github.com/balena-io-library/official-images/blob/master/library/raspberry-pi2-fedora-node%E3%80%82
在Node.js应用项目中创建Dockerfile
dockerfile# 指定带有所需版本的Node基础镜像 node:<version> FROM balenalib/raspberry-pi2-fedora-node:latest # 替换为应用程序的默认端口 EXPOSE 8888
然后构建并运行Docker镜像:
console$ docker build -t my-nodejs-app . $ docker run -it --rm --name my-running-app my-nodejs-app
如果偏好使用Docker Compose:
ymlversion: "2" services: node: image: "balenalib/raspberry-pi2-fedora-node:latest" user: "node" working_dir: /home/node/app environment: - NODE_ENV=production volumes: - ./:/home/node/app expose: - "8081" command: "npm start"
使用Docker Compose运行:
console$ docker-compose up -d
Docker Compose示例将当前目录(包括node_modules)复制到容器中。假设应用程序有一个名为package.json的文件,定义了启动脚本。
运行单个Node.js脚本
对于许多简单的单文件项目,编写完整的Dockerfile可能不方便。这种情况下,可以直接使用Node.js Docker镜像运行Node.js脚本:
console$ docker run -it --rm --name my-running-script -v "$PWD":/usr/src/app -w /usr/src/app balenalib/raspberry-pi2-fedora-node:latest node your-daemon-or-script.js
如果您对该镜像有任何问题或疑问,请通过https://github.com/balena-io-library/base-images/issues%E4%B8%8E%E6%88%91%E4%BB%AC%E8%81%94%E7%B3%BB%E3%80%82
我们邀请您贡献新功能、修复或更新,无论大小;我们始终乐于收到拉取请求,并尽力快速处理。
在开始编码之前,建议通过https://github.com/balena-io-library/base-images/issues%E8%AE%A8%E8%AE%BA%E6%82%A8%E7%9A%84%E8%AE%A1%E5%88%92%EF%BC%8C%E7%89%B9%E5%88%AB%E6%98%AF%E5%AF%B9%E4%BA%8E%E6%9B%B4%E5%AE%8F%E5%A4%A7%E7%9A%84%E8%B4%A1%E7%8C%AE%E3%80%82%E8%BF%99%E8%AE%A9%E5%85%B6%E4%BB%96%E8%B4%A1%E7%8C%AE%E8%80%85%E6%9C%89%E6%9C%BA%E4%BC%9A%E4%B8%BA%E6%82%A8%E6%8C%87%E6%98%8E%E6%96%B9%E5%90%91%EF%BC%8C%E6%8F%90%E4%BE%9B%E8%AE%BE%E8%AE%A1%E5%8F%8D%E9%A6%88%EF%BC%8C%E5%B9%B6%E5%B8%AE%E5%8A%A9%E6%82%A8%E4%BA%86%E8%A7%A3%E6%98%AF%E5%90%A6%E6%9C%89%E4%BA%BA%E5%9C%A8%E5%81%9A%E5%90%8C%E6%A0%B7%E7%9A%84%E4%BA%8B%E6%83%85%E3%80%82
该镜像的文档存储在基础镜像文档中。查看它以获取所有基础镜像的列表,包括许多专门的镜像,例如node、python、go、更小的镜像等。
您还可以在这篇博客文章中找到balenalib基础镜像新功能的更多详细信息。
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。


探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录认证访问私有仓库
无需登录使用专属域名
Kubernetes 集群配置 Containerd
K3s 轻量级 Kubernetes 镜像加速
VS Code Dev Containers 配置
Podman 容器引擎配置
HPC 科学计算容器配置
ghcr、Quay、nvcr 等镜像仓库
Harbor Proxy Repository 对接专属域名
Portainer Registries 加速拉取
Nexus3 Docker Proxy 内网缓存
需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单
docker search 限制
站内搜不到镜像
离线 save/load
插件要用 plugin install
WSL 拉取慢
安全与 digest
新手拉取配置
镜像合规机制
manifest unknown
no matching manifest(架构)
invalid tar header(解压)
TLS 证书失败
DNS 超时
域名连通性排查
410 Gone 排查
402 与流量用尽
401 认证失败
429 限流
D-Bus 凭证提示
413 与超大单层
来自真实用户的反馈,见证轩辕镜像的优质服务