Serviço de início automático

2

Estou procurando uma maneira de configurar um serviço para ser executado automaticamente sempre que ele parar por algum motivo. Atualmente eu configurei um cronjob que verifica se o serviço está rodando a cada minuto e o reinicia se ele caiu, mas isso parece monótono. Como posso fazer isso da maneira certa?

Eu adicionei alguns scripts questionáveis para fazer o serviço funcionar, você pode ver abaixo

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

E também my-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

Por exemplo, quando a máquina é reinicializada, recebo isso como status

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.
    
por php_nub_qq 24.01.2017 / 09:52

1 resposta

1

Você pode usar a ferramenta monit . é muito pequeno e útil para qualquer tipo de gerenciamento e monitoramento de processos.

Depois de fazer o download do pacote binário de este link , você pode extraí-lo para qualquer pasta em seu sistema e copiar dois arquivos de o pacote ao seu sistema para instalá-lo:

cd /path/to/monit/folder
cp ./bin/monit /usr/sbin/monit
cp ./conf/monitrc /etc/monitrc  

Agora edite /etc/monitrc base de acordo com suas necessidades ( doc de referência ). em seguida, crie um arquivo de controle init para ativar o monit na inicialização. agora comece a monitorar desta forma:

initctl reload-configuration
start monit
    
por Ghasem Pahlavan 24.01.2017 / 10:15