우선 ThinkPHP의 작동 메커니즘을 이해해 봅시다.
TP5 운영 메커니즘:
모든 요청은 tp5 항목 파일을 거쳐 프레임워크 구성 파일을 로드하고 프로세스를 시작한 다음 요청을 처리합니다.
index.php의 항목 파일에서는 먼저 APP_PATH 상수를 정의한 다음 프레임워크의 시작 파일인 start.php를 소개하는 것을 볼 수 있습니다. 그런 다음 start.php 파일을 살펴보겠습니다. 무슨 일이 일어났습니다.
여기서 먼저 기본 파일인 base.php를 로드한 다음 프레임워크 실행을 시작하고 이때 요청 처리를 시작합니다.
기존의 nginx, Apache 서버에서는 thinkphp에 요청이 올 때마다 정적 변수가 지워지고 구성 파일이 다시 로드됩니다. 그러나 swoole에서 만든 서버는 상주 프로세스이므로 서비스 시작 후 요청을 처리하기 위해 여러 프로세스가 생성됩니다. 우리는 선택적으로 구성을 로드하도록 만들고 싶습니다.
Swoole은 http 서버로 사용됩니다
<?php $http = new swoole_http_server("0.0.0.0", 8888); $http->set( [ 'enable_static_handler' => true, 'document_root' => "/data/wwwroot/zhibo/public/static", 'worker_num' => 5,//产生进程的个数 ] ); $http->on('WorkerStart',function ($ser,$worker_id){ define('APP_PATH', __DIR__ . '/../application/'); require __DIR__ . '/../thinkphp/base.php'; }); $http->on('request', function($request, $response) use($http) { if(isset($request->header)){ foreach ($request->header as $k=>$v){ $_SERVER[strtoupper($k)] = $v; } } if(isset($request->server)){ foreach ($request->server as $k=>$v){ $_HEADER[strtoupper($k)] = $v; } } $_GET = []; if(isset($request->get)){ foreach ($request->get as $k=>$v){ $_GET[$k] = $v; } } $_POST = []; if(isset($request->post)){ foreach ($request->post as $k=>$v){ $_POST[$k] = $v; } } // 执行应用并响应 //开启缓存 ob_start(); try{ think\Container::get('app', [APP_PATH])->run()->send(); }catch (\Exception $e){ } $res = ob_get_contents(); ob_end_clean(); $response->end($res); //$http->close(); }); $http->start();
코드 설명:
(1) $http->onWorkerStart: 프로세스를 시작할 때 thinkphp 프레임워크 파일인 base.php를 로드하지만 이번에는 실행할 수 없습니다. 실행하기 전에 요청이 올 때까지 기다리십시오.
(2) $http->onrequest: 클라이언트로부터 요청을 받으면 swoole 헤더 정보, 서버 정보를 변환하고 데이터를 가져오고 데이터 및 기타 메시지를 일반 $_SERVER, $_GET 및 기타 정보로 변환할 수 있습니다. tp5로.
(3) 마지막으로 실행을 시작합니다. 이때 실행을 통해 얻은 정보를 캐시에 로드한 후 send()를 통해 클라이언트에 반환해야 합니다.
Swoole은 thinkphp5에 적응합니다
swoole은 상주 프로세스이므로 이전 요청의 $_POST 및 $_GET 요청은 삭제되지 않습니다. 그 이유는 이 프로세스가 종료되지 않기 때문입니다. 요청을 받을 때 $를 변경하세요. _GET,$_POST는 비어 있습니다.
Swoole 라우팅 메커니즘은 캐시에서 그러한 요청이 있는지 항상 확인합니다. 있는 경우 새 요청이 로드되지 않습니다. 따라서 Swoole은 메모리에 상주하며 항상 첫 번째 URL이 요청되었음을 찾습니다. Swoole 서버를 다시 시작하지 않는 한.
thinkphp 프레임워크에서 요청 파일을 수정하고 두 가지 메소드(pathinfo, path)에서 $this->path의 빈 판단을 제거하여 각 요청이 이 URL을 구문 분석하도록 합니다.
검증 결과:
위 내용은 참고용입니다!
더 많은 관련 콘텐츠를 알고 싶다면 PHP 중국어 웹사이트를 방문하세요: thinkphp 튜토리얼
위 내용은 thinkphp5는 swoole Ctrip을 지원합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!