Processo Upstart listado como stop / waiting

4

Eu tenho este script inicial

Quando eu executo: sudo start poxa ele inicia o processo, mas quando eu executo: initctl list me mostra que é stop/waiting , mas quando eu verifico ps aux | grep poxa ele mostra o processo.

E, como esperado, quando eu tentar pará-lo: sudo stop poxa retorna: stop: unknown instance:

# Upstart Configuration
# put on /etc/init
description     "Poxa"
author          "Poxa"

start on (filesystem or runlevel [2345])
stop on runlevel [!2345]

#respawn
#respawn limit 10 5
umask 022

console none

pre-start script
    test -x /home/ec2-user/poxa/rel/poxa/bin/poxa || { stop; exit 0; }
end script

pre-stop script
        echo "['date -u +%Y-%m-%dT%T.%3NZ'] Stoping..." >> /var/log/poxa.log 2>&1
end script

script
        export HOME=/home/ec2-user
        echo "['date -u +%Y-%m-%dT%T.%3NZ'] Starting..." >> /var/log/poxa.log 2>&1
        exec /home/ec2-user/poxa/rel/poxa/bin/poxa start >> /var/log/poxa.log 2>&1
end script

ps aux | grep poxa

root     29032  0.0  0.1  13656  1720 ?        S    11:42   0:00 /usr/local/lib/erlang/erts-7.0/bin/run_erl -daemon /home/ec2-user/poxa/rel/poxa/tmp/erl_pipes/poxa/ /home/ec2-user/poxa/rel/poxa/log exec "/home/ec2-user/poxa/rel/poxa/bin/poxa" "console"
root     29033  0.3  2.0 318992 21100 pts/1    Ssl+ 11:42   0:00 /usr/local/lib/erlang/erts-7.0/bin/beam -- -root /home/ec2-user/poxa/rel/poxa -progname home/ec2-user/poxa/rel/poxa/releases/0.4.3/poxa.sh -- -home /home/ec2-user -- -boot /home/ec2-user/poxa/rel/poxa/releases/0.4.3/poxa -boot_var ERTS_LIB_DIR /usr/local/lib/erlang/erts-7.0/../lib -config /home/ec2-user/poxa/rel/poxa/running-config/sys.config -pa /home/ec2-user/poxa/rel/poxa/lib/consolidated -name [email protected] -setcookie
poxa -user Elixir.IEx.CLI -extra --no-halt +iex -- console

Eu fiz isso: link para obter a contagem de bifurcação, mas ela retorna 44 !

    
por Gerep 27.11.2015 / 11:24

2 respostas

5

O daemon Upstart trabalha com três modos de daemon: no expect , expect fork , expect daemon , 6.13.5 Implicações da Especificação errada esperam

Como você pode ver lá, você precisa verificar a contagem do processo.

Se você inserir expect fork , o processo "exec /home/ec2-user/poxa/rel/poxa/bin/poxa start" precisará fork once e exit . Também precisa de fork duas vezes e exit para expect daemon . O iniciante será trace desse último filho pid.

Para executar o daemon corretamente com o script upstart, você precisa verificar o fork de poxa process.

A seguir, meu exemplo para daemon upstart e simples.

script upstart em /etc/init

# egservice - eg daemon
#
# This is an example
# upstart script.

description    "egservice"

start on runlevel [2345]
stop on runlevel [!2345]
#LOOK Following line, So egdaemon needs to fork just once.
expect fork
respawn

exec /sbin/egdaemon

egdaemon.c para /sbin/egdaemon

#include <stdio.h>

int main()
{
    /* LOOK following line, just once fork and main does not wait child and die, 
    so new child will be changed to a init's child and also a daemon. */
    int pid = fork();
    if (pid == 0) {
        while (1) {
            printf("Example daemon\n");
            sleep(1);
        }
    }
    return 0;
}

E este arquivo-fonte C pode ser compilado em um binário executável com o seguinte comando.

$ gcc -o egdaemon egdaemon.c
    
por xiaodongjie 06.12.2015 / 15:46
0

Você pode verificar se adicionar expect fork (abaixo de umask 022 line) ajuda. Se o binário poxa for para segundo plano, isso ajudará o upstart a rastrear o pid.

    
por Łukasz 05.12.2015 / 18:51