検索
ホームページPHPフレームワークThinkPHPThinkPHP6 と Swoole で構築された非同期 RPC サービス

ThinkPHP6 と Swoole で構築された非同期 RPC サービス

Oct 12, 2023 am 11:10 AM
thinkphpswoole非同期 RPC

ThinkPHP6 と Swoole で構築された非同期 RPC サービス

ThinkPHP6 と Swoole を使用して構築された非同期 RPC サービス

はじめに:
インターネットの発展と普及に伴い、分散システムの適用はますます増えています。分散システムでは、RPC (リモート プロシージャ コール) は、異なるサービス間の通信を実現する重要な方法の 1 つです。従来の RPC は通常、同期要求応答モードを採用しています。つまり、呼び出し元は RPC 要求を開始し、応答結果が返されるのを待ちます。ただし、同期 RPC モードには、リクエスタが応答結果が返されるまで待つ必要があるため、リクエスタがブロックされ、システムのパフォーマンスに影響を与えるなど、いくつかの欠点があります。この問題を解決するために、非同期 RPC モードを使用できます。つまり、リクエスタがリクエストを送信した後、レスポンス結果が返されるのを待つ必要がなく、他のリクエストの処理を続行し、応答が返されるのを待つことができます。処理前に返される応答結果。この記事では、ThinkPHP6 と Swoole を使用して非同期 RPC サービスを構築する方法と、具体的なコード例を紹介します。

1. 非同期 RPC の概念と原理
非同期 RPC は、結果が返されるのを待つ必要のない RPC メソッドであり、同期 RPC と比較してパフォーマンスと同時実行パフォーマンスが優れています。非同期 RPC モードでは、呼び出し元がリクエストを送信した後、リモート サービスが結果を返すのを待つ必要がなく、他のビジネス ロジックの実行を続けることができます。リモート サービスがリクエストを処理して結果を返すと、呼び出し元はコールバック通知を受け取ります。

非同期 RPC の基本原理は次のとおりです。

  1. 呼び出し元はリモート サービスにリクエストを送信します。
  2. リモート サービスはリクエストを受信した後、リクエストをメッセージ キューに入れます。
  3. 呼び出し元は一意の識別子をリモート サービスに返します。
  4. リモート サービスはリクエストを処理し、結果をメッセージ キューに入れます。
  5. リモート サービスは呼び出し元に通知を非同期に送信し、通知にはリクエストの一意の識別子が指定されます。
  6. 呼び出し元は通知を受信すると、識別子に従ってメッセージ キューから結果を取得します。

2. ThinkPHP6 と Swoole を使用して非同期 RPC サービスを構築する手順
このセクションでは、次の手順に従って、ThinkPHP6 と Swoole を使用して非同期 RPC サービスを構築します。

  1. ThinkPHP6 と Swoole のインストール
    まず、ThinkPHP6 と Swoole をインストールする必要があります。 ThinkPHP6 は、次のコマンドでインストールできます。
composer create-project topthink/think app

次に、次のコマンドで Swoole をインストールします。

composer require swoole/swoole
  1. ThinkPHP6 の Swoole サーバーを構成します。 ThinkPHP6## のファイル #config/server.php
    で、Swoole サーバーの関連パラメーターを設定します。たとえば、サーバーの IP アドレス、ポート番号、ワーカー プロセスの数などを構成できます。
    'swoole' => [
        // 监听的地址
        'host' => '127.0.0.1',
        // 监听的端口
        'port' => 9501,
        // 工作进程数
        'worker_num' => 4,
    ],
非同期 RPC サービスの作成
    ThinkPHP6 のコントローラーに、非同期 RPC サービスのメソッドを作成します。まず、Swoole を使用して非同期 RPC サーバーを作成し、指定された IP アドレスとポート番号をリッスンする必要があります。次に、コールバック関数を定義して受信したリクエストを処理し、結果をメッセージキューに入れます。最後に、通知は呼び出し元に非同期で送信されます。

  1. 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)
        {
            // 异步发送通知给调用方
            // ...
        }
    }
非同期 RPC サービスの呼び出し
    ThinkPHP6 のコントローラーで、非同期 RPC サービスを呼び出します。 Swoole の
  1. HttpClient
    を使用して非同期 RPC サーバーにリクエストを送信すると、結果が返されるまで待つ必要がなく、他のリクエストの処理を続けることができます。
    use SwooleHttpClient;
    
    class IndexController
    {
        public function index()
        {
            $client = new Client('127.0.0.1', 9501);
            $client->post('/rpc', [], 'request data', function ($client) {
                // 发送请求后,不需要等待结果返回,可以继续处理其他请求
                // ...
            });
        }
    }
  2. 要約:
この記事の導入を通じて、非同期 RPC の概念と原則を理解し、ThinkPHP6 と Swoole を使用して単純な非同期 RPC サービスを構築しました。実際のアプリケーションでは、分散システムのニーズを満たすために、特定のニーズに応じて非同期 RPC を拡張および最適化できます。この記事が、ThinkPHP6 と Swoole を使用して非同期 RPC サービスを構築する開発者にとって役立つことを願っています。


参考資料:

ThinkPHP ドキュメント: https://www.kancloud.cn/manual/thinkphp6_0/1037639
  1. Swoole ドキュメント: https://www 。 swoole.co.uk/docs

以上がThinkPHP6 と Swoole で構築された非同期 RPC サービスの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

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

ホットツール

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境

MantisBT

MantisBT

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

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

mPDF

mPDF

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