什么是RPC框架

转自
不搬原文了~
你应该知道的 RPC 原理
JAVA中几种常用的RPC框架介绍
深入浅出 RPC - 浅出篇
深入浅出 RPC - 深入篇

rpc框架解释

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

首先了解什么叫RPC,为什么要RPC,RPC是指远程过程调用,也就是说两台服务器A,B,一个应用部署在A服务器上,想要调用B服务器上应用提供的函数/方法,由于不在一个内存空间,不能直接调用,需要通过网络来表达调用的语义和传达调用的数据。比如说,一个方法可能是这样定义的:
Employee getEmployeeByName(String fullName)那么:

  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)是业务层返回后,又经过一系列步骤,如加密等,又回到传输层。

### 什么是RPC框架 远程过程调用(Remote Procedure Call, RPC)是一种允许程序执行位于不同地址空间中的子程序的过程,而无需程序员显式编码细节[^1]。通过这种方式,RPC使得客户端能够像调用本地函数一样调用服务器端的方法。 ### RPC框架的工作原理 RPC框架的主要目标在于屏蔽远程调用和本地调用之间的差异以及隐藏底层网络通信的复杂性,从而使开发人员可以更加关注于应用程序本身的业务逻辑而不是传输层的技术细节[^4]。具体来说: - **请求发送**:当客户端发起一次远程调用时,它实际上是在调用自己的存根(stub),这个存根负责序列化参数并将它们打包成消息形式。 - **网络传输**:接着,该消息会被传递给网络层并通过某种协议(如HTTP/HTTPS、TCP/IP等)发送至服务端。 - **解码处理**:到达目的地之后,服务端接收到的消息由骨架(skeleton)解析并反序列化回原始数据结构,随后真正执行对应的服务方法。 - **响应返回**:一旦完成操作,结果会再次被封装并通过相同的路径传回到客户端,在那里再经历一轮反序列化的流程最终呈现给用户。 ```java // 客户端代码示例 public interface HelloService { String sayHello(String name); } // 使用代理模式创建远程接口实例 HelloService helloService = RpcFramework.getProxy(HelloService.class); // 调用就像调用了本地方法一样简单直观 String response = helloService.sayHello("World"); System.out.println(response); // 输出:"Hello World" ``` ### 应用场景 RPC广泛应用于构建分布式系统和服务间通讯中,尤其是在采用微服务体系架构的企业级应用里扮演着至关重要的角色。以下是几个典型的应用案例: - 微服务之间高效的数据交换; - 实现跨平台间的无缝协作; - 支持异步任务调度与事件驱动编程模型; - 提供统一的服务治理机制,比如负载均衡、熔断降级等功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值