> 백엔드 개발 > PHP 튜토리얼 > PHP의 다중 프로세스 프로그래밍 및 프로세스 관리 기술

PHP의 다중 프로세스 프로그래밍 및 프로세스 관리 기술

王林
풀어 주다: 2023-05-11 18:52:01
원래의
863명이 탐색했습니다.
  1. 머리말

PHP는 대중적인 프로그래밍 언어로 다양한 분야에서 널리 사용되고 있습니다. 높은 동시성, 대용량 데이터, 높은 로드의 경우 PHP의 단일 스레드 특성으로 인해 성능 병목 현상이 발생합니다. 머신의 모든 CPU, 메모리, IO 리소스를 최대한 활용하고 프로그램의 성능과 확장성을 향상시키기 위해서는 멀티 프로세스 기술을 사용해야 합니다.

  1. 다중 프로세스 프로그래밍이란 무엇인가요?

운영 체제에서 프로세스는 실행 중인 프로그램을 의미합니다. 다중 프로세스 프로그래밍은 프로그램을 여러 프로세스로 나누어 실행하는 것을 의미합니다. 각 프로세스는 서로 독립적이며 동시에 실행될 수 있으므로 프로그램의 처리량과 처리 능력이 향상됩니다.

PHP에서 pcntl 확장 라이브러리는 일반적으로 다중 프로세스 프로그래밍을 구현하는 데 사용됩니다.

  1. PCNTL 확장 라이브러리를 사용하는 방법은 무엇입니까?

먼저 php.ini 파일에서 pcntl 확장 라이브러리를 활성화해야 합니다.

extension=pcntl.so

pcntl_fork() 함수를 사용하여 새 하위 프로세스를 만듭니다. 하위 프로세스와 상위 프로세스는 코드 세그먼트, 데이터 세그먼트 및 스택 세그먼트를 공유하지만 각각 독립적인 실행 공간과 프로세스 ID를 갖습니다.

$pid = pcntl_fork();
if ($pid == -1) {

// fork失败
로그인 후 복사

} else if ($pid) {

// 父进程
로그인 후 복사

} else {

// 子进程
로그인 후 복사

}

pcntl_waitpid() 함수를 사용하여 wait 하위 프로세스가 종료되고 하위 프로세스가 반환한 상태 코드를 얻습니다.

$status = null;
$pid = pcntl_waitpid($child_pid, $status, WNOHANG);
if ($pid == -1) {

// waitpid错误
로그인 후 복사

} else if ($pid) {

// 子进程已结束,$status中是子进程的状态码
로그인 후 복사

} else {

// 子进程还在运行
로그인 후 복사

}

프로세스에서 수신한 신호를 마스크/복원하려면 pcntl_sigprocmask() 함수를 사용하세요.

pcntl_sigprocmask(SIG_BLOCK, [SIGTERM]);
// SIGTERM 신호를 받은 후 프로세스는 즉시 종료되지 않지만 프로세스가 처리될 때까지 기다렸다가 종료합니다.
pcntl_signal(SIGTERM, function() {

// 处理SIGTERM信号
로그인 후 복사

});
pcntl_sigprocmask(SIG_UNBLOCK, [SIGTERM]);

  1. 프로세스 관리 기술

실제 응용 프로그램에서는 프로세스의 시작, 중지, 재시작, 모니터링 및 기타 기능을 포함하여 프로세스를 관리해야 합니다. 일반적으로 사용되는 프로세스 관리 기술은 다음과 같습니다.

4.1 Supervisord

Supervisor는 여러 프로세스를 시작, 중지, 다시 시작 및 모니터링할 수 있는 프로세스 관리자입니다. 클라이언트와 서버가 있습니다. 클라이언트는 서버에 제어 명령을 보내고, 서버는 프로세스의 실행 상태를 제어합니다. Supervisor는 또한 프로세스 그룹, 로깅, 프로그램 시작 실패 시 자동 재시작, 사용자 정의 스크립트 및 기타 기능을 지원합니다.

Supervisor의 구성 파일은 INI 형식을 사용하여 매우 간단하며 유지 관리가 쉽습니다. 다음은 감독자 구성 파일의 예입니다.

[program:myprogram]
command=/usr/bin/php /path/to/myprogram.php
process_name=%(program_name)s_%(process_num)02d
numprocs =4
directory=/path/to/myprogram
autostart=true
autorestart=true
user=myuser
stdout_logfile=/var/log/myprogram.log
stderr_logfile=/var/log/myprogram.err

4.2 Systemd

Systemd sysvinit 및 upstart를 대체하는 데 사용되는 초기화 시스템이며, 프로세스 관리자로도 사용할 수 있습니다. 여러 프로세스를 시작, 중지, 다시 시작 및 모니터링할 수 있으며 프로세스 종속성, 자동 다시 시작, 프로세스 상태 쿼리, 리소스 제한 등의 기능을 지원합니다.

Systemd의 구성 파일은 비교적 복잡하며 systemd.units 파일 형식을 사용합니다. 다음은 Systemd 구성 파일의 예입니다.

[Unit]
Description=myprogram
After=network.target

[Service]
Type=simple
ExecStart=/usr/bin/php /path/to/myprogram .php
PIDFile=/run/myprogram.pid
Restart=on-failure
User=myuser

[설치]
WantedBy=multi-user.target

4.3 Docker

Docker는 오픈 소스 애플리케이션 컨테이너 엔진으로 다음을 수행할 수 있습니다. 신속하게 컨테이너를 생성, 배포 및 실행합니다. Docker에서 각 컨테이너는 독립적인 프로세스이며 Docker의 명령줄 도구나 API를 사용하여 컨테이너를 관리할 수 있습니다.

Docker는 파일 시스템, 프로세스 공간, 네트워크 등 모든 애플리케이션이 실행될 수 있는 운영 체제와 유사한 환경을 제공합니다. Docker는 분산 배포, 컨테이너 오케스트레이션, 이미지 웨어하우스 및 기타 기능도 지원합니다.

  1. 요약

다중 프로세스 프로그래밍 및 프로세스 관리 기술은 네트워크 프로그래밍 및 시스템 프로그래밍에 널리 사용됩니다. 여러 프로세스를 사용하면 프로그램의 동시 처리 기능과 처리량이 향상될 수 있습니다. 프로세스 관리자를 사용하면 프로세스의 시작, 중지, 다시 시작, 모니터링 및 기타 작업을 보다 편리하게 관리할 수 있습니다. 실제 적용에서는 실제 상황에 따라 개발 및 배포를 위해 적절한 기술을 선택해야 합니다.

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

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