该基础镜像已被弃用,将不再接收更新。请阅读公告文章获取迁移指南和建议的替代方案。
该镜像属于balena.io的IoT设备基础镜像系列,专为华硕Tinker Board S开发板优化。虽然该镜像针对balena.io和balenaOS进行了优化,但也可在任何适当架构的Docker环境中使用。
!balenalogo
balenalib基础镜像包含以下主要特性:
简化的包安装脚本:install_packages脚本抽象了底层包管理器的细节,可安装指定的软件包并最小化依赖关系(忽略可选依赖),清理包管理器元数据,并在安装失败时重试。
动态设备支持:每个balenalib基础镜像都有默认的ENTRYPOINT定义为ENTRYPOINT ["/usr/bin/entry.sh"],它会检查UDEV标志是否设置为true(通过添加ENV UDEV=1),如果为true,将启动udevd守护进程,使容器的/dev目录中出现相关设备节点。
有关更多详细信息,请查看文档中的特性概述。
balenalib镜像提供多种变体,每种变体设计用于特定场景:
:<version> 或 :<version>-run这是默认镜像。run变体设计为精简的最小变体,仅包含运行时必需组件。
:<version>-build构建变体是一个包含更多工具的较重镜像,这些工具用于从源代码构建应用程序。这减少了您需要在Dockerfile中手动安装的软件包数量,从而减小系统上所有镜像的总体大小。
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
!logo
Dockerfile链接20.12.0,19.6.1 (latest),18.14.1
有关此镜像及其历史的更多信息,请参阅balena-io-library/official-images GitHub仓库中的相关清单文件(asus-tinker-board-s-ubuntu-node)。
Dockerfiledockerfile# 指定带有所需版本的Node基础镜像 FROM balenalib/asus-tinker-board-s-ubuntu-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:
yamlversion: "2" services: node: image: "balenalib/asus-tinker-board-s-ubuntu-node:latest" user: "node" working_dir: /home/node/app environment: - NODE_ENV=production # 如需启用udevd守护进程,添加以下环境变量 # - UDEV=1 volumes: - ./:/home/node/app expose: - "8081" command: "npm start"
使用Docker Compose运行:
console$ docker-compose up -d
对于许多简单的单文件项目,可以直接使用Node.js Docker镜像运行脚本:
console$ docker run -it --rm --name my-running-script -v "$PWD":/usr/src/app -w /usr/src/app balenalib/asus-tinker-board-s-ubuntu-node:latest node your-daemon-or-script.js
| 环境变量 | 说明 | 默认值 |
|---|---|---|
| UDEV | 设置为1时启动udevd守护进程,使容器能识别动态插入的设备 | 未设置 |
| NODE_ENV | Node.js环境变量,通常设置为"production"或"development" | 未设置 |
要在容器中访问硬件设备,需要:
dockerfileFROM balenalib/asus-tinker-board-s-ubuntu-node:latest ENV UDEV=1 # 暴露应用程序端口 EXPOSE 3000 # 运行应用 CMD ["node", "app.js"]
运行时需要添加--privileged标志或具体的设备映射:
console$ docker run --privileged -e UDEV=1 -p 3000:3000 my-nodejs-app
本指南可帮助您开始将此基础镜像与balena一起使用,还有一些很棒的示例项目可以让您了解使用balena可以实现什么。
如果您对此镜像有任何问题或疑问,请通过GitHub issue与我们联系。
欢迎您贡献新功能、修复或更新,无论大小;我们始终欢迎拉取请求,并会尽最大努力快速处理。
在开始编码之前,建议通过GitHub issue讨论您的计划,特别是对于更宏大的贡献。这使其他贡献者有机会为您指明正确的方向,提供有关您设计的反馈,并帮助您了解是否有其他人正在从事相同的工作。
有关此镜像的文档存储在基础镜像文档中。查看它以获取所有基础镜像的列表,包括许多专门的镜像,如node、python、go、更小的镜像等。
您还可以在这篇博客文章中找到有关balenalib基础镜像新功能的更多详细信息。
来自真实用户的反馈,见证轩辕镜像的优质服务
免费版仅支持 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 登录认证访问私有仓库
在 Linux 系统配置镜像加速服务
在 Docker Desktop 配置镜像加速
Docker Compose 项目配置加速
Kubernetes 集群配置 Containerd
在宝塔面板一键配置镜像加速
Synology 群晖 NAS 配置加速
飞牛 fnOS 系统配置镜像加速
极空间 NAS 系统配置加速服务
爱快 iKuai 路由系统配置加速
绿联 NAS 系统配置镜像加速
QNAP 威联通 NAS 配置加速
Podman 容器引擎配置加速
HPC 科学计算容器配置加速
ghcr、Quay、nvcr 等镜像仓库
无需登录使用专属域名加速
需要其他帮助?请查看我们的 常见问题 或 官方QQ群: 13763429