web-dev-qa-db-ja.com

停止/待機としてリストされたアップスタートプロセス

私はこのスタートアップスクリプトを持っています

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 [email protected] -setcookie
poxa -user Elixir.IEx.CLI -extra --no-halt +iex -- console

これを作成しました: http://upstart.ubuntu.com/cookbook/#how-to-establish-fork-count fork countを取得しますが、44!を返します!

4
Gerep

Upstartデーモンは、3つのデーモンモードで動作します:no expectexpect forkexpect daemon6.13.5 expect の指定ミスの影響

ご覧のとおり、プロセスフォークカウントを確認する必要があります。

expect forkを挿入する場合、"exec /home/ec2-user/poxa/rel/poxa/bin/poxa start"プロセスはforkを1回、exitにする必要があります。また、forkを2回、expect daemonに対してexitにする必要があります。 upstartはtraceその最後の子pidになります。

Upstartスクリプトを使用してデーモンを正しく実行するには、fork of poxaプロセスを確認する必要があります。

以下は、upstartと単純なデーモンの例です。

/etc/initのupstartスクリプト

# 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 for /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
xiaodongjie

expect fork(以下のumask 022行)の追加が役立つかどうかを確認できます。 poxaバイナリがバックグラウンドに移行する場合、これはpidを追跡するための新興企業に役立つはずです。

0
Łukasz