>  기사  >  PHP 프레임워크  >  Swoole 코루틴의 구현 원리는 무엇입니까?

Swoole 코루틴의 구현 원리는 무엇입니까?

WBOY
WBOY원래의
2022-02-14 17:42:416597검색

Swoole 서버는 데이터를 수신하고 작업자 프로세스에서 onReceive 콜백을 트리거하여 코루틴을 생성합니다. Swoole은 각 요청에 대해 해당 코루틴을 생성할 수도 있습니다. 코루틴의 기본 구현도 가능합니다. 단일 스레드이므로 동시에 하나의 코루틴만 작동합니다.

Swoole 코루틴의 구현 원리는 무엇입니까?

이 튜토리얼의 운영 환경: Windows 10 시스템, Swoole 4 버전, DELL G3 컴퓨터

Swoole 코루틴의 구현 원리는 무엇인가요?

프로세스란 무엇인가요?

프로세스는 애플리케이션의 시작 인스턴스입니다. 독립적인 파일 자원, 데이터 자원 및 메모리 공간.

스레드란 무엇인가요?

스레드는 프로세스에 속하며 프로그램의 실행자입니다. 프로세스에는 하나 이상의 기본 스레드가 포함되어 있으며 더 많은 하위 스레드가 있을 수도 있습니다. 스레드에는 두 가지 스케줄링 전략이 있습니다. 하나는 시간 공유 스케줄링이고 다른 하나는 선점형 스케줄링입니다.

코루틴이란 무엇인가요?

코루틴은 경량 스레드이고, 코루틴도 스레드에 속하며, 코루틴은 스레드에서 실행됩니다. 코루틴의 스케줄링은 사용자가 수동으로 전환하므로 사용자 공간 스레드라고도 합니다. 코루틴의 생성, 전환, 정지, 소멸은 모두 메모리 작업이며 소모량이 매우 적습니다. 코루틴의 스케줄링 전략은 협업 스케줄링입니다.

Swoole 코루틴의 원리

Swoole4는 단일 스레드 및 다중 프로세스이며 동일한 프로세스에서 동시에 실행되는 코루틴은 하나만 있습니다.

Swoole 서버는 데이터를 수신하고 작업자 프로세스에서 onReceive 콜백을 트리거하여 Ctrip을 생성합니다. Swoole은 각 요청에 대해 해당 Ctrip을 생성합니다. 하위 코루틴은 코루틴에서도 생성될 수 있습니다.

코루틴의 기본 구현은 단일 스레드이므로 동시에 작동하는 코루틴은 하나만 있고 코루틴의 실행은 직렬입니다.

그래서 멀티 태스킹과 멀티 코루틴이 실행될 때 하나의 코루틴이 실행되면 다른 코루틴은 작동을 멈춥니다. 차단 IO 작업을 수행할 때 현재 코루틴이 중단되고 기본 스케줄러가 이벤트 루프에 들어갑니다. IO 완료 이벤트가 발생하면 기본 스케줄러는 이벤트에 해당하는 코루틴의 실행을 재개합니다. . 따라서 코루틴은 IO 시간 소비가 없으며 동시성이 높은 IO 시나리오에 매우 적합합니다. (아래 그림 참조)

Swoole 코루틴의 구현 원리는 무엇입니까?

Swoole의 코루틴 실행 프로세스

  • 코루틴에는 IO가 없고 PHP 코드의 정상적인 실행을 기다리며 실행 흐름 전환이 발생하지 않습니다.

  • 코루틴은 IO를 만나서 기다립니다. 즉시 제어를 위해 오른쪽 잘라내기, IO가 완료된 후 원래 코루틴이 잘린 지점으로 실행 흐름을 다시 전환합니다

  • 코루틴과 병렬 코루틴이 순차적으로 실행되며 이전 것과 동일한 논리

  • 외부에서 내부로 중첩된 코루틴 실행 프로세스 IO가 발생할 때까지 레이어가 들어간 다음 상위 코루틴은 하위 코루틴이 끝날 때까지 기다리지 않습니다.

