balenalib/asus-tinker-board-s-openjdk该镜像属于balena.io IoT设备基础镜像系列,专为物联网设备优化,适用于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中手动安装的软件包数量,从而减小系统中所有镜像的总体大小。
OpenJDK(开放Java开发工具包)是Java平台标准版(Java SE)的免费开源实现。自版本7起,OpenJDK成为Java SE的官方参考实现。
***.org/wiki/OpenJDK
Java是Oracle及其关联公司的注册商标。
!logo
使用该镜像最直接的方式是将Java容器同时作为构建和运行时环境。在Dockerfile中,可编写如下内容来编译和运行项目:
dockerfileFROM balenalib/asus-tinker-board-s-debian-openjdk:latest COPY . /usr/src/myapp WORKDIR /usr/src/myapp RUN javac Main.java CMD ["java", "Main"]
然后可构建并运行Docker镜像:
console$ docker build -t my-java-app . $ docker run -it --rm --name my-running-app my-java-app
有时可能不需要在容器内运行应用,仅需编译。可使用如下命令在Docker实例内编译但不运行应用:
console$ docker run --rm -v "$PWD":/usr/src/myapp -w /usr/src/myapp balenalib/asus-tinker-board-s-debian-openjdk:latest javac Main.java
该命令会将当前目录挂载为容器卷,设置工作目录为该卷,并运行javac Main.java命令,指示Java编译Main.java中的代码,并将Java类文件输出到Main.class。
如对该镜像有任何问题或疑问,请通过GitHub issue与我们联系。
我们欢迎您贡献新功能、修复或更新(无论大小);我们始终乐于接收拉取请求,并会尽力快速处理。
在开始编码前,建议通过GitHub issue讨论您的计划,尤其是对于较复杂的贡献。这能让其他贡献者为您指明方向、提供设计反馈,并帮助您了解是否有人正在开发相同功能。
该镜像的文档存储在基础镜像文档中。您可以在其中查看我们所有的基础镜像,包括许多专门用于node、python、go等的镜像以及更小的镜像等。
您还可以在这篇博客文章中找到balenalib基础镜像新功能的更多详情。

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