>백엔드 개발 >PHP 튜토리얼 >PHP의 다중 프로세스

PHP의 다중 프로세스

王林
王林원래의
2023-05-23 08:39:322220검색

인터넷이 발전함에 따라 점점 더 많은 웹사이트에서 수많은 사용자 액세스 요청을 처리해야 합니다. 동시성이 높은 경우 단일 프로세스 서버는 빠르게 병목 현상에 도달하여 사용자가 웹 사이트에 정상적으로 액세스할 수 없게 됩니다. 따라서 다중 프로세스는 높은 동시성 문제를 해결하는 효과적인 솔루션 중 하나가 되었습니다. 이 기사에서는 프로그램 품질을 보장하면서 동시 요청을 처리하는 프로그램의 기능을 향상시키기 위해 PHP의 다중 프로세스 기술을 소개합니다.

1. 다중 프로세스 소개

컴퓨터 과학에서 프로세스는 실행 중인 프로그램 인스턴스를 의미합니다. 각 프로세스에는 자체 메모리 공간과 시스템 리소스가 있습니다. 멀티프로세싱은 하나의 프로그램에서 여러 프로세스를 생성하는 것을 의미합니다. 각 프로세스는 독립적으로 실행되고 자체 프로세스 번호와 프로세스 제어 블록을 가지며 서로 간섭하지 않습니다. 다중 프로세스 기술은 서버 소프트웨어, 운영 체제 및 기타 분야에서 널리 사용됩니다.

2. PHP의 다중 프로세스

  1. 다중 프로세스 구현 방법

PHP에서 다중 프로세스를 구현하려면 pcntl 확장 또는 posix 확장을 사용할 수 있습니다. 두 확장 모두 프로세스 생성, 프로세스 간 통신, 신호 처리 등과 같은 기능을 제공합니다.

pcntl 확장은 프로세스 생성, 운영 및 관리를 위한 다양한 기능을 제공하는 PHP의 프로세스 제어 함수 라이브러리입니다. pcntl 함수 라이브러리를 사용하여 여러 프로세스를 구현하면 프로세스의 상위-하위 관계, 신호 전송, 리소스 공유 등을 쉽게 제어할 수 있습니다.

posix 확장은 pcntl 확장을 보완하는 프로세스 제어, 신호 처리 및 기타 기능도 제공합니다. 또한 파일 작업, 시스템 정보 쿼리 등과 같은 더 많은 시스템 기능을 제공합니다.

  1. 자식 프로세스 만들기

pcntl_fork() 함수를 사용하여 PHP에서 자식 프로세스를 만듭니다. fork() 함수의 반환 값이 달라서 상위 프로세스와 하위 프로세스를 구분할 수 있어 상위 프로세스와 하위 프로세스의 구분을 실현할 수 있습니다.

$pid = pcntl_fork();   // 创建子进程
if ($pid == -1) {
    die('fork failed');
} elseif ($pid == 0) { // 子进程
    // 子进程代码
} else {                // 父进程
    // 父进程代码
}

fork() 함수가 호출된 후 운영 체제는 새로운 하위 프로세스를 생성합니다. 이때 기본 프로세스는 계속 실행될 수 있으며 하위 프로세스는 fork() 함수 이후에 실행을 시작합니다. 자식 프로세스의 pid는 0이고, 부모 프로세스의 pid는 자식 프로세스의 pid 값입니다. 하위 프로세스를 생성한 후 하위 프로세스에서 시간이 많이 걸리는 일부 작업을 수행하거나 일부 작업을 병렬로 수행하여 전체 처리 시스템의 동시성 성능을 향상시킬 수 있습니다.

  1. 자식 프로세스의 종료 상태

자식 프로세스의 실행이 완료된 후 종료 상태를 얻어야 합니다. pcntl_waitpid() 함수에서 첫 번째 매개변수는 자식 프로세스가 종료되기를 기다리는 프로세스 번호이고, 두 번째 매개변수는 자식 프로세스 종료 상태가 저장되는 위치이다. 반환 값이 양수이면 자식 프로세스가 종료되었음을 의미하고, 그렇지 않으면 기다리는 동안 신호에 의해 중단되었음을 의미합니다.

