>PHP 프레임워크 >Workerman >워커맨의 성과는 어떤가요?

워커맨의 성과는 어떤가요?

(*-*)浩
(*-*)浩원래의
2019-12-02 10:28:052265검색

워커맨의 성과는 어떤가요?

Workerman의 성능이 뛰어난 이유

간단한 프로세스 통신 모델은 Workerman을 다른 복잡한 프로세스 모델 소프트웨어보다 효율적으로 만듭니다. (추천 학습: workerman 튜토리얼)

디스크 읽기 및 반복 컴파일을 피하세요

workerman 작업 중에는 단일 프로세스의 라이프 사이클에서 PHP 파일이 한 번 로드되고 컴파일되는 한, 디스크에서 읽거나 다시 컴파일할 필요가 없습니다.

workerman은 반복되는 요청 초기화, 실행 환경 생성, 어휘 구문 분석, 구문 구문 분석, opcode 컴파일 및 생성, 요청 닫기 등 시간이 많이 걸리는 많은 단계를 제거합니다.

실제로 Workerman을 실행한 후에는 디스크 IO 및 PHP 파일 컴파일 오버헤드가 거의 없습니다. 나머지는 단순한 계산 프로세스일 뿐이므로 Workerman이 매우 빠르게 실행됩니다.

데이터 또는 리소스는 전역적으로 공유될 수 있습니다.

Workerman의 여러 요청은 데이터 또는 리소스를 공유할 수 있습니다. 현재 요청에 의해 생성된 클래스의 전역 변수 또는 정적 멤버는 다음 요청에서도 계속 유효합니다. 이는 오버헤드를 줄이고 운영 효율성을 향상시키는 데 매우 유용합니다.

예를 들어 기업이 데이터베이스 연결을 한 번만 초기화하면 전 세계가 이 연결을 공유할 수 있어 진정한 데이터베이스 긴 연결이 실현됩니다. 이를 통해 사용자가 요청할 때마다 새로운 연결을 생성할 필요가 없으며, 연결 중 3방향 핸드셰이크, 연결 후 권한 확인, 연결 해제 시 4웨이브와 같이 시간이 많이 걸리는 상호 작용 프로세스를 피할 수 있습니다.

데이터베이스뿐만 아니라 redis, memcache 등도 효과적입니다. 이러한 오버헤드와 네트워크 상호 작용을 줄이면 Workerman의 실행 속도가 빨라집니다.

추가 네트워크 오버헤드 없음

기존 PHP 애플리케이션은 외부 네트워크 서비스를 제공하기 위해 apache 및 nginx와 같은 컨테이너를 사용해야 하며, 이로 인해 apache, nginx 및 기타 컨테이너에서 PHP 프로세스로 데이터 전송 오버헤드가 추가로 발생합니다.

Apache 또는 nginx 컨테이너가 실행 중이므로 서버 리소스가 더 많이 소모됩니다. Workerman은 이러한 오버헤드가 없습니다. 이는 Workerman 자체가 PHP 프로세스 관리 및 네트워크 통신 기능을 갖춘 서버 컨테이너이기 때문입니다. Apache, nginx, php-fpm 및 기타 컨테이너에 의존하지 않고 독립적으로 실행할 수 있으므로 성능이 더 높습니다. .

위 내용은 워커맨의 성과는 어떤가요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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