Heim >Backend-Entwicklung >PHP-Tutorial >So implementieren Sie die Multiprozessprogrammierung in PHP
In diesem Artikel wird hauptsächlich die PHP-Multiprozess-Programmiermethode vorgestellt und die Konzepte, Verwendung, zugehörigen Funktionen und Verwendungstechniken der PHP-Multiprozess-Programmierung ausführlicher analysiert
Schritt eins:
Befehl $ php -m, um zu überprüfen, ob PHP PCNTL- und Posix-Erweiterungen installiert hat. Wenn nicht, installieren Sie
Verwendungsszenario:
1. Es müssen viele zeitaufwändige Netzwerkoperationen durchgeführt werden
2. Es müssen viele Berechnungen durchgeführt werden, und das System verfügt über mehrere CPUs Erfahrung, eine Aufgabe wird in mehrere kleine Aufgaben unterteilt und schließlich zusammengeführt.
Gemeinsame Funktionen für mehrere Prozesse:
pcntl_alarm – Stellen Sie ein Weckersignal für den Prozess ein
pcntl_errno – Alias pcntl_strerror
pcntl_exec – Führt das angegebene Programm im aktuellen Prozessraum aus
pcntl_fork – Erstellt einen untergeordneten Prozess und generiert einen Zweig (untergeordneten Prozess) an der aktuellen Position des aktuellen Prozesses. Anmerkung: Sowohl der übergeordnete Prozess als auch der untergeordnete Prozess werden weiterhin von der Gabelposition aus ausgeführt. Der Unterschied besteht darin, dass der Rückgabewert von fork die Nummer des untergeordneten Prozesses ist Prozess erhält 0.
pcntl_get_last_error – Rufen Sie die Fehlernummer ab, die von der letzten fehlgeschlagenen pcntl-Funktion festgelegt wurde
pcntl_getpriority – Rufen Sie die Priorität eines beliebigen Prozesses ab
pcntl_setpriority – Ändern Sie die Priorität eines Prozesses
pcntl_signal_dispatch – Rufen Sie einen Handler auf, der auf ein Signal wartet
pcntl_signal – Installieren Sie einen Signalhandler
pcntl_sigprocmask — Blockierungssignal setzen oder abrufen
pcntl_sigtimedwait — Signal warten mit Timeout-Mechanismus
pcntl_sigwaitinfo — Auf Signal warten
pcntl_strerror — System abrufen Fehlermeldung im Zusammenhang mit der angegebenen Fehlernummer
pcntl_wait – Warten Sie auf den untergeordneten Prozessstatus von fork oder geben Sie ihn zurück
pcntl_waitpid – Warten Sie auf den untergeordneten Prozessstatus von fork
pcntl_wexitstatus – Gibt den Rückkehrcode eines unterbrochenen untergeordneten Prozesses zurück
pcntl_wifexited – Prüft, ob der Statuscode einen normalen Exit darstellt.
pcntl_wifsignaled – Überprüfen Sie, ob der Statuscode des untergeordneten Prozesses bedeutet, dass er aufgrund eines Signals unterbrochen wurde.
pcntl_wifstopped – Überprüfen Sie, ob der untergeordnete Prozess derzeit gestoppt ist
pcntl_wstopsig – Gibt das Signal zurück, das den untergeordneten Prozess stoppt
pcntl_wtermsig – Gibt das Signal zurück, das den untergeordneten Prozess unterbricht
Beispiel 1:
<?php //最早的进程,也是父进程 $parentPid = getmypid(); echo '原始父进程:' . $parentPid . PHP_EOL; //创建子进程,返回子进程id $pid = pcntl_fork(); if( $pid == -1 ){ exit("fork error"); } //pcntl_fork 后,父进程返回子进程id,子进程返回0 echo 'ID : ' . $pid . PHP_EOL; if( $pid == 0 ){ //子进程执行pcntl_fork的时候,pid总是0,并且不会再fork出新的进程 $mypid = getmypid(); // 用getmypid()函数获取当前进程的PID echo 'I am child process. My PID is ' . $mypid . ' and my fathers PID is ' . $parentPid . PHP_EOL; } else { //父进程fork之后,返回的就是子进程的pid号,pid不为0 echo 'Oh my god! I am a father now! My childs PID is ' . $pid . ' and mine is ' . $parentPid . PHP_EOL; } $aa = shell_exec("ps -af | grep index.php"); echo $aa;
Beispiel 2: Mehrere untergeordnete Prozesse öffnen, um Fork-Flooding zu vermeiden
<?php //最早的进程,也是父进程 $parentPid = getmypid(); echo '原始父进程:' . $parentPid . PHP_EOL; //开启十个子进程 for($i = 0; $i < 10; $i++) { $pid = pcntl_fork(); if($pid == -1) { echo "Could not fork!\n"; exit(1); } //子进程 if(!$pid) { //child process workspace echo '子进程:' . getmypid() . PHP_EOL; exit(); //子进程逻辑执行完后,马上退出,以免往下走再fork子进程,不好控制 } else { echo '父进程:' . getmypid() . PHP_EOL; } } echo getmypid() . PHP_EOL; $aa = shell_exec("ps -af | grep index.php"); echo $aa;
Hinweis:
Verwenden Sie die Multiprozessfunktion über die Funktionsreihe pcntl_XXX. Hinweis: pcntl_XXX kann nur in der PHP-CLI-Umgebung (Befehlszeile) ausgeführt werden. In der Webserverumgebung kann es zu unvorhersehbaren Ergebnissen kommen. Bitte verwenden Sie es mit Vorsicht! Verwandte Empfehlungen:PHP-Implementierung basierend auf DateisperrlösungMehrere ProzesseEine Datei gleichzeitig lesen und schreiben
PHPMultiprozessProgrammierbeispiele implementieren
PHP-ImplementierungMultiprozess und Multi-Thread
Das obige ist der detaillierte Inhalt vonSo implementieren Sie die Multiprozessprogrammierung in PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!