アプリケーションがより複雑で分散化するにつれて、言語を越えたリモート プロシージャ コール (RPC) と通信がますます重要になります。ソフトウェア開発において、RPC は、さまざまなプログラムまたはプロセスがネットワーク上で相互に通信できるようにするテクノロジーを指します。
Thrift は、効率的な言語間 RPC サービスを迅速に開発するのに役立つ、シンプルで使いやすい RPC フレームワークです。 Thrift は Facebook によって開発された、効率的なリモート サービス呼び出しプロトコルです。 PHP、Java、Python、C、Ruby などの複数の言語をサポートします。
この記事では、PHP で Thrift を使用して言語を超えたリモート プロシージャ コールと通信を実装する方法を紹介します。
Thrift を使用する前に、まずインストールする必要があります。 Thrift のインストールは非常に簡単で、公式 Web サイトから対応するバージョンのバイナリ ファイルをダウンロードするだけです。 Thrift は、Windows、Linux、および Mac OS X システムをサポートします。
インストールが完了したら、コマンド ライン ツールを使用して必要なコードとサービス フレームワークを生成できます。
Thrift は、IDL (インターフェイス定義言語) を使用して RPC サービスを定義します。 IDL を通じて、他のアプリケーションに公開するサービス メソッド、パラメータの型、および戻り値の型を定義できます。
次は、Thrift でメソッドを定義する方法を示す簡単な例です:
service HelloWorld { string sayHello(1: string name), }
この IDL は、HelloWorld という名前のサービスを定義します。このサービスには、sayHello という名前のメソッドがあり、文字列パラメータを入力して " name」と入力し、文字列タイプ「Hello, name!」を返します。
Thrift サービス定義ファイルを定義した後、Thrift コンパイラーを使用して必要なコードを生成する必要があります。 Thrift コンパイラは、IDL ファイルをさまざまな言語のタイプおよびサービス コードに変換します。
PHP では、次のコマンドを使用してコードを生成できます:
thrift --gen php example.thrift
その中で、example.thrift は今定義した IDL ファイルです。
PHP コードを生成した後、特定のサービス実装を記述する必要があります。 「Hello, name!」という文字列を返す単純な HelloWorld サービスを実装します。
次は簡単な例です:
<?php require_once 'HelloWorldService.php'; class HelloWorldHandler implements HelloWorldServiceIf { public function sayHello($name) { return "Hello, " . $name . "! "; } } $handler = new HelloWorldHandler(); $processor = new HelloWorldServiceProcessor($handler); $transport = new TServerSocket('localhost', 8000); $server = new TSimpleServer($processor, $transport); $server->serve(); ?>
この例では、HelloWorldServiceIf インターフェイスに SayHello メソッドを実装し、文字列「Hello, name!」を返します。 HelloWorldHandler オブジェクトを作成し、それをサービス実装として使用します。次に、Thrift が提供する TSimpleServer クラスを使用して TCP サーバーを作成し、ポート番号を 8000 に設定します。最後に、サーバーを起動し、クライアントがリクエストを送信するのを待ちます。
サーバー コードを作成した後、現在のサービスを呼び出すクライアント コードを作成する必要があります。 PHP では、Thrift が提供する THttpClient または TSocket クラスを使用してサーバーにアクセスできます。
以下は簡単な例です:
<?php require_once 'HelloWorldService.php'; $socket = new TSocket('localhost', 8000); $transport = new TBufferedTransport($socket, 1024, 1024); $protocol = new TBinaryProtocol($transport); $client = new HelloWorldServiceClient($protocol); $transport->open(); echo $client->sayHello('John'); $transport->close(); ?>
この例では、TSocket オブジェクトを作成し、それをサーバーと通信するためのトランスポート層として使用します。 TBufferedTransport を使用してトランスポート層をバッファーにラップし、クライアント プロトコルを TBinaryProtocol に設定します。次に、クライアント プロトコルを入出力プロトコルとして使用する HelloWorldServiceClient オブジェクトを作成しました。最後に、sayHello メソッドを呼び出し、「John」という名前の文字列パラメータを渡します。応答では、「Hello, John!」という文字列を出力します。
この記事の学習を通じて、PHP で Thrift を使用して言語を超えたリモート プロシージャ呼び出しと通信を実現する方法を学びました。 Thrift サービスを定義し、必要なコードを生成し、サーバー側のコードを実装し、クライアント側のコードを作成する方法を学びました。 Thrift を使用すると、最新のアプリケーション開発に不可欠な、効率的な言語間 RPC サービスを簡単に実装できます。
以上がThrift を使用して PHP で言語を超えたリモート プロシージャ呼び出しと通信を実装するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。