Новомодный процесс перечислен как остановка/ожидание

У меня есть этот новомодный сценарий

Когда я работаю: sudo start poxa это запускает процесс, но когда я работаю: initctl list это показывает мне, который является, stop/waiting но когда я проверяю ps aux | grep poxa это показывает процесс.

И, как ожидалось, когда я пытаюсь остановить его: sudo stop poxa это возвращается: 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 poxa@127.0.0.1 -setcookie
poxa -user Elixir.IEx.CLI -extra --no-halt +iex -- console

Я сделал это: http://upstart.ubuntu.com/cookbook/#how-to-establish-fork-count для получения количества ветвления, но это возвращается 44!

4
задан 6 December 2015 в 19:46

2 ответа

Можно проверить, если добавление expect fork (ниже umask 022 строка) помогает. Если poxa двоичный файл переходит к фону, это должно помочь выскочке отследить pid

0
ответ дан 1 December 2019 в 09:33

Новомодный демон работает с тремя режимами демона: no expect, expect fork, expect daemon, 6.13.5 Последствия Misspecifying ожидают

Как Вы видите в там, необходимо проверить количество ветвления процесса.

Если Вы вставляете expect fork, "exec /home/ec2-user/poxa/rel/poxa/bin/poxa start" обработайте должен fork однажды и exit. Также это должно fork дважды и exit для expect daemon. Выскочка будет trace тот последний дочерний pid.

Для выполнения демона правильно с новомодным сценарием необходимо проверить fork из poxa процесс.

Следующее является моим примером для выскочки и простого демона.

новомодный сценарий в /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 для /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;
}

И этот исходный файл C может быть скомпилирован в исполняемый двоичный файл со следующей командой.

$ gcc -o egdaemon egdaemon.c
5
ответ дан 1 December 2019 в 09:33

Другие вопросы по тегам:

Похожие вопросы: