>  기사  >  백엔드 개발  >  Swoole 코루틴과 기존 fpm 동기화 모드 비교

Swoole 코루틴과 기존 fpm 동기화 모드 비교

藏色散人
藏色散人앞으로
2019-04-28 10:07:103609검색

배열이 PHP의 본질이라면, 배열을 다룰 줄 모른다면 아예 PHP를 사용할 수 없다고 볼 수 없습니다. Swoole의 코루틴에도 동일하게 적용됩니다. 코루틴을 이해하지 못하고 Swoole을 사용한다면 맹목적으로 사용하는 것입니다.

Swoole 코루틴과 기존 fpm 동기화 모드 비교

우선 Swoole은 명령줄(Cli) 모드에서만 실행할 수 있기 때문에 개발과 디버깅에는 가 아닌 명령줄을 사용합니다. > php-fpm/apache 등. php-fpm/apache 等。

在 Swoole 中,我们可以使用`SwooleCoroutine::create()`

Swoole에서는 `SwooleCoroutine::create()`를 사용하여 코루틴을 만들거나 약어 `go()`를 사용할 수도 있습니다.

Swoole 코루틴에 대한 첫 만남

go(function(){
    go(function(){
        echo 0, PHP_EOL;
    });
    echo 1, PHP_EOL;
});
go(function(){
    echo 2, PHP_EOL;
});
go(function(){
    echo 3, PHP_EOL;
});

실행 결과:

0
1
2
3
Swoole 코루틴 및 동기식 모드 비교

우리는 Swoole 코루틴이 I/O 집약적 시나리오에 적합하다고 항상 말해왔습니다. 동일한 하드웨어 구성 환경에서는 기존 동기 모드보다 더 많은 데이터를 전달합니다.

우리에게 익숙한 파일 읽기 및 쓰기, 네트워크 통신 요청(MySQL, Redis, HTTP 등)은 모두 I/O 집약적인 시나리오입니다.

SQL 쿼리에 100ms가 걸린다고 가정하면 기존 동기화 모드에서 현재 프로세스는 이 100ms 동안 다른 작업을 수행할 수 없습니다. 이 SQL을 10번 실행하려면 1초 이상 걸릴 수도 있습니다.

코루틴을 사용하는 경우, 서로 다른 코루틴이 순서대로 실행되더라도 이전 코루틴에 대한 100ms의 대기 시간 동안 하위 계층에서는 CPU가 다른 코루틴의 작업을 수행하도록 예약합니다. 즉, 첫 번째 쿼리가 결과를 반환하기 전에 여러 다른 쿼리가 MySQL로 전송되어 실행되고 있을 가능성이 있습니다. 10개의 코루틴이 열리고 이 SQL이 별도로 실행되는 경우 완료하는 데 100ms 이상만 걸릴 수 있습니다.

테스트 코드는 다음과 같습니다.

Swoole\Runtime::enableCoroutine(); // 开启一键协程化
 
function work()
{
    $pdo = new \PDO('mysql:host=127.0.0.1;dbname=db_test', 'root', 'root');
    $pdo->exec('select SLEEP(0.1)'); // 模拟sql需要执行 100ms 的情况
}
$time = microtime(true);
for($i = 0; $i < 10; ++$i)
{
    work();
}
echo &#39;time: &#39;, (microtime(true) - $time), &#39;s&#39;, PHP_EOL;
$time = microtime(true);
for($i = 0; $i < 10; ++$i)
{
    go(&#39;work&#39;);
}
swoole_event_wait(); // 等待所有协程执行完
echo &#39;time: &#39;, (microtime(true) - $time), &#39;s&#39;, PHP_EOL;

실행 결과:

time: 1.0326268672943s
time: 0.10734605789185s

위 코드는 단일 프로세스에 소요되는 시간으로 짐작할 수 있습니다. 10개의 요청을 처리합니다. 각 요청에는 100ms가 소요되는 SQL 문을 실행해야 합니다.

약 1초 정도 걸리는 동기 모드가 fpm입니다. 보시다시피 100ms를 기다리는 동안에는 아무 것도 할 수 없습니다.

Coroutine 모델 중 0.1초 정도 걸리는 것이 Swoole입니다. 100ms의 대기 기간 동안 현재 코루틴은 일시 중지되고 기본 스케줄링을 통해 CPU가 다른 코루틴의 작업을 수행할 수 있습니다. #🎜🎜#

위 내용은 Swoole 코루틴과 기존 fpm 동기화 모드 비교의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 yurunsoft.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제