php如何实现rpc服务?
Admin 2021-05-18 群英技术资讯 670 次浏览
这篇文章主要给大家介绍关于php实现rpc的操作,本文有具体代码和调用过程,具有一定的借鉴价值,感兴趣的朋友可以参考学习,下面我们就一起来看看具体操作吧。
RPC全称为Remote Procedure Call,翻译过来为"远程过程调用"。主要应用于不同的系统之间的远程通信和相互调用。比如有两个系统,一个是PHP写的,一个是JAVA写的,而PHP想要调用JAVA中的某个类的某个方法,这时候就需要用到RPC了。怎么调?直接调是不可能,只能是PHP通过某种自定义协议请求JAVA的服务,JAVA解析该协议,在本地实例化类并调用方法,然后把结果返回给PHP。
这里我们用PHP的socket扩展来创建一个服务端和客户端,演示调用过程。
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));
然后分别运行上面两个脚本(注意,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实现rpc内容可以关注其他相关文章。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
除了要学习PHP的基本知识,还要了解一些代码优化上的技巧,从而帮助我们写出更加优秀的程序。我们在编写程序时,总是想要使自己的程序占用资源最小,运行速度更快,代码量更少。
PHP图像处理怎样获取索引的颜色?一些朋友可能会遇到这方面的问题,对此在下文小编向大家来讲解一下,内容详细,易于理解,希望大家阅读完这篇能有收获哦,有需要的朋友就往下看吧!
首先打开php.ini查看phpinfo()方法是否被禁用,然后把phpinfo()方法从disable_functions中删除掉,重新加载php.ini文件,再通过浏览器访问test.php即可。
这篇文章主要介绍了PHP中token的生成案例,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
在PHP中,预定义的$_POST变量用于收集来自method="post"的表单中的值,$_POST也常用于传递变量。下文有实例供大家参考,对大家了解操作过程或相关知识有一定的帮助,而且实用性强,希望这篇文章能帮助大家,下面我们一起来了解看看吧。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008