Мы запускаем процесс 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, мы постарались сделать это с таким же успехом.