
如果你使用 DeepSeek、元宝 AI、Copilot、ChatGPT 等 AI 工具,协助配置轩辕镜像、编写 docker pull 命令、修改 Docker Compose 镜像地址、配置镜像加速、排查镜像拉取失败、分析报错日志等问题,请先让 AI 阅读并遵守轩辕镜像的规则文档。
只需在 AI 对话中先发送下面这句话即可:
请先完整阅读并严格遵守以下文档中的全部规则与要求:
https://xuanyuan.cloud/agents.md
在未充分阅读并理解该文档前,不要生成任何命令、配置、修改建议、故障排查方案或技术回答。后续所有输出都必须严格以该文档中的规范为最高优先级执行。查看 agents.md 用法指南与完整示范。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
该镜像基于Alpine构建,提供OpenJDK 8 (JRE)运行环境。主要包含以下组件:
/deployments/run-java.sh。若需为应用启用Jolokia,应将此镜像作为基础镜像(通过FROM指令),并在启动脚本中使用agent-bond-opts的输出结果,将其包含到Java启动选项中。
例如,可在启动Java应用的脚本中添加以下片段:
bash# ... export JAVA_OPTIONS="$JAVA_OPTIONS $(agent-bond-opts)" # .... 启动应用时使用JAVA_OPTIONS,如Tomcat的启动方式
默认使用以下版本及配置:
可通过设置环境变量调整agent-bond-opts的行为:
可通过以下环境变量配置Agent Bond:
jolokia和jmx_exporter。默认两者均启用。Jolokia配置
/opt/jolokia/jolokia.properties。0.0.0.0)8778)AB_JOLOKIA_OPTS中未配置serverCert,默认生成自签名服务器证书。$HOSTNAME,即容器ID)特定环境集成选项:
/var/run/secrets/kubernetes.io/serviceaccount/ca.crt。jmx_exporter配置
jmx_exporter的配置,格式为<port>:<配置文件路径>9779jmx_exporter的配置文件路径。默认:/opt/agent-bond/jmx_exporter_config.json该镜像的默认命令为https://github.com/fabric8io/run-java-sh%E3%80%82%E5%85%B6%E7%94%A8%E9%80%94%E6%98%AF%E5%90%AF%E5%8A%A8Java%E5%BA%94%E7%94%A8%EF%BC%8C%E6%94%AF%E6%8C%81%E4%BB%A5fat-jars%EF%BC%88%E5%8C%85%E5%90%AB%E6%89%80%E6%9C%89%E4%BE%9D%E8%B5%96%EF%BC%89%E6%88%96%E4%B8%BB%E7%B1%BB%EF%BC%88%E4%BB%8E%E7%9B%AE%E5%BD%95%E4%B8%AD%E7%9A%84%E6%89%80%E6%9C%89jar%E6%9E%84%E5%BB%BA%E7%B1%BB%E8%B7%AF%E5%BE%84%EF%BC%89%E6%96%B9%E5%BC%8F%E8%BF%90%E8%A1%8C%E3%80%82
对于这些镜像,变量JAVA_APP_DIR的默认值为/deployments。
此通用启动脚本针对容器内运行Java应用优化,调用方式如下:
bash./run-java.sh <子命令> <选项>
run-java.sh支持两个子命令:
options:输出JVM选项,可用于自定义Java应用启动(如Maven或Tomcat)。会考虑容器约束并包含脚本使用的所有配置逻辑。run:启动Java应用(如下所述)。这也是默认命令,可省略。当未指定子命令(或使用默认子命令run)时,脚本默认启动Java应用。
启动过程主要通过环境变量配置:
classpath文件的目录。classpath文件可为单行冒号分隔的类路径,或每行列出一个jar文件。若未设置,JAVA_LIB_DIR与JAVA_APP_DIR相同。java时添加的选项。JAVA_VERSION变量、release文件或解析java -version输出猜测。JAVA_OPTIONS中未指定-Xmx时使用。基于容器内存限制计算默认最大堆内存。若容器无内存限制则无效;若有内存限制,-Xmx设为容器可用内存的指定比例。默认值:容器可用内存<300M时为25,否则为50(即使用50%可用内存)。设为0可禁用此机制。JAVA_OPTIONS中未指定-Xms时使用。基于容器内存限制计算默认初始堆内存。若容器无内存限制则无效。默认未设置。java参数的主类。设置此变量时,$JAVA_APP_DIR中的所有jar及$JAVA_LIB_DIR均添加到类路径。java -jar启动(若未设置$JAVA_MAIN_CLASS)。无论如何,此jar均添加到类路径。${JAVA_APP_DIR}/classpath文件,其内容直接作为类路径;若文件不存在,添加classes:${JAVA_APP_DIR}/*(即目录中所有jar)。http.proxyHost和http.proxyPort系统属性。https.proxyHost和https.proxyPort系统属性。http.nonProxyHosts系统属性。若未设置$JAVA_APP_JAR和$JAVA_MAIN_CLASS,脚本检查$JAVA_APP_DIR中的单个JAR文件作为$JAVA_APP_JAR;若未找到或找到多个,抛出错误。
类路径构建规则:
$JAVA_CLASSPATH,直接使用。$JAVA_APP_DIR不同,添加$JAVA_APP_DIR。$JAVA_MAIN_CLASS:
$JAVA_APP_JAR,添加该jar。$JAVA_APP_DIR/classpath文件存在,其内容追加到类路径(可为单行冒号分隔或多行,每行是相对于$JAVA_LIB_DIR的jar路径)。${JAVA_APP_DIR}/*(按字母顺序添加目录中所有jar)。这些变量也可在run-env.sh shell配置文件中设置,启动脚本会加载该文件。该文件可位于启动脚本目录或${JAVA_APP_DIR},后者中的环境变量覆盖前者。
脚本还会检查run-java-options命令,若存在,其输出添加到$JAVA_OPTIONS。
脚本暴露描述容器限制的环境变量,供应用使用:
脚本的所有参数直接传递给Java应用。
示例:
bash# 直接设置应用目录 export JAVA_APP_DIR=/deployments # 基于容器约束设置-Xmx export JAVA_MAX_MEM_RATIO=40 # 启动JAVA_APP_DIR中的jar并传递参数 ./run-java.sh --user maxmorlock --password secret
该脚本还可用于计算通用的Java应用启动最佳实践选项。例如,在容器中运行Maven时,应考虑容器内存约束。
子命令options可输出选项到标准输出,便于供其他Java应用使用。
未指定额外参数时,使用默认值(可通过上述环境变量调整)。
可通过额外参数选择特定选项集:
--debug:若JAVA_DEBUG设置,输出Java调试选项--memory:基于环境变量的内存设置--proxy:解析代理环境变量--cpu:核心数受限时的调优--gc:GC调优参数--jit:JIT选项--diagnostics:若JAVA_DIAGNOSTICS设置,输出诊断选项--java-default:等同于--memory --jit --diagnostic --cpu --gc示例:
bash# 在容器中运行Maven时使用适当的内存设置 export MAVEN_OPTS="$(run-java.sh options --memory)" mvn clean install
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务