700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > RPC(Remote Procedure Call)远程过程调用

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

时间:2019-06-27 19:19:44

相关推荐

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、HTTP2、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实现参考:/codingexperience/p/5930752.html

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

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。