本站支持搜索的镜像仓库:Docker Hub、gcr.io、ghcr.io、quay.io、k8s.gcr.io、registry.gcr.io、elastic.co、mcr.microsoft.com
该基础镜像已被弃用,将不再接收更新。请阅读公告文章获取迁移指南和建议的替代方案。
该镜像属于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)。
Dockerfile# 指定带有所需版本的Node基础镜像 FROM balenalib/asus-tinker-board-s-ubuntu-node:latest # 替换为应用程序的默认端口 EXPOSE 8888
然后可以构建并运行Docker镜像:
$ docker build -t my-nodejs-app . $ docker run -it --rm --name my-running-app my-nodejs-app
如果偏好使用Docker Compose:
version: "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运行:
$ docker-compose up -d
对于许多简单的单文件项目,可以直接使用Node.js Docker镜像运行脚本:
$ 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" | 未设置 |
要在容器中访问硬件设备,需要:
FROM balenalib/asus-tinker-board-s-ubuntu-node:latest ENV UDEV=1 # 暴露应用程序端口 EXPOSE 3000 # 运行应用 CMD ["node", "app.js"]
运行时需要添加--privileged标志或具体的设备映射:
$ 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 登录方式配置轩辕镜像加速服务,包含7个详细步骤
在 Linux 系统上配置轩辕镜像源,支持主流发行版
在 Docker Desktop 中配置轩辕镜像加速,适用于桌面系统
在 Docker Compose 中使用轩辕镜像加速,支持容器编排
在 k8s 中配置 containerd 使用轩辕镜像加速
在宝塔面板中配置轩辕镜像加速,提升服务器管理效率
在 Synology 群晖NAS系统中配置轩辕镜像加速
在飞牛fnOS系统中配置轩辕镜像加速
在极空间NAS中配置轩辕镜像加速
在爱快ikuai系统中配置轩辕镜像加速
在绿联NAS系统中配置轩辕镜像加速
在威联通NAS系统中配置轩辕镜像加速
在 Podman 中配置轩辕镜像加速,支持多系统
配置轩辕镜像加速9大主流镜像仓库,包含详细配置步骤
无需登录即可使用轩辕镜像加速服务,更加便捷高效
需要其他帮助?请查看我们的 常见问题 或 官方QQ群: 13763429