Reactor 스레드
SwooleServer의 주요 프로세스는 멀티 스레드 프로그램입니다. Reactor 스레드라고 하는 매우 중요한 스레드 그룹이 있습니다. 실제로 TCP 연결을 처리하고 데이터를 주고받는 스레드입니다.
새 연결을 수락한 후 Swoole의 메인 스레드는 고정된 Reactor 스레드에 연결을 할당하고 이 스레드는 소켓 모니터링을 담당합니다. 소켓을 읽을 수 있을 때 데이터를 읽고, 프로토콜 분석을 수행하고, 요청을 작업자 프로세스에 전달합니다. 소켓에 쓰기가 가능해지면 TCP 클라이언트에 데이터를 보냅니다.
할당은 fd % serv->reactor_num
으로 계산됩니다. PHP 언어는 멀티스레딩을 지원하지 않기 때문에 Swoole은 멀티프로세스 모드를 사용합니다. 다중 프로세스 모드에는 프로세스 메모리 격리가 있습니다. 작업 프로세스에서 전역 변수와 슈퍼 전역 변수가 수정되면 다른 프로세스에서는 유효하지 않습니다.
worker_num=1로 설정하면 프로세스 격리가 없으며 전역 변수를 사용하여 데이터를 저장할 수 있습니다.
프로세스 격리
$fds = array(); $server->on('connect', function ($server, $fd){ echo "connection open: {$fd}\n"; global $fds; $fds[] = $fd; var_dump($fds); });
$fds 전역 변수이지만 현재 내에서만 유효합니다. 프로세스. Swoole 서버의 맨 아래 계층은 여러 작업자 프로세스를 생성합니다. var_dump($fds)에 인쇄된 값에는 부분적으로 연결된 fds만 포함됩니다.
해당 솔루션은 외부 스토리지 서비스를 사용하는 것입니다.
데이터베이스: MySQL, MongoDB
캐시 서버: Redis, Memcache
디스크 파일, 여러 프로세스가 동시에 읽고 쓸 때 잠금이 필요함
일반적인 데이터베이스 및 디스크 파일 작업에는 IO 대기 시간이 많이 걸립니다. 따라서 다음을 사용하는 것이 좋습니다.
Redis 메모리 데이터베이스, 읽기 및 쓰기 속도가 매우 빠릅니다.
/dev/shm 메모리 파일 시스템, 모든 읽기 및 쓰기 작업이 메모리에서 완료되고 IO 소비가 없으며 매우 높은 성능
스토리지 사용 외에도 공유 메모리를 사용하여 데이터를 저장할 수도 있습니다
추천 학습: swoole 비디오 튜토리얼
위 내용은 Swoole은 멀티스레딩을 지원합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!