rpc的通信流程

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

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

传输协议

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

封装一个可用的协议

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

序列化

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

压缩

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

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

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

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

相关推荐

  1. 【Spark源码分析】SparkRPC通信二-初稿

    2024-04-03 07:24:02       39 阅读
  2. 【Spark源码分析】SparkRPC通信一-初稿

    2024-04-03 07:24:02       30 阅读
  3. Kafka中RPC:Server端代码流程简单概述

    2024-04-03 07:24:02       9 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-04-03 07:24:02       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-03 07:24:02       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-03 07:24:02       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-03 07:24:02       20 阅读

热门阅读

  1. Odoo中管理网站的站点地图

    2024-04-03 07:24:02       16 阅读
  2. Kong基于QPS、IP限流

    2024-04-03 07:24:02       19 阅读
  3. Python学习(1):装饰器

    2024-04-03 07:24:02       14 阅读
  4. SpringBoot -- Profiles

    2024-04-03 07:24:02       17 阅读
  5. Vue项目动态加载图片

    2024-04-03 07:24:02       17 阅读
  6. 若依框架:登陆(后端)

    2024-04-03 07:24:02       15 阅读
  7. 494. 目标和(力扣LeetCode)

    2024-04-03 07:24:02       15 阅读
  8. wpf Ellipse

    2024-04-03 07:24:02       13 阅读
  9. 小参林八股

    2024-04-03 07:24:02       10 阅读
  10. notepad++ 快捷键使用

    2024-04-03 07:24:02       15 阅读
  11. vim脚本的语言语法

    2024-04-03 07:24:02       11 阅读