ThinkPHP6 と Swoole を使用して構築された非同期 RPC サービス
はじめに:
インターネットの発展と普及に伴い、分散システムの適用はますます増えています。分散システムでは、RPC (リモート プロシージャ コール) は、異なるサービス間の通信を実現する重要な方法の 1 つです。従来の RPC は通常、同期要求応答モードを採用しています。つまり、呼び出し元は RPC 要求を開始し、応答結果が返されるのを待ちます。ただし、同期 RPC モードには、リクエスタが応答結果が返されるまで待つ必要があるため、リクエスタがブロックされ、システムのパフォーマンスに影響を与えるなど、いくつかの欠点があります。この問題を解決するために、非同期 RPC モードを使用できます。つまり、リクエスタがリクエストを送信した後、レスポンス結果が返されるのを待つ必要がなく、他のリクエストの処理を続行し、応答が返されるのを待つことができます。処理前に返される応答結果。この記事では、ThinkPHP6 と Swoole を使用して非同期 RPC サービスを構築する方法と、具体的なコード例を紹介します。
1. 非同期 RPC の概念と原理
非同期 RPC は、結果が返されるのを待つ必要のない RPC メソッドであり、同期 RPC と比較してパフォーマンスと同時実行パフォーマンスが優れています。非同期 RPC モードでは、呼び出し元がリクエストを送信した後、リモート サービスが結果を返すのを待つ必要がなく、他のビジネス ロジックの実行を続けることができます。リモート サービスがリクエストを処理して結果を返すと、呼び出し元はコールバック通知を受け取ります。
非同期 RPC の基本原理は次のとおりです。
- 呼び出し元はリモート サービスにリクエストを送信します。
- リモート サービスはリクエストを受信した後、リクエストをメッセージ キューに入れます。
- 呼び出し元は一意の識別子をリモート サービスに返します。
- リモート サービスはリクエストを処理し、結果をメッセージ キューに入れます。
- リモート サービスは呼び出し元に通知を非同期に送信し、通知にはリクエストの一意の識別子が指定されます。
- 呼び出し元は通知を受信すると、識別子に従ってメッセージ キューから結果を取得します。
2. ThinkPHP6 と Swoole を使用して非同期 RPC サービスを構築する手順
このセクションでは、次の手順に従って、ThinkPHP6 と Swoole を使用して非同期 RPC サービスを構築します。
- ThinkPHP6 と Swoole のインストール
まず、ThinkPHP6 と Swoole をインストールする必要があります。 ThinkPHP6 は、次のコマンドでインストールできます。
composer create-project topthink/think app
次に、次のコマンドで Swoole をインストールします。
composer require swoole/swoole
- ThinkPHP6 の Swoole サーバーを構成します。 ThinkPHP6## のファイル #config/server.php
で、Swoole サーバーの関連パラメーターを設定します。たとえば、サーバーの IP アドレス、ポート番号、ワーカー プロセスの数などを構成できます。'swoole' => [ // 监听的地址 'host' => '127.0.0.1', // 监听的端口 'port' => 9501, // 工作进程数 'worker_num' => 4, ],
- ThinkPHP6 のコントローラーに、非同期 RPC サービスのメソッドを作成します。まず、Swoole を使用して非同期 RPC サーバーを作成し、指定された IP アドレスとポート番号をリッスンする必要があります。次に、コールバック関数を定義して受信したリクエストを処理し、結果をメッセージキューに入れます。最後に、通知は呼び出し元に非同期で送信されます。
-
use SwooleHttpServer; use SwooleProcess; class RpcController { public function index() { $server = new Server('127.0.0.1', 9501); $server->on('request', function ($request, $response) { // 处理请求并返回结果 $result = $this->handleRequest($request); // 将结果放入消息队列中 $this->putToQueue($result); // 异步发送通知给调用方 $this->sendNotification($response); }); // 启动RPC服务器 $server->start(); } private function handleRequest($request) { // 处理请求并返回结果 // ... } private function putToQueue($result) { // 将结果放入消息队列中 // ... } private function sendNotification($response) { // 异步发送通知给调用方 // ... } }
- ThinkPHP6 のコントローラーで、非同期 RPC サービスを呼び出します。 Swoole の
- HttpClient
を使用して非同期 RPC サーバーにリクエストを送信すると、結果が返されるまで待つ必要がなく、他のリクエストの処理を続けることができます。use SwooleHttpClient; class IndexController { public function index() { $client = new Client('127.0.0.1', 9501); $client->post('/rpc', [], 'request data', function ($client) { // 发送请求后,不需要等待结果返回,可以继续处理其他请求 // ... }); } }
要約:
参考資料:
- Swoole ドキュメント: https://www 。 swoole.co.uk/docs
以上がThinkPHP6 と Swoole で構築された非同期 RPC サービスの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

メモ帳++7.3.1
使いやすく無料のコードエディター

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。