$pid = pcntl_fork();
if ($pid == -1) {
    die('fork failed');
} elseif ($pid == 0) {
    // 子进程
    exit(0); // 子进程退出状态为0
} else {
    // 父进程
    pcntl_waitpid($pid, $status); // 等待子进程退出
    echo $status;   // 输出子进程退出状态
}

3. 실제 사례

다음은 PHP에서 다중 프로세스 기술을 사용하는 방법을 보여주는 간단한 실제 사례입니다.

여러 URL의 콘텐츠를 가져오고, 여러 하위 프로세스를 생성하여 동시에 URL 콘텐츠를 가져오고, 성공적으로 획득한 후 해당 콘텐츠를 데이터베이스에 저장하는 스크립트를 구현하세요.

<?php
// 需要获取的URL列表
$urlList = [
    'https://www.baidu.com/',
    'https://www.qq.com/',
    'https://www.sina.com.cn/',
    'https://www.163.com/',
    'https://www.taobao.com/'
];

// 创建多个子进程并行获取URL内容
foreach ($urlList as $url) {
    $pid = pcntl_fork();
    if ($pid == -1) {
        die('fork failed');
    } elseif ($pid == 0) {
        // 子进程
        $content = file_get_contents($url); // 获取URL内容
        // 保存内容到数据库
        $pdo = new PDO('mysql:host=localhost;dbname=test', 'root', '');
        $stmt = $pdo->prepare("INSERT INTO url_content(url, content) VALUES(?, ?)");
        $stmt->execute([$url, $content]);
        exit(0);
    }
}

// 等待所有子进程执行完毕
while (pcntl_waitpid(0, $status) != -1) {
    // do nothing
}
echo 'All child processes have terminated' . PHP_EOL;

위 코드에서는 foreach를 통해 $urllist를 탐색하고 여러 하위 프로세스를 생성하여 URL 콘텐츠를 병렬로 가져옵니다. file_get_contents() 함수를 통해 URL 콘텐츠를 얻은 후 콘텐츠를 데이터베이스에 저장합니다. 상위 프로세스에서는 while 및 pcntl_waitpid() 함수를 통해 하위 프로세스의 실행이 완료될 때까지 기다립니다.

4. 주의 사항

멀티 프로세스 기술을 사용하는 경우 다음 사항에 주의해야 합니다.

  1. 부모 프로세스가 끝나기 전에 자식 프로세스가 종료되어야 합니다. 그렇지 않으면 좀비 프로세스가 생성됩니다.
  2. 하위 프로세스는 상위 프로세스가 생성될 때만 복사본을 만듭니다. 하위 프로세스에서 수정한 콘텐츠는 상위 프로세스에 영향을 주지 않으며, 상위 프로세스에서 수정한 콘텐츠는 하위 프로세스에 영향을 주지 않습니다.
  3. 자식 프로세스가 생성되면 상위 프로세스의 모든 변수와 파일 설명자가 복사되지만 상위 프로세스에서 열린 스트림은 복사되지 않습니다.
  4. 멀티 프로세스 기술을 사용하는 경우 시스템 리소스의 과도한 소비를 피하기 위해 시스템 리소스 사용량을 고려해야 합니다.

5. 요약

PHP에 다중 프로세스 기술을 적용하면 프로그램의 동시 요청 처리 능력을 효과적으로 향상시킬 수 있습니다. 멀티 프로세스 기술을 통해 여러 작업을 병렬로 처리할 수 있어 시스템의 응답 속도와 동시성이 향상됩니다. 프로그램 품질 보장을 전제로 다중 프로세스 기술은 효율적이고 간단한 솔루션을 제공합니다.

위 내용은 PHP의 다중 프로세스의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.