백엔드에서 장기간 작업을 처리할 때 PHP가 차단되는 것을 방지하고 페이지 요청에 신속하게 응답하려면 다음 조치를 취할 수 있습니다.
1. fastcgi_finish_request()를 사용하세요.
PHP와 웹 서버를 사용하는 경우 PHP-FPM(FastCGI 프로세스 관리자)의 경우 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);
출력 결과를 보면 페이지에 프로그램 시작...이 인쇄된 후 첫 번째 줄을 log.txt로 출력한 후 세션이 반환되므로 후속 디버그...가 브라우저에 표시되지 않고, 로그 .txt 파일은 세 가지 완료 시간을 모두 수신할 수 있습니다.
2. 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의 cur_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. Gearman/Swoole 확장 사용
Gearman은 대량의 비동기 작업을 처리할 수 있는 PHP 확장이 포함된 분산 비동기 처리 프레임워크입니다.
Swoole은 최근 매우 인기가 있으며 비동기 방식이 많고 사용하기 쉽습니다.
5. 캐시 및 대기열 사용redis 및 기타 캐시 및 대기열을 사용하여 캐시에 데이터를 쓰고 백그라운드 예약 작업을 사용하여 데이터의 비동기 처리를 달성합니다.
이 방법은 트래픽이 많은 일반적인 아키텍처에서 매우 일반적이어야 합니다
6. 시스템 명령 호출극단적인 경우에는 시스템 명령을 호출하고 실행을 위해 데이터를 백그라운드 작업에 전달할 수 있습니다. 매우 효율적이라고 생각합니다.
$cmd = 'nohup php ./processd.php $someVar >/dev/null &'; `$cmd`
7. pcntl_fork()
를 사용하여 pcntl 확장을 설치하고, pcntl_fork()를 사용하여 작업을 비동기적으로 실행하는 것이 가장 편리하다고 생각합니다. 좀비 프로세스.
아아아아위 내용은 PHP 비동기 비차단 구현 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!