스울은 어떻게 작동하나요?

풀어 주다: 2019-12-12 15:53:57
원래의
3063명이 탐색했습니다.

스울은 어떻게 작동하나요?

Swoole은 두 가지 작동 모드를 도입합니다.

단일 스레드 모드(SWOOLE_BASE)

이 모드는 전통적인 비동기 비차단 서버입니다. Nginx 및 Node.js와 같은 프로그램과 완전히 일치합니다.

배달 작업을 전달하는 대신 타임 루프에서 직접 PHP 함수를 호출하세요. 콜백 함수에 차단 작업이 있으면 서버는 동기 모드로 변질됩니다. Worker_num 매개변수는 BASE 모드에서도 여전히 유효하며 여러 작업자 프로세스가 시작됩니다.

BASE 모드에서는 마스터 프로세스의 역할이 없습니다.

각 Worker 프로세스는 Process 모드에서 Reactor 스레드와 Worker 프로세스의 책임을 동시에 맡습니다.

BASE 모드에서는 Manager 프로세스가 선택 사항이며, BASE 모드에서는 Manager 프로세스가 선택 사항입니다. Task 및 MaxRequest 기능을 사용하지 않으면 하위 계층에서 별도의 Worker 프로세스가 생성되고 Manager 프로세스가 생성되지 않습니다.

BASE 모드의 장점:

BASE 모드에는 IPC 오버헤드가 없으며

BASE 모드 코드가 더 좋습니다. 간단하고 쉽지 않습니다. Error

BASE 모드의 단점:

TCP 연결은 작업자 프로세스에서 유지되므로 작업자 프로세스가 중단되면 이 작업자의 모든 연결이 닫힙니다.

몇 개의 긴 TCP 연결은 불가능합니다. 모든 Worker 프로세스에 사용됩니다

TCP 연결은 Worker에 바인딩되어 있습니다. 연결이 긴 애플리케이션의 일부 연결에는 많은 양의 데이터가 있으며 이러한 연결이 있는 Worker 프로세스의 부하가 매우 높습니다. 그러나 일부 연결의 데이터 볼륨이 작기 때문에 작업자 프로세스의 로드가 매우 낮고 다른 작업자 프로세스가 균형을 이룰 수 없습니다.

BASE 모드에 적용 가능한 시나리오:

클라이언트 연결 간 상호 작용이 필요하지 않은 경우 BASE 모드를 사용할 수 있습니다. Memcache, HTTP 서버 등

추천 학습: swoole 비디오 튜토리얼

프로세스 모드(SWOOLE_PROCESS)

다중 프로세스 모드는 많은 프로세스 간 통신 및 프로세스 관리 메커니즘을 사용하는 가장 복잡한 방법입니다. 매우 복잡한 비즈니스 논리가 있는 시나리오에 적합합니다. Swoole은 완전한 프로세스 관리 및 메모리 보호 메커니즘을 제공합니다. 비즈니스 로직이 매우 복잡하더라도 오랫동안 안정적으로 실행될 수 있습니다.

Swoole은 다수의 느린 연결과 바이트 단위의 악성 클라이언트를 처리할 수 있는 Reactor 스레드의 버퍼 기능을 제공합니다. 또한 프로그램을 보다 효율적으로 실행할 수 있도록 CPU 선호도 설정 옵션이 제공됩니다.

프로세스 모드의 장점:

연결과 데이터 요청 전송이 분리되어 있으며 일부 연결에는 데이터 양이 많고 일부 연결에는 데이터 양이 적으므로 작업자 프로세스의 불균형이 발생하지 않습니다.

작업자 프로세스에서 전송합니다. 치명적인 오류가 발생해도 연결은 끊어지지 않습니다.

단일 연결 동시성을 달성할 수 있고 소수의 TCP 연결만 유지되며 요청은 여러 작업자 프로세스에서 동시에 처리될 수 있습니다.

프로세스 모드의 단점:

마스터 프로세스와 작업자 프로세스에 필요한 IPC 2개의 오버헤드가 있습니다. UnixSocket을 사용하여 통신합니다.

sendwait, 일시 중지, 재개 및 기타 작업과 같은 일부 고급 기능을 지원하지 않습니다.

위 내용은 스울은 어떻게 작동하나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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