이 기사에서는 주로 pcntl_fork 실행 프로세스의 예를 공유합니다. 프로세스(프로세스)의 개념은 주로 세 가지 요소를 포함하는 프로세스입니다.
1. 실행 가능한 프로그램
2. 프로세스와 관련된 모든 데이터(변수, 메모리 공간, 버퍼 등 포함)
3. 프로그램의 실행 컨텍스트
는 다음과 같이 생각할 수 있습니다.
프로세스는 실행 가능한 프로그램이 실행되는 동안의 상태를 나타냅니다. 운영 체제의 프로세스 관리는 일반적으로 프로세스 테이블을 통해 수행됩니다. 프로세스 테이블의 각 항목은 현재 운영 체제의 프로세스 상태를 기록합니다.
단일 CPU의 경우 특정 순간에 하나의 프로세스만 CPU를 점유하지만 시스템에는 동시에 여러 개의 활성(실행 대기 또는 계속 실행) 프로세스가 있을 수 있습니다. 프로그램 카운터(pc)라고 불리는 레지스터는 현재 CPU를 점유하고 있는 프로세스가 실행할 다음 명령어의 위치를 나타냅니다. 프로세스에 할당된 CPU 시간이 모두 사용되면 운영 체제는 프로세스와 관련된 레지스터의 값을 프로세스 테이블의 해당 항목에 저장합니다. 이 프로세스는 프로세스 테이블에서 읽어 해당 레지스터를 업데이트합니다(이 프로세스를 "Context Switch(프로세스 컨텍스트 스위치)"라고 합니다. 실제 컨텍스트 전환에는 더 많은 데이터가 포함되어야 하며 이는 포크와 관련이 없으므로 더 이상 말하지 않겠습니다. 기억해야 할 가장 중요한 점은 프로그램 레지스터 pc가 현재 프로그램이 실행된 위치를 가리킨다는 것입니다. 이는 CPU를 교체하는 프로세스가 이 값을 저장해야 하는 프로세스 컨텍스트의 중요한 부분입니다. 레지스터로 전환하는 프로세스도 프로세스 실행 컨텍스트 정보에 따라 값을 저장해야 하며 이 레지스터를 업데이트해야 합니다.
포크 이후 운영 체제는 상위 프로세스와 완전히 동일한 하위 프로세스를 복사합니다. 비록 아버지와 아들의 관계이지만 운영 체제의 관점에서는 형제에 가깝습니다. 이 두 프로세스는 코드 공간을 공유합니다. 그러나 데이터 공간은 서로 독립적입니다. 하위 프로세스의 데이터 공간에 있는 내용은 상위 프로세스의 완전한 복사본이며 명령 포인터는 정확히 동일합니다. 차이가 있다면, 포크가 성공하면 자식 프로세스의 포크 반환 값은 0이고, 부모 프로세스의 포크 반환 값은 0입니다. 포크의 반환 값은 포크인 경우 자식 프로세스의 프로세스 번호입니다. 실패하면 상위 프로세스가 오류를 반환합니다. 두 프로세스가 동시에 동일한 속도로 실행되고 있다고 상상할 수 있습니다. 포크 이후에는 각각 다른 작업을 수행합니다. 즉 분기됩니다. 이것이 포크(fork)라고 불리는 이유입니다. 어떤 프로세스가 먼저 실행되는지는 운영 체제 플랫폼의 스케줄링 알고리즘과 관련이 있으며 실제 응용 프로그램에서는 이 문제가 중요하지 않습니다. 부모 프로세스와 자식 프로세스가 함께 작동해야 하는 경우 구문 구조를 제어하여 해결할 수 있습니다.
2
fork 이전에는 하위 프로세스가 상위 프로세스의 항목을 상속받을 수 있지만 pcntl_fork() 이후에는 하위 프로세스와 상위 프로세스 간에 상속 관계가 없습니다. 자식 프로세스에서 생성된 것은 자식 프로세스에 속하고, 부모 프로세스에서 생성된 것은 완전히 두 개의 독립적인 프로세스로 간주될 수 있습니다.
3
프로그램 세그먼트에서 pcntl_fork()를 사용한 후 프로그램이 분기되었고 어느 프로세스가 먼저 실행되는지는 시스템의 스케줄링 알고리즘에 따라 달라집니다.
여기서는 "pid=pcntl_fork();"로 실행될 때 시스템이 기본 프로그램과 정확히 동일한 하위 프로세스를 생성한다고 생각할 수 있습니다. 프로세스의 "pid=pcntl_fork();" 문장에서 얻은 pid는 자식 프로세스 자체의 pid이며, 자식 프로세스가 끝난 후 부모 프로세스의 "pid=pcntl_fork()"에서 얻은 pid입니다. 는 상위 프로세스 자체의 pid입니다. 따라서 프로그램에는 두 줄의 출력이 있습니다.
4
pcntl_fork() 함수는 현재 프로세스의 PCB를 복사하고 파생된 하위 프로세스의 pid를 상위 프로세스로 반환합니다. 상위 프로세스와 하위 프로세스는 명령문 인쇄 순서에 따라 완전히 다릅니다. 시스템의 스케줄링 알고리즘과 인쇄된 내용은 pid 변수에 의해 제어됩니다. pcntl_fork()는 파생된 하위 프로세스의 pid를 상위 프로세스에 반환하며 이는 양의 정수인 반면 파생된 하위 프로세스의 pid 변수는 변경되지 않았기 때문에 이 차이를 통해 서로 다른 출력을 볼 수 있습니다.
5
관련 추천:
자식 프로세스, 즉 상위 프로세스의 pid는 동일합니다.
자식 프로세스의 경우 fork() 함수는 0을 반환하지만 자신의 pid는 확실히 0이 아닐 것입니다. fork() 함수가 0을 반환하는 이유는 자신의 pid를 얻기 위해 언제든지 getpid()를 호출할 수 있기 때문입니다. 동기화를 사용하지 않으면 누가 먼저 실행하고 누가 먼저 종료하는지 결정할 수 없습니다. 자식 프로세스가 끝난 후에만 부모 프로세스가 포크에서 반환된다고 생각하는 것은 잘못된 것입니다. 이는 포크의 경우가 아니라 vfork의 경우입니다.
- 예
<?php$lock = new swoole_lock(SWOOLE_MUTEX);echo "[主进程]create lock\n";$lock->lock();$res = pcntl_fork();if ($res>0) { echo "1\n"; $lock->unlock(); sleep(1); echo "222"; } else{ echo "[子进程] Wait Lock\n"; $lock->lock(); echo "[子进程] Get Lock\n"; $lock->unlock(); exit("[子进程] exit\n"); }echo "[主进程]release lock\n";unset($lock);echo "[主进程]exit\n";로그인 후 복사
Weibo Qzone WeChat pcntl_fork는 PHP 다중 프로세스를 구현합니다.
php 다중 프로세스에서 pcntl_fork에 대한 자세한 소개
php pcntl_fork 및 pcntl_fork 사용법
위 내용은 pcntl_fork 실행 과정 예시에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!