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 ...
随机推荐
- 一次峰回路转的getshell
扫目录发现 http://www.xxx.test.cn/bak/以及/bak/upload.jsp
- Arthas 开源一周年,GitHub Star 16 K ,我们一直在坚持什么?
缘起 最近看到一个很流行的标题,<开源XX年,star XXX,我是如何坚持的>.看到这样的标题,忽然发觉 Arthas 从 2018 年 9 月开源以来,刚好一年了,正好在这个秋高气爽的 ...
- Mybatis基于SqlSession实现CRUD
之前我们讲的基于XML还是接口注解配置都是使用接口实现CRUD,本文我们将要讲解通过splsession来实现CRUD,这种方法比较灵活. 基本配置 <!-- spring和MyBatis完美整 ...
- CDN技术之--集群服务与负载均衡
Web集群是由多个同时运行同一个web应用的服务器组成,在外界看来就像一个服务器一样,这多台服务器共同来为客户提供更高性能的服务.集群更标准的定义是:一组相互独立的服务器在网络中表现为单一的系统,并以 ...
- I/O 优化
数字的读入优化: /* I/O * Au: GG */ #include <cstdio> #include <cstdlib> #include <cmath> ...
- Effective Objective-C 2.0
Effective Objective-C 2.0:编写高质量iOS与OS X代码的52个有效方法 作者:Matt Galloway(英) 译者:爱飞翔 出版社:机械工业出版社 出版年:2014-01 ...
- JS - 计算两个数组的交集、差集、并集、补集(多种实现方式)
方法一:最普遍的做法 使用 ES5 语法来实现虽然会麻烦些,但兼容性最好,不用考虑浏览器 JavaScript 版本.也不用引入其他第三方库. 1,直接使用 filter.concat 来计算 var ...
- ansible 远程执行时提示 command not found 问题
问题 最近在学习 ansible ,在使用普通用户远程执行 ip a 命令是发现提示错误:/bin/sh: ip: command not found. 原因 command not found 命令 ...
- The Preliminary Contest for ICPC Asia Shenyang 2019 H
H. Texas hold'em Poker 思路:根据每个牌型分等级,然后排序按照等级优先,最大值次之,次大值,最后比较剩下值的和. #include<bits/stdc++.h> us ...
- Eureka 系列(03)Spring Cloud 自动装配原理
Eureka 系列(03)Spring Cloud 自动装配原理 [TOC] 0. Spring Cloud 系列目录 - Eureka 篇 本文主要是分析 Spring Cloud 是如何整合 Eu ...