Programmieren Sie den nicht blockierenden Modus, der auch als Parallelität verstanden werden kann. Um zu verhindern, dass PHP blockiert, muss PHP eine langfristige Verarbeitung als Back-End-Verarbeitung durchführen, um schnell auf Seitenanforderungen reagieren zu können Ohne ein Urteil über die Ergebnisrückgabe zu fällen, können Sie die folgenden Maßnahmen ergreifen:
Spezifische nicht blockierende PHP-Implementierungsmethode:
1 Verwenden Sie fastcgi_finish_request()
Wenn PHP und der Webserver PHP-FPM (FastCGI Process Manager) verwenden, kann die Sitzung sofort über die Funktion fastcgi_finish_request() und PHP beendet werden Der Thread kann weiterhin im Hintergrund ausgeführt werden.
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 Sie den Ausgabeergebnissen entnehmen können, kehrt die Sitzung nach dem Drucken der Seite, dem Programmstart ... nach der Ausgabe der ersten Zeile in log.txt zurück, sodass das nachfolgende Debuggen ... nicht erfolgt Wird auf dem Browser-Display ausgeführt, und die Datei log.txt kann drei Mal vollständig abgeschlossen werden.
2 Verwenden Sie fsockopen()
Verwenden Sie fsockopen(), um eine Netzwerkverbindung oder eine Unix-Socket-Verbindung zu öffnen, und verwenden Sie dann stream_set_blocking() für die Anforderung des nicht blockierenden Modus :
$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);
3 Verwenden Sie cURL
Verwenden Sie die Funktionen „curl_multi_*“ in cURL, um asynchrone Anfragen zu senden
$cmh = curl_multi_init(); $ch1 = curl_init(); curl_setopt($ch1, CURLOPT_URL, "http://localhost/"); curl_multi_add_handle($cmh, $ch1); curl_multi_exec($cmh, $active); echo "End\n";
4 Verwenden Sie die Gearman/Swoole-Erweiterung
Gearman ist ein verteiltes asynchrones Verarbeitungsframework mit PHP-Erweiterung, das große Mengen asynchroner Aufgaben verarbeiten kann.
Swoole erfreut sich in letzter Zeit großer Beliebtheit. Es verfügt über viele asynchrone Methoden und ist einfach zu verwenden.
5 Verwenden Sie Caches und Warteschlangen
Verwenden Sie Redis und andere Caches und Warteschlangen, um Daten in den Cache zu schreiben, und verwenden Sie im Hintergrund geplante Aufgaben, um eine asynchrone Datenverarbeitung zu erreichen.
Diese Methode sollte in gängigen Architekturen mit hohem Datenverkehr sehr verbreitet sein
6 Systembefehle aufrufen
In extremen Fällen können Sie Systembefehle aufrufen. Daten können zur Ausführung an Hintergrundaufgaben übergeben werden, ich persönlich halte dies jedoch für nicht sehr effizient.
$cmd = 'nohup php ./processd.php $someVar >/dev/null &'; `$cmd`
7 Verwenden Sie pcntl_fork()
, um die pcntl-Erweiterung zu installieren und verwenden Sie pcntl_fork(), um einen Unterprozess zur asynchronen Ausführung von Aufgaben zu generieren ist der bequemste, aber auch einfach durchzuführende Zombie-Prozess.
$pid = pcntl_fork() if ($pid == 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); }
8 PHP native Unterstützung
Gringos ultimativer Schachzug, ich verstehe ihn nicht
http://nikic.github.io/2012 / 22.12./Cooperative-multitasking-using-coroutines-in-PHP.html
Das obige ist der detaillierte Inhalt von8 nicht blockierende PHP-Implementierungsmethoden, um schnell auf Seitenanfragen zu reagieren. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!