우선 Swoole은 명령줄(Cli) 모드에서만 실행할 수 있기 때문에 개발 및 디버깅에는 php-fpm/apache가 아닌 명령줄을 사용하며, 등. Swoole에서는 `SwooleCoroutine::create()`
을 사용하여 코루틴을 만들거나 약어 `go()`를 사용할 수도 있습니다.
Swoole 코루틴 첫 소개
실행 결과:
#🎜 🎜#
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 'time: ', (microtime(true) - $time), 's', PHP_EOL; $time = microtime(true); for($i = 0; $i < 10; ++$i) { go('work'); } swoole_event_wait(); // 等待所有协程执行完 echo 'time: ', (microtime(true) - $time), 's', PHP_EOL;
time: 1.0326268672943s time: 0.10734605789185s
위 내용은 기존 fpm 동기화 모드와 swoole 코루틴의 차이점의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!