RPC(Remote Procedure Call)远程过程调用

所谓的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

【忘记了原链接,如有侵权,联系我删除】

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值