코루틴의 실행 순서

먼저 기본 예제를 살펴보겠습니다.

go(function () {
    echo "hello go1 \n";});echo "hello main \n";go(function () {
    echo "hello go2 \n";});

go()는 Co::create()의 약어이며, 콜백을 매개변수로 받아들이는 코루틴을 생성하는 데 사용됩니다. new coroutine.

참고: SwooleCoroutine은 Co

로 축약할 수 있습니다. 위 코드의 실행 결과:

root@b98940b00a9b /v/w/c/p/swoole# php co.phphello go1
hello main
hello go2

실행 결과는 우리가 일반적으로 코드를 작성하는 순서와 다르지 않은 것 같습니다.

  • 이 코드를 실행하면 시스템이 새로운 프로세스를 시작합니다

  • go( )를 만나고, 현재 프로세스에서 코루틴이 생성되고, heelo go1이 코루틴에 출력되고, 코루틴이 종료됩니다

  • 프로세스는 계속됩니다 코드를 실행하면 hello main

  • 이 출력되고 또 다른 코루틴이 생성되고 heelo go2가 코루틴에서 출력되고 코루틴이 종료됩니다

이 코드를 실행하면 시스템이 새 프로세스를 시작합니다. 이 문장을 이해하지 못하는 경우 다음 코드를 사용할 수 있습니다.

// co.php<?phpsleep(100);

ps aux를 실행하고 사용하여 시스템의 프로세스를 확인하세요.

root@b98940b00a9b /v/w/c/p/swoole# php co.php &⏎
root@b98940b00a9b /v/w/c/p/swoole# ps auxPID   USER     TIME   COMMAND
    1 root       0:00 php -a   10 root       0:00 sh   19 root       0:01 fish  749 root       0:00 php co.php  760 root       0:00 ps aux

us 약간 변경하여 코루틴 예약을 경험해 보겠습니다.

use Co;go(function () {
    Co::sleep(1); // 只新增了一行代码
    echo "hello go1 \n";});echo "hello main \n";go(function () {
    echo "hello go2 \n";});
\Co::sleep() 函数功能和 sleep() 差不多, 但是它模拟的是 IO等待(IO后面会细讲). 执行的结果如下:
root@b98940b00a9b /v/w/c/p/swoole# php co.phphello main
hello go2
hello go1

왜 순차적으로 실행되지 않았나요? 실제 실행 프로세스:

  • 이 코드를 실행하면 시스템이 새 프로세스를 시작합니다.

  • go()가 발생하고 현재 프로세스에서 코루틴이 생성됩니다

  • 코루틴이 IO 차단( 여기에 Co::sleep()에 의해 시뮬레이션된 IO가 있습니다. 코루틴은 제어를 포기하고 코루틴 예약 대기열에 들어갑니다

  • 프로세스 실행을 계속하고 hello main

  • 을 출력하여 다음 코루틴을 실행하고 hello go2를 출력합니다.

  • 이전 코루틴이 준비되었습니다. 실행을 계속하고 hello go1을 출력합니다.

여기까지 이미 swoole을 볼 수 있습니다. 코루틴과 프로세스의 관계 및 코루틴의 스케줄링과 관련하여 프로그램을 변경해 보겠습니다. 지금:

go(function () {
    Co::sleep(1);
    echo "hello go1 \n";});echo "hello main \n";go(function () {
    Co::sleep(1);
    echo "hello go2 \n";});

당신은 이미 출력이 어떻게 보이는지 알고 있다고 생각합니다:

root@b98940b00a9b /v/w/c/p/swoole# php co.phphello main
hello go1
hello go2

권장 학습: swoole 튜토리얼

위 내용은 Swoole 코루틴의 구현 원리는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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