您好,登錄后才能下訂單哦!
PHP中怎么創建一個RPC服務,相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
RPC全稱為Remote Procedure Call,翻譯過來為"遠程過程調用"。主要應用于不同的系統之間的遠程通信和相互調用。
比如有兩個系統,一個是PHP寫的,一個是JAVA寫的,而PHP想要調用JAVA中的某個類的某個方法,這時候就需要用到RPC了。
怎么調?直接調是不可能,只能是PHP通過某種自定義協議請求JAVA的服務,JAVA解析該協議,在本地實例化類并調用方法,然后把結果返回給PHP。
這里我們用PHP的socket擴展來創建一個服務端和客戶端,演示調用過程。
RpcServer.php代碼如下:
<?phpclass 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));
然后分別運行上面兩個腳本(注意,php要添加環境變量)
> php RpcServer.php > php RpcClient.php
結果如下:
Test.php代碼如下:
<?phpclass Test { public function hehe() { return 'hehe'; } public function hehe2($params) { return json_encode($params); }}
目錄結構如下:
上面我們自定義的協議,可以隨意修改,只要是客戶端和服務端兩邊能夠統一并能解析。
客戶端通過請求服務端,把要調用的類,方法和參數傳遞給服務端,服務端去通過實例化調用方法返回結果。
看完上述內容,你們掌握PHP中怎么創建一個RPC服務的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。