thinkphp rpc
RPC(Remote Procedure Call Protocol)——远程过程调用协议,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议。RPC协议假定某些传输协议的存在,如TCP或UDP,为通信程序之间携带信息数据。在OSI网络通信模型中,RPC跨越了传输层和应用层。RPC使得开发包括网络分布式多程序在内的应用程序更加容易。
RPC采用客户机/服务器模式。请求程序就是一个客户机,而服务提供程序就是一个服务器。首先,客户机调用进程发送一个有进程参数的调用信息到服务进程,然后等待应答信息。在服务器端,进程保持睡眠状态直到调用信息的到达为止。当一个调用信息到达,服务器获得进程参数,计算结果,发送答复信息,然后等待下一个调用信息,最后,客户端调用进程接收答复信息,获得进程结果,然后调用执行继续进行。
ThinkPHP支持广泛的RPC协议,包括PHPRPC、HPRose、JsonRPC以及Yar。
PHPRPC支持
PHPRPC 是一个轻型的、安全的、跨网际的、跨语言的、跨平台的、跨环境的、跨域的、支持复杂对象传输的、支持引用参数传递的、支持内容输出重定向的、支持分级错误处理的、支持会话的、面向服务的高性能远程过程调用协议。目前该协议的最新版本为 3.0。详细的资料可以参考phprpc官网( http://www.phprpc.org/zh_CN/)
ThinkPHP提供了对PHPRpc的服务端和客户端调用的支持(客户端是跨平台跨语言的,可以支持任何语言的调用)。
服务器端的实现非常简单,你只需要把控制器继承Think\Controller\RpcController类即可。
例如:
namespace Home\Controller;use Think\Controller\RpcController;class ServerController extends RpcController{public function test1(){return 'test1';}public function test2(){return 'test2';}private function test3(){return 'test3';}protected function test4(){return 'test3';}}
这样,ServerController控制器就变成了一个PHPRpc服务端,请求地址为:
http://serverName/index.php/Home/Server
rpc客户端可以调用test1和test2方法。方法的返回值可以支持数组等PHPRpc支持的格式。
注意:如果设置了不同的URL模式的话,服务器端请求地址需要相应调整。
可以使用allowMethodList属性设置允许访问的方法列表,例如:
namespace Home\Controller;use Think\Controller\RpcController;class ServerController extends RpcController{protected $allowMethodList = array('test1','test2');public function test1(){return 'test1';}public function test2(){return 'test2';}public function test3(){return 'test3';}}
上面的设置表示只允许test1和test2方法被rpc客户端调用。
你可以采用多个控制器进行不同的PHPRpc Server端用于不同的需要。
如果要在ThinkPHP里面进行客户端调用,可以使用下面的代码:
namespace Home\Controller;use Think\Controller;class IndexController extends Controller {public function index(){Vendor('phpRPC.phprpc_client');$client = new \PHPRPC_Client('http://serverName/index.php/Home/Server');// 或者采用//$client = new \PHPRPC_Client();//$client->useService('http://serverName/index.php/Home/Server');$result = $client->test1();}}
其中test1就是服务器端定义的方法。其他使用和PHP的方法调用一致。
Hprose支持
Hprose (High Performance Remote Object Service Engine) 是一个MIT开源许可的新型轻量级跨语言跨平台的面向对象的高性能远程动态通讯中间件。它支持众多语言,例如nodeJs, C++, .NET, Java, Delphi, Objective-C, ActionScript, JavaScript, ASP, PHP, Python, Ruby, Perl 等语言,通过 Hprose 可以在这些语言之间实现方便且高效的互通。
你可以认为它是 PHPRPC 的商业版本,但是它跟 PHPRPC 完全不同,hprose 协议是全新设计的,比 PHPRPC 更加高效,实现也完全是全部从头开始的,比 PHPRPC 更加易用。更多信息可以参考(http://www.hprose.com/)
ThinkPHP同样也提供了对Hprose的服务端和客户端调用的支持。
服务器端的使用和PHPRPC的区别只是把控制器继承Think\Controller\HproseController类即可,其他用法基本一致,例如:
namespace Home\Controller;use Think\Controller\HproseController;class ServerController extends HproseController{public function test1(){return 'test1';}public function test2(){return 'test2';}}
我们可以进行一些hprose服务器端的参数设置,包括debug、crossDomain、P3P和get,设置方法如下:
namespace Home\Controller;use Think\Controller\HproseController;class ServerController extends HproseController{protected $crossDomain = true;protected $P3P = true;protected $get = true;protected $debug = true;public function test1(){return 'test1';}public function test2(){return 'test2';}}
采用ThinkPHP的Hprose的客户端调用示例如下:
namespace Home\Controller;use Think\Controller;class IndexController extends Controller {public function index(){vendor('Hprose.HproseHttpClient');$client = new \HproseHttpClient('http://serverName/index.php/Home/Server');// 或者采用//$client = new \HproseHttpClient();//$client->useService('http://serverName/index.php/Home/Server');$result = $client->test1();}}
JsonRPC支持
json-rpc是基于json的跨语言远程调用协议,比xml-rpc、webservice等基于文本的协议传输数据格小;相对hessian、java-rpc等二进制协议便于调试、实现、扩展,是非常优秀的一种远程调用协议。
ThinkPHP3.2提供了对JsonRPC的服务器端和客户端调用支持,服务器端实现示例:
namespace Home\Controller;use Think\Controller\JsonRpcController;class ServerController extends JsonRpcController {public function index(){return 'Hello, JsonRPC!';}// 支持参数传入public function test($name=''){return "Hello, {$name}!";}}
所有的public方法都可以用于远程调用,客户端调用方式如下:
namespace Home\Controller;use Think\Controller;class IndexController extends Controller {public function index(){vendor('jsonRPC.jsonRPCClient');$client = new \jsonRPCClient('http://serverName/index.php/Home/Server');$result = $client->index();var_dump($result); // 结果:Hello, JsonRPC!$result = $client->test('ThinkPHP');var_dump($result); // 结果:Hello, ThinkPHP!}}
Yar支持
Yar (yet another RPC framework) 是一个PHP扩展的RPC框架, 和现有的RPC框架(xml-rpc, soap)不同, 这是一个轻量级的框架, 支持多种打包协议(msgpack, json, php), 并且最重要的一个特点是, 它是可并行化的。
要使用Yar支持首先需要安装Yar扩展,扩展下载地址: http://pecl.php.net/package/yar
Yar说明文档: http://hk2.php.net/manual/zh/book.yar.php
安装好扩展后,使用ThinkPHP就可以开发服务器端,示例如下:
namespace Home\Controller;use Think\Controller\YarController;class ServerController extends YarController {public function index(){return 'Hello, Yar RPC!';}public function hello($name=''){return 'Hello, {$name}!';}}
Yar除了并行,还有一个亮点,通过GET方式可以查看到接口列表及注释。
客户端调用示例如下:
namespace Home\Controller;use Think\Controller;class IndexController extends Controller {public function index(){$client = new \Yar_client('http://serverName/index.php/Home/Server');$result = $client->index();var_dump($result); // 结果:Hello, Yar!}}
thinkphp rpc的更多相关文章
- 关于 thinkPHP Deprecated: preg_replace(): The /e modifier is deprecated, use preg_replace_callback
Deprecated: preg_replace(): The /e modifier is deprecated, use preg_replace_callback 关于thinkPHP rpc调 ...
- workerman-chat(PHP开发的基于Websocket协议的聊天室框架)(thinkphp也是支持socket聊天的)
workerman-chat(PHP开发的基于Websocket协议的聊天室框架)(thinkphp也是支持socket聊天的) 一.总结 1.下面链接里面还有一个来聊的php聊天室源码可以学习 2. ...
- 2017-07-26 ThinkPHP简单使用
ThinkPHP是什么?有何优点? ThinkPHP 是一个免费开源的,快速.简单的面向对象的 轻量级PHP开发框架,ThinkPHP为WEB应用开发提供了强有力的支持,这些支持包括: * MVC支持 ...
- 利用Metasploit 打入ThinkPHP内网...
出品|MS08067实验室(www.ms08067.com) 本文作者:dch(Ms08067实验室 SRSP TEAM小组成员) 一.利用Metasploit进行攻击的流程图 Metasploi ...
- 从RPC开始(一)
这是一篇关于纯C++RPC框架的文章.所以,我们先看看,我们有什么? 1.一个什么都能干的C++.(前提是,你什么都干了) 2.原始的Socket接口,还是C API.还得自己去二次封装... 3.C ...
- 制作类似ThinkPHP框架中的PATHINFO模式功能
一.PATHINFO功能简述 搞PHP的都知道ThinkPHP是一个免费开源的轻量级PHP框架,虽说轻量但它的功能却很强大.这也是我接触学习的第一个框架.TP框架中的URL默认模式即是PathInfo ...
- RPC 使用中的一些注意点
最近线上碰到一点小问题,分析其原因发现是出在对 RPC 使用上的一些细节掌握不够清晰导致.很多时候我们做业务开发会把 RPC 当作黑盒机制来使用,但若不对黑盒的工作原理有个基本掌握,也容易犯一些误用的 ...
- 谈谈如何使用Netty开发实现高性能的RPC服务器
RPC(Remote Procedure Call Protocol)远程过程调用协议,它是一种通过网络,从远程计算机程序上请求服务,而不必了解底层网络技术的协议.说的再直白一点,就是客户端在不必知道 ...
- 游戏编程系列[1]--游戏编程中RPC协议的使用[3]--体验
运行环境,客户端一般编译为.Net 3.5 Unity兼容,服务端因为用了一些库,所以一般为4.0 或往上.同一份代码,建立拥有2个项目.客户端引用: WindNet.Client服务端引用: OpL ...
随机推荐
- SQL Server 2014 安装说明
SQL Server 2014 安装说明 本节内容将说明如何通过安装向导在 Windows Server 2012 R2 上安装 SQL Server 2014. 先从 MSDN 网站上下载安装了 S ...
- linux find grep
find是文件查找, grep是文件内容查找. 1. find find path expression -options[-print -exec -ok] -print 将结果输出到标准输出: - ...
- JavaScript 六种继承方式
title: JS的六种继承方式 date: 2017-06-27 05:55:49 tags: JS categories: 学习 --- 继承是面向对象编程中又一非常重要的概念,JavaScrip ...
- 大碗宽面Beta迭代阶段第十二周会议记录
本周一晚上我们在熟悉的宿舍楼一楼大厅进行了本周的小组会议. 对于上周的任务,前端的同学修改统一了导航栏和footer,在课程评价界面中添加了“添加评论”功能,其中含有,是否修改过该课程的单选框,评论, ...
- vue2 的 过渡(动画)效果
1.在过渡 效果的使用中 ,key属性需要注意 : 有相同父元素的子元素必须有独特的 key.重复的 key 会造成渲染错误. 参考官方说明: https://cn.vuejs.org/ ...
- 51nod1340地铁环线
经典题. 经典差分约束模型. 但是 显然这个总长是有上下界的. 直接二分总长,判断有没有负环 如果没有负环好办,有负环就不知道怎么偏了. 因为没有单调性! (如果所有没有单调性的函数图像,都知道往哪里 ...
- [CSP-S模拟测试ex]题解
爆零了.少特判见祖宗.还好这场不计入总分. 考场上什么都没想.感觉考试状态又回到了两个月前. A.Antipalindrome 手玩样例,不难发现题目中要求的合法串的充要条件是:对于任意$i \in ...
- PAT_A1131#Subway Map
Source: PAT A1131 Subway Map (30 分) Description: In the big cities, the subway systems always look s ...
- 【react】---react项目中如何使用iconfont
一.路由配置 export const TabBarRouter = [ { path:"/home", icon:"\ue628", name:"首 ...
- 马士兵对话京东T6阿里P7(薪水):月薪5万,他为何要离职?
马士兵大佬你知道吗? 你竟然不知道?你怎么可能不知道!你不知道是不可能的! 记得自己的第一行Java代码,你的Hello World是跟着谁学的吗?我的就是马士兵老师! 马士兵是唯一一个在当时讲课是让 ...