balenalib/asus-tinker-board-s-debian-node该镜像属于balena.io物联网设备基础镜像系列,针对balena.io平台和balenaOS进行了优化,同时也可在任何适当架构的Docker环境中使用。它基于Node.js,为物联网设备上的Node.js应用开发和部署提供了精简高效的运行环境。
!balenalogo
提供名为install_packages的实用软件包安装脚本,抽象了底层包管理器的细节。该脚本具有以下特点:
每个balenalib基础镜像都默认设置了ENTRYPOINT ["/usr/bin/entry.sh"],可处理动态插入的设备:
ENV UDEV=1启用udev支持udevd守护进程,使容器内/dev目录中出现相关设备节点更多详细信息,请查看特性概述文档。
balenalib镜像提供多种变体,适用于不同使用场景:
:<version> 或 :<version>-run这是默认镜像。run变体设计为精简版本,仅包含运行时必需组件,体积小巧。
:<version>-build构建变体是较完整的镜像,包含许多从源代码构建所需的工具。这减少了在Dockerfile中手动安装的软件包数量,从而减小系统中所有镜像的总体积。
了解更多变体信息
适用于在物联网设备(如华硕Tinker Board S)上开发和部署Node.js应用,特别适合需要与硬件设备交互、资源受限环境下的应用开发。可用于构建实时数据处理、设备监控、边缘计算等物联网解决方案。
快速入门指南可帮助您开始使用此基础镜像,同时还有一些示例项目展示其功能。
Node.js是一个用于可扩展服务器端和网络应用的软件平台。Node.js应用使用JavaScript编写,可在Mac OS X、Windows和Linux上的Node.js运行时中无需修改即可运行。
Node.js应用旨在通过非阻塞I/O和异步事件最大化吞吐量和效率。Node.js应用单线程运行,但会为文件和网络事件使用多线程。由于其异步特性,Node.js常用于实时应用。
Node.js内部使用Google V8 JavaScript引擎执行代码;大部分基础模块使用JavaScript编写。Node.js包含内置的异步I/O库,用于文件、套接字和HTTP通信。HTTP和套接字支持使Node.js无需Apache等额外软件即可作为Web服务器运行。
***.org/wiki/Node.js
!Node.js logo
18.7.0 (latest)、16.17.0、14.20.0、12.22.12
有关该镜像及其历史的更多信息,请查看相关清单文件(asus-tinker-board-s-debian-node),位于balena-io-library/official-images GitHub仓库。
dockerfile# 指定所需版本的Node.js基础镜像 node:<version> FROM balenalib/asus-tinker-board-s-debian-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/asus-tinker-board-s-debian-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的文件,其中定义了start脚本。
对于许多简单的单文件项目,编写完整的Dockerfile可能不方便。这种情况下,可以直接使用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-debian-node:latest node your-daemon-or-script.js
如果对该镜像有任何问题或疑问,请通过GitHub issue与我们联系。
欢迎贡献新功能、修复或更新(无论大小);我们始终乐于接收拉取请求,并会尽快处理。
在开始编码之前,建议通过GitHub issue讨论您的计划,尤其是对于更复杂的贡献。这让其他贡献者有机会为您指明方向、提供设计反馈,并帮助您了解是否有人在做相同的工作。
该镜像的文档存储在基础镜像文档中。查看该文档可获取所有基础镜像的列表,包括许多专用镜像(如node、python、go、更小的镜像等)。
您还可以在这篇博客文章中找到balenalib基础镜像新功能的更多详细信息。


manifest unknown 错误
TLS 证书验证失败
DNS 解析超时
410 错误:版本过低
402 错误:流量耗尽
身份认证失败错误
429 限流错误
凭证保存错误
来自真实用户的反馈,见证轩辕镜像的优质服务