rpc的通信流程

rpc能实现调用远程方法就跟调用本地(同一个项目中的方法)一样,发起调用请求的那一方叫做服务调用方 ,被调用的一方叫做服务提供方

接下来就和大家分享一下调用过程的流程和细节。

传输协议

既然是远程调用那肯定就需要通过网络来传输数据,并且 rpc 常用于业务系统之间的数据交互,需要保证其可靠性,所以 rpc 一般默认采用 TCP 来传输。事实上,我们常用的 HTTP 协议也是建立在 TCP 之上的。

封装一个可用的协议

选择了合适的传输层协议之后,我们需要基于此建立一个我们自己的通用协议,和http一样需要封装自己的应用层协议。

序列化

网络传输的数据必须是二进制数据,但调用方请求的出入参数都是对象。对象是肯定没法直接在网络中传输的,需要提前把它转成可传输的二进制,并且要求转换算法是可逆的,这个过程我们一般叫做"序列化"。

压缩

如果我们觉得序列化后的字节数组体积比较大,我们还可以对他进行压缩,压缩后的字节数组体积更小,能在传输的过程中更加节省带宽和内存。

上图就是整个rpc的调用过程。

那上述几个流程就组成了一个完整的 rpc 吗?

还不太算一个完整的rpc,因为我们一般都是面向对象编程,所以我们要使用面向对象的思想,使用封装,让调用者不去关注底层细节,只需要关注业务就可以,所以最终还需要通过动态代理将这些API封装并进行功能增强,这就成为了一个rpc。

相关推荐
Irissgwe22 分钟前
五、应用层协议HTTP
linux·网络·网络协议·http·状态码·url
自动跟随3 小时前
UWB自动跟随技术全栈解析:从定位算法到“位控一体化“
java·网络·人工智能
长和信泰光伏储能3 小时前
远离电网的底气:离网光伏系统核心原理与搭建要点
网络
天天进步20153 小时前
Tunnelto 源码解析 #8:多路复用机制:StreamId、ActiveStreams 与并发请求生命周期
网络
数智化管理手记4 小时前
标准作业越推越虚?重塑认知、规避误区,破解精益落地形式主义
大数据·网络·精益工程
路由侠内网穿透4 小时前
本地部署开源自托管服务器监控系统哪吒监控并实现外部访问
运维·服务器·网络协议
上海云盾-小余5 小时前
SSL 证书部署误区避坑:加密部署与防劫持落地教程
网络协议·iphone·ssl
国科安芯5 小时前
ASP7A84AS——航天级低噪声高PSRR线性稳压器
网络·单片机·嵌入式硬件·架构·安全性测试
以太浮标6 小时前
华为eNSP模拟器综合实验之- 路由黑洞场景解析及实验
运维·网络·网络协议·网络安全·华为·智能路由器·信息与通信
北京耐用通信6 小时前
耐达讯自动化 Modbus RTU转Profibus 网关产品技术说明书
人工智能·物联网·网络协议·自动化·信息与通信