バックエンドで長期タスクを処理するときに PHP がブロックされるのを防ぎ、ページリクエストに迅速に応答するには、次の措置を講じることができます:
1. fastcgi_finish_request()## を使用します。
#PHP と Web サーバーが PHP-FPM (FastCGI Process Manager) を使用している場合、fastcgi_finish_request() 関数を通じてセッションを即座に終了でき、PHP スレッドはバックグラウンドで実行を続けることができます。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);
2. fsockopen() を使用します
fsockopen() を使用してネットワーク接続または Unix ソケット接続を開き、stream_set_blocking() を使用して非ブロッキング モード:$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. cURL を使用します
cURL でcurl_multi_* 関数を使用して、非同期リクエストを送信します$mh = curl_multi_init(); $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, "http://localhost/"); curl_multi_add_handle($mh, $ch); curl_multi_exec($mh, $active); curl_close($ch); curl_multi_remove_handle($mh, $ch); curl_multi_close($mh); echo "End\n";
4.Use Gearman/Swoole 拡張機能
Gearman は、大量の非同期タスクのバッチを処理できる PHP 拡張機能を備えた分散型非同期処理フレームワークです。 最近人気のSwooleは非同期メソッドが豊富で使いやすいです。5. キャッシュとキューの使用
redis およびその他のキャッシュとキューを使用してキャッシュにデータを書き込み、バックグラウンドでスケジュールされたタスクを使用してデータの非同期処理を実現します。 このメソッドは、一般的な高トラフィック アーキテクチャでは非常に一般的です。6. システム コマンドを呼び出す
極端な場合には、システムを呼び出すこともできます。コマンドはバックグラウンドタスクにデータを渡して実行することができますが、個人的にはあまり効率的ではないと感じています。$cmd = 'nohup php ./processd.php $someVar >/dev/null &'; `$cmd`
7. pcntl_fork() を使用します
pcntl 拡張機能をインストールし、pcntl_fork() を使用して子プロセスを生成し、タスクを非同期に実行します。最も便利ですが、簡単でもあります。ゾンビ プロセスが表示されます。rree
以上がPHP非同期ノンブロッキング実装方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。