Heim > Backend-Entwicklung > PHP-Tutorial > Zwei Methoden des Daemon-Prozesses in PHP

Zwei Methoden des Daemon-Prozesses in PHP

墨辰丷
Freigeben: 2023-03-25 19:22:01
Original
1697 Leute haben es durchsucht

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);
}
Nach dem Login kopieren

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]#
Nach dem Login kopieren

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
Nach dem Login kopieren

Das Obige ist eine kurze Einführung in den &-Befehl


Schauen wir uns einen weiteren Befehl nohup an

Der gestartete Prozess ignoriert das Hang-Signal (SIGHUP) unter Linux Der folgende Inhalt ist ein Auszug aus der Baidu-Enzyklopädie:


SIGHUP会在以下3种情况下被发送给相应的进程:
1、终端关闭时,该信号被发送到session首进程以及作为job提交的进程(即用 & 符号提交的进
程)
2、session首进程退出时,该信号被发送到该session中的前台进程组中的每一个进程
3、若父进程退出导致进程组成为孤儿进程组,且该进程组中有进程处于停止状态(收到SIGSTOP或
SIGTSTP信号),该信号会被发送到该进程组中的每一个进程。
Nach dem Login kopieren

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

auszuführen Führen Sie diese Routine in der Befehlszeile aus, schließen Sie dann direkt das Shell-Terminalfenster und öffnen Sie dann erneut ein Terminal, um es anzuzeigen. Läuft dieser Prozess noch:

系统对SIGHUP信号的默认处理是终止收到该信号的进程。所以若程序中没有捕捉该信号,当收到该
信号时,进程就会退出。
Nach dem Login kopieren

Sie können sehen, dass deadloop.php und sein übergeordneter Prozess noch ausgeführt werden ist zum Init-Prozess geworden (da sein ursprünglicher übergeordneter Prozess beendet wurde und vom Init-Prozess übernommen wurde). Ab dem Schreiben können Sie auch im Dateiinhalt sehen, dass das SIGHUP-Signal durch Schließen des Terminalprozesses empfangen wurde. Tatsächlich müssen wir nicht so mühsam sein. Wir müssen nur den von Linux bereitgestellten Befehl nohup verwenden. Wenn wir jedoch nohup verwenden, um den Prozess zu starten, wird der Prozess das empfangene SIGHUP-Signal ignorieren. Entfernen Sie jetzt den Signalverarbeitungscode. Führen Sie dann nohup aus.

<?php
pcntl_signal(SIGHUP, function(){
   //这地方处理信号的方式我们只是简单的写入一句日志到文件中
   file_put_contents(&#39;logs.txt&#39;, &#39;pid : &#39; . posix_getpid() . &#39; 
   receive SIGHUP 信号&#39; . PHP_EOL);
});
        
while(1) {
        sleep(10);
        pcntl_signal_dispatch();
}
Nach dem Login kopieren


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 信号
Nach dem Login kopieren


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"
Nach dem Login kopieren



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
Nach dem Login kopieren


Wobei >logs.txt die Standardausgabe umleitet, leitet 2>error.txt die Standardfehlerausgabe um.


Das Obige ist eine Einführung in die erste Implementierungsmethode.

Die zweite Implementierungsmethode besteht darin, ihn gemäß den Regeln und Merkmalen des Daemon-Prozesses zu implementieren. Das größte Merkmal des Daemon-Prozesses besteht darin, dass er vom Benutzerterminal und der Sitzung getrennt ist implementierter Code, mit Kommentaren an wichtigen Stellen.

[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 ~]#
Nach dem Login kopieren

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!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage