stop" 메소드를 사용하십시오. 여기서 $waitEvent 매개변수는 종료 전략을 제어할 수 있습니다. 기본값은 즉시 종료하는 false이고, true로 설정하는 것은 이벤트 루프가 비어 있을 때까지 기다리는 것을 의미합니다. 나가기 전에."/> stop" 메소드를 사용하십시오. 여기서 $waitEvent 매개변수는 종료 전략을 제어할 수 있습니다. 기본값은 즉시 종료하는 false이고, true로 설정하는 것은 이벤트 루프가 비어 있을 때까지 기다리는 것을 의미합니다. 나가기 전에.">
Server->stop
현재 Worker 프로세스를 중지하고 onWorkerStop 콜백 함수를 즉시 트리거합니다.
function Server->stop(int $worker_id = -1, bool $waitEvent = false);
작업자 프로세스의 수명 주기를 종료하려면 종료/다이 대신 이 함수를 사용하세요.
$waitEvent는 종료 전략을 제어할 수 있습니다. 기본값은 즉시 종료하려면 false이고, 이벤트 루프가 비어 있을 때까지 기다리려면 true로 설정하세요. 종료하기 전에
다른 작업자 프로세스를 종료하려면 stop에서 작업자_id를 매개변수로 추가하거나 swoole_process::kill($worker_pid)
이 방법은 버전 1.8.2 이상에서 사용할 수 있습니다
$waitEvent는 1.9.19 이상 버전에서 사용할 수 있습니다
Asynchronous Exit
비동기 서버가 stop을 호출하여 프로세스를 종료할 때 여전히 대기 중인 이벤트가 있을 수 있습니다. 예를 들어 SwooleMySQL->query는 SQL 문을 보내는 데 사용되지만 여전히 MySQL 서버가 결과를 반환할 때까지 기다리고 있습니다. 이때 프로세스가 강제 종료되면 SQL 실행 결과가 손실됩니다.
$waitEvent = true로 설정한 후 하단 레이어는 비동기 안전 재시작 전략을 사용합니다. 먼저 Manager 프로세스에 알리고 새 작업자를 다시 시작하여 새 요청을 처리합니다. 현재의 이전 작업자는 이벤트 루프가 비어 있거나 max_wait_time을 초과할 때까지 이벤트를 기다린 다음 비동기 이벤트의 안전성을 최대한 보장하기 위해 프로세스를 종료합니다.
추천 학습: swoole 튜토리얼
위 내용은 스울을 종료하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!