У меня есть файл конфигурации выскочки, как показано ниже, который отлично работает в Ubuntu 14:
#/etc/init/data_server.conf
#sudo start data_server
#sudo stop data_server
#sudo status data_server
start on runlevel [2345]
stop on runlevel [016]
chdir /opt/hold/data_server
respawn
post-start script
echo "data server started at `date +"%F %T"` on `hostname -f`" | mailx -r "abc@host.com" -s "data server Started" "pqr@host.com"
end script
post-stop script
sleep 30
end script
limit core unlimited unlimited
limit nofile 100000 100000
setuid goldy
exec ./proc_server --init_file=../config/tree.init --port=8080 --dir=/data/hold/ --max_sec=2400 --max_mb=100 --active=5
Теперь мы переходим на Ubuntu 16, поэтому мы не можем использовать upstart
и похоже, что нам нужно использовать systemd
Вот. Я должен убедиться, что при перезагрузке системы или завершении работы приложения мой systemd
скрипт автоматически, который, в свою очередь, запускает мой data server
. Итак, я придумал ниже systemd
скрипт: Сообщите мне, правильно ли я поступаю, поскольку я делаю это впервые?
[Unit]
Description=test server
After=network.target
StartLimitIntervalSec=0
[Service]
User=goldy
Group=goldy
Type=simple
WorkingDirectory=/opt/hold/data_server
ExecStart=/opt/hold/data_server/proc_server --init_file=../config/tree.init --port=8080 --dir=/data/hold/ --max_sec=2400 --max_mb=100 --active=5
Restart=always
RestartSec=3
LimitNOFILE=100000
LimitCORE=infinity
[Install]
WantedBy=multi-user.target
Всякий раз, когда я запускаю вышеуказанный скрипт, он выдает эту ошибку, я не уверен, что не так?
[/lib/systemd/system/queue_server_two.service:3] Unknown lvalue 'StartLimitIntervalSec' in section 'Unit'
Вы, вероятно, сравниваете systemd
документы, которые вы читали в Интернете для другой версии, вместо того, чтобы использовать документы в вашей системе, соответствующие вашей версии.
Проверьте man systemd.unit
в вашей собственной системе. Вы можете обнаружить, что в вашей версии директива называется
StartLimitInterval=
и должен использоваться [Service]
не [Unit]
.
Я нашел ответ, выполнив поиск systemd StartLimitIntervalSec.