什么是 RPC 框架

什么是 RPC 框架rpc 框架解释谁能用通俗的语言解释一下什么是 RPC 框架 远程过程调用协议 RPC RemoteProced 首先了解什么叫 RPC 为什么要 RPC RPC 是指远程过程调用 也就是说两台服务器 A B 一个应用部署在 A 服务器上 想要调用 B 服务器上应用提供的函数 方法 由于不在一个内存空间 不能直接调用 需要通过网络来表达调用的语义和传达调用的数据 比如

rpc框架解释

谁能用通俗的语言解释一下什么是 RPC 框架? – 远程过程调用协议RPC(Remote Procedure Call Protocol)

  1. 首先,要解决通讯的问题,主要是通过在客户端和服务器之间建立TCP连接,远程过程调用的所有交换的数据都在这个连接里传输。连接可以是按需连接,调用结束后就断掉,也可以是长连接,多个远程过程调用共享同一个连接。
  2. 第二,要解决寻址的问题,也就是说,A服务器上的应用怎么告诉底层的RPC框架,如何连接到B服务器(如主机或IP地址)以及特定的端口,方法的名称名称是什么,这样才能完成调用。比如基于Web服务协议栈的RPC,就要提供一个endpoint
    URI,或者是从UDDI服务上查找。如果是RMI调用的话,还需要一个RMI Registry来注册服务的地址。
  3. 第三,当A服务器上的应用发起远程过程调用时,方法的参数需要通过底层的网络协议如TCP传递到B服务器,由于网络协议是基于二进制的,内存中的参数的值要序列化成二进制的形式,也就是序列化(Serialize)或编组(marshal),通过寻址和传输将序列化的二进制发送给B服务器。
  4. 第四,B服务器收到请求后,需要对参数进行反序列化(序列化的逆操作),恢复为内存中的表达方式,然后找到对应的方法(寻址的一部分)进行本地调用,然后得到返回值。
  5. 第五,返回值还要发送回服务器A上的应用,也要经过序列化的方式发送,服务器A接到后,再反序列化,恢复为内存中的表达方式,交给A服务器上的应用

    这里写图片描述
    为什么RPC呢?就是无法在一个进程内,甚至一个计算机内通过本地调用的方式完成的需求,比如比如不同的系统间的通讯,甚至不同的组织间的通讯。由于计算能力需要横向扩展,需要在多台机器组成的集群上部署应用,RPC的协议有很多,比如最早的CORBA,Java RMI,Web Service的RPC风格,Hessian,Thrift,甚至Rest API。关于Netty而Netty框架不局限于RPC,更多的是作为一种网络协议的实现框架,比如HTTP,由于RPC需要高效的网络通信,就可能选择以Netty作为基础。除了网络通信,RPC还需要有比较高效的序列化框架,以及一种寻址方式。如果是带会话(状态)的RPC调用,还需要有会话和状态保持的功能。大体上来说,Netty就是提供一种事件驱动的,责任链式(也可以说是流水线)的网络协议实现方式。网络协议包含很多层次,很多部分组成,如传输层协议,编码解码,压缩解压,身份认证,加密解密,请求的处理逻辑,怎么能够更好的复用,扩展,业界通用的方法就是责任链,一个请求应答网络交互通常包含两条链,一条链(Upstream)是从传输层,经过一系列步骤,如身份认证,解密,日志,流控,最后到达业务层,一条链(DownStream)是业务层返回后,又经过一系列步骤,如加密等,又回到传输层。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/206486.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月19日 下午3:35
下一篇 2026年3月19日 下午3:35


相关推荐

  • pycharm django环境搭建_挣钱项目

    pycharm django环境搭建_挣钱项目2021/2/2pycharm打开的界面有更新。1.找到setting先找到自定义(customize)然后再点击Allsettings进入界面2.下载django的解释器先点击python的解释器(pythoninterpreter)然后选择一个需要配置django解释器的python项目,也可以新创一个。选择好python项目之后,可以从package栏查看下载了哪些python包。然后,点击pip,查找django就可以下载django的python包。THAT‘

    2022年8月27日
    6
  • websrorm2021.5激活码[在线序列号][通俗易懂]

    websrorm2021.5激活码[在线序列号],https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月18日
    44
  • 手把手在 macOS 安装并使用 OpenClaw

    手把手在 macOS 安装并使用 OpenClaw

    2026年3月13日
    3
  • maven配置阿里云镜像的两种方式

    maven配置阿里云镜像的两种方式maven 配置阿里云镜像的两种方式配置方式第一种方式 settings xml 文件 在 mirrors 节点下加入一个新的 mirror 节点 配置阿里镜像地址 完整配置如下 mirrors mirror id alimaven id name aliyunmaven name url http maven aliyun com nexus content url mirror mirrors

    2026年3月18日
    2
  • linux ad7705驱动程序,tm7705_51单机片驱动[通俗易懂]

    这是tm7705_51单机片驱动,为AD7705的驱动程序,keil开放环境开发。基于51单片机。软件说明tm770551驱动已在STC单片机51驱动AD77057705电路图TL431管脚图软件功能这是我自己做的AD7705采集模块,我毕业设计做的linux系统下面的前置采集,做的是AD7705的驱动的编写,下面是我编写的AD7705的51单片机的程序,直接调试完成了,你们可以直接…

    2022年4月12日
    94
  • 【读书】领导力的5个层次-职位

    【读书】领导力的5个层次-职位领导力的 5 个层次 职位 你已经踏上了培养领导力的征程一 前言传统意义上的领导力征途都是从领导职位开始的 职位是领导力提升之旅的起点 也是领导力建立与发展的最低层次与牢固基石 真正的影响为必须以此为基础 二 职位的积极方面 1 领导职位被赋予某些人往往是因为他们具有领导潜质大多数时候人们能够获得某个

    2026年3月19日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号