RPC(Remote Procedure Call)—远程过程调用,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议。RPC协议假定某些传输协议的存在,如TCP或UDP,为通信程序之间携带信息数据。在OSI网络通信模型中,RPC跨越了传输层和应用层,RPC使得开发包括网络分布式多程序在内的应用程序更加容易。
简而言之就是 在A (client) 调用 B (server) 提供的A方法.
例如在某庞大商场系统中,你可以把整个商场拆分为N个微服务(理解为N个独立的小模块也行),例如:订单系统 ,用户管理系统
此时在订单系统要调用用户系统的方法,则为远程调用
而调用过程实现的通讯协议可以有很多,可以是http协议或者tcp协议
在一个完整的Rpc中,包含了:
1:服务端,提供Rpc服务接口的服务端,可以有多个
2:客户端,请求Rpc服务端,可以有多个,客户端也可以是服务端,服务端也可以是客户端,互相调用不同的服务
3:如何进行序列化和反序列化.
4:如何进行网络传输(选择何种网络协议)多数RPC框架选择TCP作为传输协议,也有部分选择HTTP。如gRPC使用HTTP2。不同的协议各有利弊
这就有点像我们传统使用的restful接口
RESTful是一种软件架构风格、设计风格,而不是标准,只是提供了一组设计原则和约束条件。它主要用于客户端和服务器交互类的软件。通过http协议中的POST/GET/PUT/DELETE等方法和一个可读性强的URL来提供一个http请求。而rpc则不一定通过http,更常用的是使用TCP来实现
1.restfull和rpc都是client/server模式的,都是在 Server端 把一个个函数封装成接口暴露出去
2.restful使用http协议实现,而rpc则不一定使用http,一般比较常用的是tcp, RPC 可以获得更好的性能(省去了 HTTP 报头等一系列东西),TCP更加高效,而HTTP在实际应用中更加的灵活。
3.从使用上来说:Http接口只关注服务提供方(服务端),对于客户端怎么调用,调用方式怎样并不关心;而RPC服务则需要客户端接口与服务端保持一致,服务端提供一个方法,客户端通过接口直接发起调用。
php的rpc框架主要有 phprpc,yar, thrift, gRPC, swoole, hprose,
以下简单列我本地调试用的三种方式。
1.可以基于socket来实现,参考 http://www.php20.cn/article/149
2.easyswoole框架提供的rpc组件,参考 https://github.com/easy-swoole/rpc
3.鸟叔的yar扩展,基于http以及socket,参考 http://www.laruence.com/2012/09/15/2779.html
https://www.php.cn/php-weizijiaocheng-389167.html
http://www.php20.cn/article/149
https://baijiahao.baidu.com/s?id=1617168792520937104&wfr=spider&for=pc
https://blog.csdn.net/u014590757/article/details/80233901