我在尝试运行使用 spring boot 创建的可引导 jar 的 Centos Dist 上遇到了一个奇怪的行为。
如果我从 shell 运行 jar 应用程序,它会完美运行
使用以下配置创建的服务运行应用程序时:
[Unit]
Description=app
After=syslog.target
[Service]
ExecStart=/foo/bar/app.jar
SuccessExitStatus=143
[Install]
WantedBy=multi-user.target
~
我不断收到错误“无法找到 Java”我检查了 $PATH 和 $JAVA_HOME 属性并且它们设置正确(我不认为这会增加更多信息,因为可引导 jar 在没有服务的情况下正确运行)
我做错了什么?解决这个问题 3 天了,这让我很生气。
最佳答案
问题的长短在于 systemd 不会在与用户 shell 相同的上下文中运行服务,用于运行 .jar 文件的机制直接使用 PATH
变量来确定运行 jar 的 JRE 的位置。
如果 java 在默认的 systemd 路径上,则该服务将默认启动。 default path for systemd绝对不包含您为 java 指定的路径。
为了解决 PATH 变量设置不充分的问题,我们将使用 PATH
更新服务配置。环境变量更适合它。为此,我们需要添加 Environment
[Service]
的变量服务定义文件的部分。
[Unit]
Description=app
After=syslog.target
[Service]
Environment=PATH=/usr/lib/jvm/jdk-14.0.2/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
ExecStart=/foo/bar/app.jar
SuccessExitStatus=143
[Install]
WantedBy=multi-user.target
然后我们重新加载systemd(systemctl daemon-reload
),我们应该能够启动服务(systemctl start blah.service
)。如果您要使用的 jre 集成到操作系统中,可能会容易得多;它省去了在 PATH 上的麻烦,并且可以在升级到 java 后幸存下来,这会改变路径,需要更新服务定义 - 有一个漂亮的 good guide here至于如何安装,系统集成:
wget --no-check-certificate -c --header "Cookie: oraclelicense=accept-securebackup-cookie" https://download.oracle.com/otn-pub/java/jdk/14.0.2+12/205943a0976c4ed48cb16f1043c5c647/jdk-14.0.2_linux-x64_bin.rpm
yum localinstall jdk-14.0.2_linux-x64_bin.rpm
alternatives
配置javaalternatives --config java
java -version
关于java - systemd 找不到 Java,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63377036/