QPM은 데몬 개발을 단순화하는 데 사용할 수 있는 PHP 프로세스 관리 프레임워크입니다. 프로젝트 주소는 https://github.com/Comos/qpm 입니다. 버전 0.2부터 QPM은 OneForOne MultiGroupOneForOne 및 TaskFactoryMode의 3가지 감독 모드를 지원합니다. 다양한 모드에서는 다양한 프로세스 트리 조합을 설정하고, 하위 프로세스를 다시 시작하고, 동시성 제어 전략을 적용하여 다양한 애플리케이션 시나리오에 적응할 수 있습니다. 예를 들어, OneForOne의 생성 방법은 qpmsupervisorSupervisor::oneForOne($config);OneForOnemethodqpmsupervisorSupervisor::oneForOne($config)사용 시나리오모든 하위 프로세스는 동일한 콜백 함수 또는 Runnable 클래스를 사용합니다. 구성 필드
*runnableCallback 또는 runnableClass. 유형 callable 또는 qpmprocessRunnable runnableCallback은 하위 프로세스에서 실제 작업을 수행하는 콜백입니다. runnableClass는 자식 프로세스에서 실제 작업을 수행하는 클래스이고, runnableCallback은 선택사항입니다.
수량 유형 정수 기본값 동시 수량 1개.
maxRestartTimes 유형 정수 최대 재시작 횟수, withInSeconds와 함께 사용됩니다.
withInSeconds 유형 정수 및 maxRestartTimes는 합의된 시간 내에 마스터 프로세스의 최대 재시작 횟수를 나타냅니다.
예시 1 'justDoIt', 'quantity' => 3];
$sup = qpm\supervisor\Supervisor::oneForOne($config);
$sup->start();
예시 2 'Foo', 'quantity' => 5, 'maxRestartTimes'=>100, 'withInSeconds'=>10];
$sup = qpm\supervisor\Supervisor::oneForOne($config);
$sup->start();
MultiGroupOneForOne 방법qpmsupervisorSupervisor::oneForOne($config)사용 시나리오MultiGroupOneForOne은 OneForOne의 업그레이드 버전이며 OneForOne 프로세스의 여러 그룹을 관리할 수 있습니다. MultiGroupOneForOne의 구성은 여러 OneForOne 구성이 포함된 배열입니다. TaskFactoryMode태스크 팩토리 모드, 태스크는 지정된 팩토리 메소드에 의해 생성됩니다. 방법qpmsupervisorSupervisor::taskFactoryMode($config)사용 시나리오각 하위 프로세스에서 수행하는 작업은 다르며 다른 매개변수가 필요합니다. 클래스 또는 Run 함수이므로 각 작업은 작업 팩터리에 의해 생성됩니다. 구성 필드*factoryMethod callable 작업 개체 또는 호출 가능 항목을 생성하는 데 사용되는 팩토리 메서드입니다. FactoryMethod 반환 값은 qpmprocessRunnable 또는 호출 가능일 수 있습니다.
수량 유형 정수 기본값 동시 수량 1개.
QPM은 버전 0.2부터 OneForOne MultiGroupOneForOne 및 TaskFactoryMode의 3가지 감독 모드를 지원합니다. 다양한 모드에서는 다양한 프로세스 트리 조합을 설정하고, 하위 프로세스를 다시 시작하고, 동시성 제어 전략을 적용하여 다양한 애플리케이션 시나리오에 적응할 수 있습니다. 예를 들어, OneForOne의 생성 방법은 qpmsupervisorSupervisor::oneForOne($config);OneForOnemethodqpmsupervisorSupervisor::oneForOne($config)사용 시나리오모든 하위 프로세스는 동일한 콜백 함수 또는 Runnable 클래스를 사용합니다. 구성 필드
*runnableCallback 또는 runnableClass. 유형 callable 또는 qpmprocessRunnable runnableCallback은 하위 프로세스에서 실제 작업을 수행하는 콜백입니다. runnableClass는 자식 프로세스에서 실제 작업을 수행하는 클래스이고, runnableCallback은 선택사항입니다.
수량 유형 정수 기본값 동시 수량 1개.
maxRestartTimes 유형 정수 최대 재시작 횟수, withInSeconds와 함께 사용됩니다.
withInSeconds 유형 정수 및 maxRestartTimes는 합의된 시간 내에 마스터 프로세스의 최대 재시작 횟수를 나타냅니다.
예시 1 'justDoIt', 'quantity' => 3];
$sup = qpm\supervisor\Supervisor::oneForOne($config);
$sup->start();
예시 2 'Foo', 'quantity' => 5, 'maxRestartTimes'=>100, 'withInSeconds'=>10];
$sup = qpm\supervisor\Supervisor::oneForOne($config);
$sup->start();
MultiGroupOneForOne 방법qpmsupervisorSupervisor::oneForOne($config)사용 시나리오MultiGroupOneForOne은 OneForOne의 업그레이드 버전이며 OneForOne 프로세스의 여러 그룹을 관리할 수 있습니다. MultiGroupOneForOne의 구성은 여러 OneForOne 구성이 포함된 배열입니다. TaskFactoryMode태스크 팩토리 모드, 태스크는 지정된 팩토리 메소드에 의해 생성됩니다. 방법qpmsupervisorSupervisor::taskFactoryMode($config)사용 시나리오각 하위 프로세스에서 수행하는 작업은 다르며 다른 매개변수가 필요합니다. 클래스 또는 Run 함수이므로 각 작업은 작업 팩터리에 의해 생성됩니다. 구성 필드*factoryMethod callable 작업 개체 또는 호출 가능 항목을 생성하는 데 사용되는 팩토리 메서드입니다. FactoryMethod 반환 값은 qpmprocessRunnable 또는 호출 가능수량 유형 정수 기본값 1 동시 수량일 수 있습니다.
위 내용은 관련 내용을 포함하여 QPM-PHP 다중 프로세스 개발-감독자 구성 참조를 소개합니다. PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.