この記事では、RPC とは何か、そして PHP を使用して RPC サービスを簡単かつ迅速に作成する方法を紹介します。実際は非常に簡単です。見てみましょう~困っている友達に役立つことを願っています~
RPC は Remote Procedure Call の略で、「リモート プロシージャ コール」と訳されます。主にリモート通信や異なるシステム間の相互通話に使用されます。 [推奨学習: PHP ビデオ チュートリアル ]
たとえば、2 つのシステムがあり、1 つは PHP で書かれ、もう 1 つは JAVA で書かれており、PHP は特定のクラスを呼び出したいと考えています。 JAVA 特定のメソッドでは、現時点では RPC を使用する必要があります。
調整方法は?直接調整は不可能です。PHP は、カスタム プロトコルを通じてのみ JAVA のサービスを要求できます。JAVA はプロトコルを解析し、ローカルでクラスをインスタンス化し、メソッドを呼び出し、結果を PHP に返します。
ここでは、PHP のソケット拡張機能を使用してサーバーとクライアントを作成し、呼び出しプロセスを示します。
RpcServer.php コードは次のとおりです:
<?php class RpcServer { protected $serv = null; public function __construct($host, $port, $path) { //创建一个tcp socket服务 $this->serv = stream_socket_server("tcp://{$host}:{$port}", $errno, $errstr); if (!$this->serv) { exit("{$errno} : {$errstr} \n"); } //判断我们的RPC服务目录是否存在 $realPath = realpath(__DIR__ . $path); if ($realPath === false || !file_exists($realPath)) { exit("{$path} error \n"); } while (true) { $client = stream_socket_accept($this->serv); if ($client) { //这里为了简单,我们一次性读取 $buf = fread($client, 2048); //解析客户端发送过来的协议 $classRet = preg_match('/Rpc-Class:\s(.*);\r\n/i', $buf, $class); $methodRet = preg_match('/Rpc-Method:\s(.*);\r\n/i', $buf, $method); $paramsRet = preg_match('/Rpc-Params:\s(.*);\r\n/i', $buf, $params); if($classRet && $methodRet) { $class = ucfirst($class[1]); $file = $realPath . '/' . $class . '.php'; //判断文件是否存在,如果有,则引入文件 if(file_exists($file)) { require_once $file; //实例化类,并调用客户端指定的方法 $obj = new $class(); //如果有参数,则传入指定参数 if(!$paramsRet) { $data = $obj->$method[1](); } else { $data = $obj->$method[1](json_decode($params[1], true)); } //把运行后的结果返回给客户端 fwrite($client, $data); } } else { fwrite($client, 'class or method error'); } //关闭客户端 fclose($client); } } } public function __destruct() { fclose($this->serv); } } new RpcServer('127.0.0.1', 8888, './service');
RpcClient.php コードは次のとおりです:
<?php class RpcClient { protected $urlInfo = array(); public function __construct($url) { //解析URL $this->urlInfo = parse_url($url); if(!$this->urlInfo) { exit("{$url} error \n"); } } public function __call($method, $params) { //创建一个客户端 $client = stream_socket_client("tcp://{$this->urlInfo['host']}:{$this->urlInfo['port']}", $errno, $errstr); if (!$client) { exit("{$errno} : {$errstr} \n"); } //传递调用的类名 $class = basename($this->urlInfo['path']); $proto = "Rpc-Class: {$class};" . PHP_EOL; //传递调用的方法名 $proto .= "Rpc-Method: {$method};" . PHP_EOL; //传递方法的参数 $params = json_encode($params); $proto .= "Rpc-Params: {$params};" . PHP_EOL; //向服务端发送我们自定义的协议数据 fwrite($client, $proto); //读取服务端传来的数据 $data = fread($client, 2048); //关闭客户端 fclose($client); return $data; } } $cli = new RpcClient('http://127.0.0.1:8888/test'); echo $cli->hehe(); echo $cli->hehe2(array('name' => 'test', 'age' => 27));
次に、上記の 2 つのスクリプトをそれぞれ実行します (php で追加する必要があることに注意してください)環境変数)
> php RpcServer.php > php RpcClient.php
結果は次のとおりです:
Test.php コードは次のとおりです:
<?php class Test { public function hehe() { return 'hehe'; } public function hehe2($params) { return json_encode($params); } }
ディレクトリ構造は次のとおりです。
クライアントとサーバーが統合され、解析できる限り、上記のカスタマイズされたプロトコルは自由に変更できます。
クライアントはサーバーにリクエストすることで、呼び出されるクラス、メソッド、パラメータをサーバーに渡し、サーバーは呼び出したメソッドをインスタンス化して結果を返します。
以上がPHP が RPC サービスを迅速に作成する方法を分析する (コードのデモ)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。