Я ищу способ настроить сервис для выполнения автоматически каждый раз, когда он останавливается по некоторым причинам. В настоящее время я настраивал cronjob, который проверяет, работает ли услуга каждую минуту и перезапускает его, если он отказал, но это кажется тусклым. Как я могу сделать это правильный путь?
Я добавил некоторые сомнительные сценарии, чтобы заставить сервис работать, Вы видите ниже
x@x:~$ sudo cat /etc/init.d/my-service
#!/bin/sh
### BEGIN INIT INFO
# Provides: my-service
# Required-Start: $remote_fs $syslog
# Required-Stop: $remote_fs $syslog
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Start daemon at boot time
# Description: Enable service provided by daemon.
### END INIT INFO
dir="/var/www/html/my-service"
cmd="nodejs chat.js"
user="www-data"
name=`basename $0`
pid_file="/var/run/$name.pid"
stdout_log="/var/log/$name.log"
stderr_log="/var/log/$name.err"
get_pid() {
cat "$pid_file"
}
is_running() {
[ -f "$pid_file" ] && ps `get_pid` > /dev/null 2>&1
}
case "$1" in
start)
if is_running; then
echo "Already started"
else
echo "Starting $name"
cd "$dir"
if [ -z "$user" ]; then
sudo $cmd >> "$stdout_log" 2>> "$stderr_log" &
else
sudo -u "$user" $cmd >> "$stdout_log" 2>> "$stderr_log" &
fi
echo $! > "$pid_file"
if ! is_running; then
echo "Unable to start, see $stdout_log and $stderr_log"
exit 1
fi
fi
;;
stop)
if is_running; then
echo -n "Stopping $name.."
kill `get_pid`
for i in {1..10}
do
if ! is_running; then
break
fi
echo -n "."
sleep 1
done
echo
if is_running; then
echo "Not stopped; may still be shutting down or shutdown may have f ailed"
exit 1
else
echo "Stopped"
if [ -f "$pid_file" ]; then
rm "$pid_file"
fi
fi
else
echo "Not running"
fi
;;
restart)
$0 stop
if is_running; then
echo "Unable to stop, will not attempt to start"
exit 1
fi
$0 start
;;
status)
if is_running; then
echo "Running"
else
echo "Stopped"
exit 1
fi
;;
*)
echo "Usage: $0 {start|stop|restart|status}"
exit 1
;;
esac
exit 0
И также мой-service.service
x@x:~$ cat /etc/systemd/system/my-service.service
[Unit]
Description=my-service daemon
[Service]
ExecStart=/usr/bin/nodejs /var/www/html/my-service/chat.js
Type=simple
User=root
Group=root
Restart=always
[Install]
WantedBy=multi-user.target
Например, когда перезагрузки машины я получаю это как состояние
Jan 24 10:54:41 x systemd[1]: my-service.service: Service hold-off time over, scheduling restart.
Jan 24 10:54:41 x systemd[1]: Stopped my-service daemon.
Jan 24 10:54:41 x systemd[1]: my-service.service: Start request repeated too quickly.
Jan 24 10:54:41 x systemd[1]: Failed to start my-service daemon.
Можно использовать инструмент monit . это является очень маленьким и полезным для любого типа управления процессами и контроля.
После Загрузки двоичного пакета от эта ссылка , можно извлечь его к любой папке в системе и затем скопировать два файла от пакета до системы для установки его:
cd /path/to/monit/folder
cp ./bin/monit /usr/sbin/monit
cp ./conf/monitrc /etc/monitrc
Теперь редактирование /etc/monitrc
основа на Ваших потребностях ( справочный документ ). затем создайте файл управления init для включения monit на запуске. теперь запустите monit этот путь:
initctl reload-configuration
start monit