1 Star 0 Fork 552

Leader / CS-Wiki

forked from 小牛肉 / cs-wiki 
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
1-什么是RPC及其原理.md 4.69 KB
一键复制 编辑 原始数据 按行查看 历史
小牛肉 提交于 2021-07-11 21:36 . 🥽 更新目录结构

📞 什么是 RPC 及其原理


1. 什么是 RPC

RPC(Remote Procedure Call)远程过程调用,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议。比如两个不同的服务 A、B 部署在两台不同的机器上,那么服务 A 如果想要调用服务 B 中的某个方法该怎么办呢?使用 HTTP 请求当然可以,但是可能会比较麻烦。 RPC 的出现就是为了让你调用远程方法像调用本地方法一样简单

2. RPC 原理

我们可以将整个 RPC的 核心功能看作是下面 6 个部分实现的:

  • 客户端(服务消费端 Client) :调用远程方法的一端。
  • 服务端(服务提供端 Server) :提供远程方法的一端。
  • 客户端 Stub(桩) : 这其实就是一代理类。代理类主要做的事情很简单,就是把你调用方法、类、方法参数等信息传递到服务端。
  • 服务端 Stub(桩) :这个桩就不是代理类了。这里的服务端 Stub 实际指的就是接收到客户端执行方法的请求后,去指定对应的方法然后返回结果给客户端的类。
  • 网络传输 : 网络传输就是把你调用的方法的信息比如说参数这些东西传输到服务端,然后服务端执行完之后再把返回结果通过网络传输给你传输回来。网络传输的实现方式有很多种比如最基本的 Socket 或者性能以及封装更加优秀的 Netty(推荐)。

核心原理如下

  1. 服务消费方(Client)以本地调用方式调用服务;
  2. Client Stub 接收到调用后,负责将方法、参数等组装成能够进行网络传输的消息体 RpcRequest(需要进行序列化);
  3. Client Stub 找到服务地址,并将消息发送到服务端;
  4. Server Stub 收到消息体后,反序列化为 Java 对象 RpcRequest
  5. Server Stub 根据 RpcRequest 中的类、方法、方法参数等信息调用本地的服务/方法;
  6. 本地服务执行并将结果返回给 Server Stub;
  7. Server Stub 得到方法执行结果并将组装成能够进行网络传输的消息体 RpcResponse(需要进行序列化)发送至消费方;
  8. Client Stub 接收到消息体,并反序列化为 Java 对象 RpcResponse 。这样,服务消费方得到了最终结果。

时序图如下:

3. 常见的 RPC 框架

我们这里说的 RPC 框架指的就是可以让客户端直接调用服务端方法,就像调用本地方法一样简单的框架:

  • RMI(JDK自带): JDK 自带的 RPC,有很多局限性,不推荐使用。
  • Dubbo: Dubbo 是阿里巴巴公司开源的一个高性能优秀的服务框架,使得应用可通过高性能的 RPC 实现服务的输出和输入功能,可以和 Spring 框架无缝集成。目前 Dubbo 已经成为 Spring Cloud Alibaba 中的官方组件。
  • gRPC :gRPC是可以在任何环境中运行的现代开源高性能 RPC 框架。它可以通过可插拔的支持来有效地连接数据中心内和跨数据中心的服务,以实现负载平衡,跟踪,运行状况检查和身份验证。它也适用于分布式计算的最后一英里,以将设备,移动应用程序和浏览器连接到后端服务。
  • Hessian: Hessian 是一个轻量级的 remotingonhttp 工具,使用简单的方法提供了 RMI 的功能。 相比WebService,Hessian更简单、快捷。采用的是二进制 RPC 协议,因为采用的是二进制协议,所以它很适合于发送二进制数据。
  • Thrift: Apache Thrift 是Facebook开源的跨语言的 RPC 通信框架,目前已经捐献给Apache基金会管理,由于其跨语言特性和出色的性能,在很多互联网公司得到应用,有能力的公司甚至会基于 thrift 研发一套分布式服务框架,增加诸如服务注册、服务发现等功能。

4. RPC 与 HTTP

🚨 RPC 与 HTTP 并非一个层级的概念:

  • RPC 只是一种概念、一种设计,就是为了解决 不同服务之间的调用问题, 它一般会包含有 传输协议序列化协议 这两个。

  • HTTP 是一种协议,RPC 框架可以使用 HTTP 协议作为传输协议或者直接使用 TCP 作为传输协议,使用不同的协议一般也是为了适应不同的场景。

📚 References

Java
1
https://gitee.com/mmbuy_admin/CS-Wiki.git
git@gitee.com:mmbuy_admin/CS-Wiki.git
mmbuy_admin
CS-Wiki
CS-Wiki
master

搜索帮助