이 기사의 예에서는 PHP의 pcntl 다중 프로세스 사용법을 설명합니다. 참고할 수 있도록 모든 사람과 공유하세요. 구체적인 분석은 다음과 같습니다.
PHP는 PCNTL 시리즈 기능을 사용하여 여러 프로세스로 트랜잭션을 처리할 수도 있습니다. 예를 들어, 데이터베이스에서 80만 개의 데이터를 얻은 후 일련의 후속 처리를 수행해야 하는데 이때 단일 프로세스를 사용합니까? 내년 오늘까지 기다리시면 됩니다. 따라서 pcntl 기능을 사용해야 합니다.
20개의 프로세스를 시작하고 1~80w의 데이터를 20개의 부분으로 나누고 싶다고 가정해 보겠습니다. 기본 프로세스는 종료되기 전에 모든 하위 프로세스가 완료될 때까지 기다립니다.
$max = 800000; $workers = 20; $pids = array(); for($i = 0; $i < $workers; $i++){ $pids[$i] = pcntl_fork(); switch ($pids[$i]) { case -1: echo "fork error : {$i} \r\n"; exit; case 0: $param = array( 'lastid' => $max / $workers * $i, 'maxid' => $max / $workers * ($i+1), ); $this->executeWorker($input, $output, $param); exit; default: break; } } foreach ($pids as $i => $pid) { if($pid) { pcntl_waitpid($pid, $status); } }
여기서 pcntl_fork가 나오면 pid 값이 반환됩니다. 이 pid는 자식 프로세스에서는 0이고, 부모 프로세스에서는 자식 프로세스의 pid입니다(>0). 포크가 잘못되었다는 뜻입니다.
$pids 배열을 사용하여 기본 프로세스가 종료되기 전에 모든 프로세스가 완료될 때까지 기다리게 합니다.
이 기사가 모든 사람의 PHP 프로그래밍 설계에 도움이 되기를 바랍니다.