所谓的RPC(remote procedure call 远程过程调用)框架实际是提供了一套机制,
使得应用之间可以进行通讯,而且也遵从server/client模型。
使用的时候客户端调用server端提供的接口就像是调用本地的函数一样
最初提的RPC图示:
描述
RPC框架的组成:
一个完整的RPC框架包含了服务注册发现、负载、容错、序列化、协议编码和网络传输等组件。不同的RPC框架包含的组件可能会有所不同,但是一定都包含RPC协议相关的组件,RPC协议包括序列化、协议编码解码器和网络传输栈
RPC和HTTP区别
RPC和HTTP都是微服务之间通讯较为常见的方案,其实RPC和HTTP并不完全是同一个层次的概念
1、RPC是远程过程调用,其调用协议通常包括序列化协议和传输协议。序列化协议有基于纯文本的xml和JSON、二进制的Protobuf和Hessian。传输协议是指其底层网络传输所使用的协议,比如TCP、HTTP
2、HTTP可以是RPC传输协议的一个可选方案,比如说gRPC的网络传输协议就是HTTP(HTTP2.0),HTTP可以和RPC一样作为服务间通讯的解决方案,也可以作为RPC中通讯层的传输协议
常见的RPC框架
阿里的Dubbo、Google的gRPC、FaceBook的Thrift和Twotter的Finagle
1、Go RPC:Go语言原生支持的RPC框架调用机制,简单便捷
2、gRPC:谷歌发布的开源RPC框架,基于HTTP2.0
3、Thrift:FaceBook的开源RPC框架,主要是一个跨语言的服务开发框架,老牌的RPC协议,高性能和稳定性成为众多开源项目提供数据的方案选项。
大致组件:
- 服务端提供接口实现类及方法实现,并对注册中心注册
- 服务注册中心注册服务
- 客户端请求服务注册中心,传入相应的接口、方法、参数
简单的RPC流程:
? 1、服务端注册服务到注册中心
? 2、客户端带着接口、方法、参数以输出流的方式把数据包装到Socket中,并请求注册中心
? 3、服务端通过反射的方式创建实体类对象,并执行对应的方法
? 4、通过Socket的方式返回数据
? 5、客户端以输入流的方式来读取数据
简单RPC实现参考:https://www.cnblogs.com/codingexperience/p/5930752.html
【忘记了原链接,如有侵权,联系我删除】
|