Мы запускаем процесс Java с помощью следующей команды:

/usr/bin/java -classpath /home/somejavadaemon/Java/classes:/home/somejavadaemon/Java/classes/mail.jar:/home/somejavadaemon/Java/classes/commons-logging-1.2.jar:/home/somejavadaemon/Java/classes/httpclient-4.5.2.jar:/home/somejavadaemon/Java/classes/httpcore-4.4.4.jar core.Main configFile=/home/somejavadaemon/Java/config.cfg

При запуске из пользовательской оболочки (somejavadaemon) все в порядке - демон работает и делает то, что должен.

Теперь мы хотим сделать это из файла модуля Systemd:

[Unit]
Description=somejavadaemon service
After=network-online.target
Wants=network-online.target systemd-networkd-wait-online.service

[Service]

User=somejavadaemon
Group=somejavadaemon

Environment=JAVA_HOME=/usr/lib/jvm/java-8-oracle
Environment=J2SDKDIR=/usr/lib/jvm/java-8-oracle
Environment=DERBY_HOME=/usr/lib/jvm/java-8-oracle/db
Environment=J2REDIR=/usr/lib/jvm/java-8-oracle/jre
Environment=PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/lib/jvm/java-8-oracle/bin:/usr/lib/jvm/java-8-oracle/db/bin:/usr/lib/jvm/java-8-oracle/jre/bin

ExecStart=/usr/bin/java -classpath /home/somejavadaemon/Java/classes:/home/somejavadaemon/Java/classes/mail.jar:/home/somejavadaemon/Java/classes/commons-logging-1.2.jar:/home/somejavadaemon/Java/classes/httpclient-4.5.2.jar:/home/somejavadaemon/Java/classes/httpcore-4.4.4.jar core.Main configFile=/home/somejavadaemon/Java/config.cfg

[Install]
WantedBy=multi-user.target

По учетным записям Systemd, служба запускается - процесс находится в памяти. Однако, когда я смотрю на его статус, я вижу следующее: Exception in thread "main" java.lang.OutOfMemoryError: unable to create new native thread at java.lang.Thread.start0(Native Method) at java.lang.Thread.start(Thread.java:717) at whois.WhoisThreadPool$WhoisThread.start(WhoisThreadPool.java:319) at whois.WhoisThreadPool.init(WhoisThreadPool.java:42) at whois.WhoisThreadPool.<init>(WhoisThreadPool.java:36) at whois.Whois.<init>(Whois.java:49) at core.Main.main(Main.java:110) Почему это происходит? Чем запуск Systemd отличается от запуска из пользовательской оболочки? То же самое и с cron, мы постарались сделать это с таким же успехом.

0