Der nicht blockierende Modus bezieht sich auf den Nachrichtenmechanismus, der Socket-Ereignisse verwendet. In diesem Artikel können alle interessierten Freunde den nicht blockierenden PHP-Modus kennenlernen. Ich hoffe, es hilft allen.
Wenn PHP als Back-End-Prozess eine langfristige Verarbeitung durchführen muss, um schnell auf Seitenanfragen zu reagieren, ohne das zurückgegebene Ergebnis zu beurteilen, können die folgenden Maßnahmen ergriffen werden genommen werden:
1. Wenn Sie den FastCGI-Modus verwenden, kann die Verwendung von fastcgi_finish_request() die Sitzung sofort beenden, der PHP-Thread wird jedoch weiterhin ausgeführt.
echo "program start."; file_put_contents('log.txt','start-time:'.date('Y-m-d H:i:s'), FILE_APPEND); fastcgi_finish_request(); sleep(1); echo 'debug...'; file_put_contents('log.txt', 'start-proceed:'.date('Y-m-d H:i:s'), FILE_APPEND); sleep(10); file_put_contents('log.txt', 'end-time:'.date('Y-m-d H:i:s'), FILE_APPEND);
Wie in der Ausgabe dieses Beispiels gezeigt, kehrt die Sitzung nach dem Programmstart zurück, sodass der Debug-Ausgabebrowser sie nicht empfangen kann. angekommen, und die log.txt-Datei kann vollständig drei Abschlusszeiten erhalten.
2. Verwenden Sie den nicht blockierenden Modus von fsockopen und cUrl, um eine andere URL anzufordern
$fp = fsockopen("www.example.com", 80, $errno, $errstr, 30); if (!$fp) die('error fsockopen'); stream_set_blocking($fp,0); $http = "GET /save.php / HTTP/1.1\r\n"; $http .= "Host: www.example.com\r\n"; $http .= "Connection: Close\r\n\r\n"; fwrite($fp,$http); fclose($fp);
Verwenden Sie die Funktion „curl_multi_*“ in cURL, um asynchrone Anfragen zu senden
$cmh = curl_multi_init(); $ch1 = curl_init(); curl_setopt($ch1, CURLOPT_URL, "http://localhost:6666/child.php"); curl_multi_add_handle($cmh, $ch1); curl_multi_exec($cmh, $active); echo "End\n";
3. Verwenden Sie Gearman- und Swoole-Erweiterungen
Gearman ist ein verteiltes asynchrones Verarbeitungsframework mit PHP-Erweiterungen, das große Mengen asynchroner Aufgaben verarbeiten kann.
Swoole erfreut sich in letzter Zeit großer Beliebtheit, verfügt über viele asynchrone Methoden und ist einfach zu verwenden . (Chenyuan-Hinweis: Es wird behauptet, PHP neu zu definieren und NodeJS vollständig zu versprühen. Obwohl das Swoole-Tool gut ist, habe ich das Gefühl, dass die Erweiterung selbst nicht mit NodeJS vergleichbar ist)
4. Verwenden Sie redis. Warten Sie, bis der Cache und die Warteschlange Daten in den Cache schreiben, und verwenden Sie geplante Hintergrundaufgaben, um die asynchrone Verarbeitung von Daten zu implementieren.
Diese Methode sollte in gängigen Architekturen mit hohem Datenverkehr sehr verbreitet sein
5. Im Extremfall kann das System aufgerufen werden Command kann Daten zur Ausführung an Hintergrundaufgaben übergeben, ich persönlich halte dies jedoch für nicht sehr effizient.
$cmd = 'nohup php ./processd.php $someVar >/dev/null &'; `$cmd`
6. Der ultimative Schachzug des Gringos, ich verstehe ihn nicht, native PHP-Unterstützung
http://nikic.github.io/2012/12/22/Cooperative-multitasking-using-coroutines-in-PHP.html
7. Installieren Sie die pcntl-Erweiterung und generieren Sie mit pcntl_fork einen untergeordneten Prozess, um Aufgaben asynchron auszuführen, aber es ist auch anfällig für Zombie-Prozesse.
if (($pid = pcntl_fork()) == 0) { child_func(); //子进程函数,主进程运行 } else { father_func(); //主进程函数 } echo "Process " . getmypid() . " get to the end.\n"; function father_func() { echo "Father pid is " . getmypid() . "\n"; } function child_func() { sleep(6); echo "Child process exit pid is " . getmypid() . "\n"; exit(0); }
PHP verwendet tatsächlich Swoole -Zeitliche Aktualisierung von Kundendaten
Verwendung von Swoole zur asynchronen Erfassung von Webseiten und zum praktischen Teilen
PHP CGI, FastCGI, APACHE2HANDLER, detaillierte Erklärung des CLI-Betriebsmodus
Das obige ist der detaillierte Inhalt vonDetaillierte Erläuterung des nicht blockierenden PHP-Modus. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!