systemd.unit 中带有 %p 的 jvm 选项 -Xloggc 给出了错误的日志文件名

systemd.unit 中带有 %p 的 jvm 选项 -Xloggc 给出了错误的日志文件名

我有一个 java 进程,我想使用以下选项运行它:

-Xloggc:/var/log/mylog_%p.gc.log

以便日志文件的名称包含 PID。例如,如果进程的 PID 为 3498,则日志文件名称为/var/log/mylog_pid3498.gc.log.我希望 Java 进程由系统单元文件。单元文件为:

[Service]
User=ubuntu
Type=simple
WorkingDirectory=/home/ubuntu/my_code
ExecStart=/usr/bin/java -Xloggc:/var/log/mylog_%%p.gc.log -jar my_code.jar
Restart=always

请注意,我使用了该%%字符来转义%.然而,这并没有给出预期的结果,因为我知道日志文件有 name /var/log/mylog_%p.gc.log,即 Java 无法%p用实际的 PID 进行替换。

任何想法?谢谢!

操作系统:

Ubuntu 16.04.3 LTS (GNU/Linux 4.4.0-1066-aws x86_64)

Java版本:

java version "1.8.0_181"
Java(TM) SE Runtime Environment (build 1.8.0_181-b13)
Java HotSpot(TM) 64-Bit Server VM (build 25.181-b13, mixed mode)

系统版本:

systemd 229
+PAM +AUDIT +SELINUX +IMA +APPARMOR +SMACK +SYSVINIT +UTMP +LIBCRYPTSETUP +GCRYPT +GNUTLS +ACL +XZ -LZ4 +SECCOMP +BLKID +ELFUTILS +KMOD -IDN

更新

systemctl show -p ExecStart --no-pager my_service
ExecStart={ path=/usr/bin/java ; argv[]=/usr/bin/java -Xloggc:/var/log/mylog_%%p.gc.log -jar my_code.jar ; ignore_errors=no ; start_time=[Tue 2018-11-27 17:08:43 UTC] ; stop_time=[n/a] ; pid=1664 ; code=(null) ; status=0/0 }

相关内容