In diesem Artikel werden hauptsächlich die beiden Daemon-Methoden in PHP vorgestellt. Ich hoffe, dass er allen helfen kann.
Die erste Möglichkeit besteht darin, nohup und & zusammen zu verwenden.
Durch das Hinzufügen des kaufmännischen Und-Zeichens nach dem Befehl kann der gestartete Prozess im Hintergrund ausgeführt werden, ohne die Konsole zu belegen. Hier verwende ich eine while-Endlosschleife, um dies zu demonstrieren 🎜>
<?php while(true){ echo time().PHP_EOL; sleep(3); }
Verwendung und Methode zum Starten des Prozesses
[root@localhost php]# php deadloop.php & [1] 3454 [root@localhost php]# ps aux | grep 3454 root 3454 0.0 0.8 284544 8452 pts/0 T 18:06 0:00 php deadloop.php root 3456 0.0 0.0 103316 896 pts/0 S+ 18:08 0:00 grep 3454 [1]+ Stopped php deadloop.php [root@localhost php]#
Sie können sehen, dass der Prozess die Konsole nicht belegt und die Konsole zu diesem Zeitpunkt auch andere Befehle ausführen kann Wir können auch den Befehl fg verwenden, um den Prozess wieder in den normalen Modus der Konsolenbelegung zu versetzen.
[root@localhost php]# fg php deadloop.php 1470996682 1470996685 1470996688 1470996691
Das Obige ist eine kurze Einführung in den &-Befehl
SIGHUP会在以下3种情况下被发送给相应的进程: 1、终端关闭时,该信号被发送到session首进程以及作为job提交的进程(即用 & 符号提交的进 程) 2、session首进程退出时,该信号被发送到该session中的前台进程组中的每一个进程 3、若父进程退出导致进程组成为孤儿进程组,且该进程组中有进程处于停止状态(收到SIGSTOP或 SIGTSTP信号),该信号会被发送到该进程组中的每一个进程。
Durch die Kombination von 1 und 2 wissen wir, dass unabhängig davon, ob der Prozess mit & (Jobmodus) gestartet wird, der Das SIGHUP-Signal wird empfangen, wenn das Terminal geschlossen wird. Wie wird der Prozess mit dem SIGHUP-Signal umgehen? , und die Standardverarbeitungsmethode dieses Signals besteht darin, den Prozess zu beenden und zu verarbeiten, oder ihn beispielsweise im folgenden Code
rrree
系统对SIGHUP信号的默认处理是终止收到该信号的进程。所以若程序中没有捕捉该信号,当收到该 信号时,进程就会退出。
<?php pcntl_signal(SIGHUP, function(){ //这地方处理信号的方式我们只是简单的写入一句日志到文件中 file_put_contents('logs.txt', 'pid : ' . posix_getpid() . ' receive SIGHUP 信号' . PHP_EOL); }); while(1) { sleep(10); pcntl_signal_dispatch(); }
Und nohup leitet die Ausgabe des Programms standardmäßig in die Datei nohup.out im aktuellen Verzeichnis um, falls vorhanden Keine Schreibberechtigung, dann schreiben Sie $homepath/nohup.out
[root@localhost php]# ps -ef | grep deadloop.php root 16112 1 0 17:20 ? 00:00:00 php deadloop.php root 16138 16115 0 17:24 pts/4 00:00:00 grep deadloop.php [root@localhost php]# cat logs.txt pid : 16112 receive SIGHUP 信号
Schließen Sie das Terminal zu diesem Zeitpunkt, der Prozess wird nicht beendet, sondern zu einem verwaisten Prozess ( ppid=1 ), weil der übergeordnete Prozess, der es erstellt hat, beendet wurde.
[root@localhost php]# nohup php deadloop.php nohup: 忽略输入并把输出追加到"nohup.out"
Fazit : Wenn wir also die Methoden nohup und & kombinieren, belegt der gestartete Prozess die Konsole nicht und ist nicht auf die Konsole angewiesen. Nach dem Schließen der Konsole wird der Prozess von Prozess Nr. 1 übernommen und zu einem verwaisten Prozess ist dem Mechanismus des Daemon-Prozesses sehr ähnlich.
[root@localhost php]# ls cmd.sh deadloop.php getPhoto.php nohup.out pics [root@localhost php]# tail -f nohup.out 1470999772 1470999775 1470999778 1470999781 1470999784 1470999787 1470999790 1470999793 1470999796 1470999799 1470999802
Wobei >logs.txt die Standardausgabe umleitet, leitet 2>error.txt die Standardfehlerausgabe um.
Das Obige ist eine Einführung in die erste Implementierungsmethode.
[root@localhost ~]# ps -ef | grep 3554 root 3554 3497 0 19:09 pts/0 00:00:00 php deadloop.php root 3575 3557 0 19:10 pts/1 00:00:00 grep 3554 [root@localhost ~]# ps -ef | grep 3554 root 3554 1 0 19:09 ? 00:00:00 php deadloop.php root 3577 3557 0 19:10 pts/1 00:00:00 grep 3554 [root@localhost ~]#
Verwandte Empfehlungen:
PHP-Prozesssignalverarbeitung
PHP-Inter- Prozess Detaillierte Erläuterung der Kommunikation
So implementieren Sie die PHP-Prozesssperre
Das obige ist der detaillierte Inhalt vonZwei Methoden des Daemon-Prozesses in PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!