Supervisord "exit-status 1 nicht zu erwarten" php-Skript

Bin ich mit Problem versuchen zu konfigurieren, supervisor, um ein php-Skript. Ausführen von supervisor im debug-Modus gibt mir diese:

2015-03-09 08:53:06,342 INFO supervisord started with pid 2030
2015-03-09 08:53:06,358 INFO spawned: 'worker1' with pid 2031
2015-03-09 08:53:06,423 INFO exited: worker1 (exit status 1; not expected)
2015-03-09 08:53:06,424 INFO received SIGCLD indicating a child quit
2015-03-09 08:53:07,440 INFO spawned: 'worker1' with pid 2032
2015-03-09 08:53:07,587 INFO exited: worker1 (exit status 1; not expected)
2015-03-09 08:53:07,589 INFO received SIGCLD indicating a child quit
2015-03-09 08:53:09,604 INFO spawned: 'worker1' with pid 2033
2015-03-09 08:53:09,756 INFO exited: worker1 (exit status 1; not expected)
2015-03-09 08:53:09,758 INFO received SIGCLD indicating a child quit
2015-03-09 08:53:12,775 INFO spawned: 'worker1' with pid 2034
2015-03-09 08:53:12,973 INFO exited: worker1 (exit status 1; not expected)
2015-03-09 08:53:12,974 INFO received SIGCLD indicating a child quit
2015-03-09 08:53:13,976 INFO gave up: worker1 entered FATAL state, too many start retries too quickly

Den supervisord Konfiguration:

[program:worker1]
command=php myScript.php
directory=/home/path/to/script/
user=root
autostart=true
autorestart=true
stderr_logfile=/var/log/worker1.err.log
stdout_logfile=/var/log/worker1.out.log
redirect_stderr=true
environment=PATH="/usr/bin"

Für diesen test myScript.php einfach ausdrucken echo "test".PHP_EOL;

Gibt es keine logs Fehlermeldungen von php, und wenn ich das Skript ausführen thru cli funktioniert es wie erwartet. Der supervisord anmelden so melden Sie die gleiche Ausgabe wie debuggin.

Habe ich auch versucht, mit absoluten Pfaden wie /usr/bin/php /home/path/to/script/myScript.php aber es ändert sich nichts.

Datei, die Erlaubnis für myScript.php eingestellt sind -rwxrwxr-x 1 root apache

Weiß wirklich nicht, was ich sonst noch überprüfen könnte. Danke für die Unterstützung!

UPDATE_1

Ich habe auch versucht zu überwachen anderen Programm wie /bin/cat oder ein bash-Skript und funktioniert wie ein Charme. Das problem scheint zu sein, beschränkt auf die php.

UPDATE_2

B. N. B. wies darauf hin, in der Kommentare, die ich geändert habe das test-script Aussehen mehr lange-laufen-job:

while(true){
    echo "test".PHP_EOL;
    sleep(10);
}

Gleiche wie zuvor, begibt er sich in TÖDLICHE Zustand.

Sagen Sie, dass nichts in "worker1.err.log" ?
Nope, nichts. Es ist noch nicht angelegt...
haben Sie versucht, den vollständigen Pfad zum Skript in der "command" - Zeile?
Yep, versucht, läuft es wie: /usr/bin/php /home/path/to/script/myScript.php. Kein Unterschied.
redirect_stderr umleiten, um Sie stdout, nehme ich an es gibt nichts in Ihrem stdout als auch?

InformationsquelleAutor Luciano | 2015-03-09

Schreibe einen Kommentar