RPC核心概念理解

介绍
本文主要介绍 RPC 是什么, 为什么要使用 RPC,使用 RPC 需要解决问题及 RPC 使用实例

RPC 是什么
RPC(Remote Procedure Call)远程过程调用协议,一种通过网络从远程计算机上请求服务,而不需要了解底层网络技术的协议。RPC 它假定某些协议的存在,例如 TPC/UDP 等,为通信程序之间携带信息数据。在 OSI 网络七层模型中,RPC 跨越了传输层和应用层,RPC 使得开发,包括网络分布式多程序在内的应用程序更加容易。

简单一点说:就是向远程服务器发送请求,做业务处理或任务计算等 (即程序),就是想要把调用远程服务器中方法的过程和像调用本地方法一样简单。

为什么要使用 RPC
当我们无法在一个进程内,甚至通过本第地调用的方式满足我们的需求时,比如我们的通讯系统,甚至不同的组织间的通讯,由于计算能力需要横向扩展,需要在多台机器组成的集群上部署应用,这才能是我们进行远程的通讯;又或者说电商系统,我们不可能靠着本地调用就能满足我们的需求,例如提交订单的处理方法,库存处理方法等在本地调用,在肯定是不行的,这是用户发起相应的请求由我们远程服务器去做业务处理和计算的。所以 RPC 就显得如此重要了。

使用 RPC 需要解决问题
这里我们来看,我们想象一下当我们在远程调用 (也就是使用 RPC) 的过程中,我们需要执行的函数或者方法在远程机器上,例如我们要调用远程计算机的 add 方法,下面就会有这几个问题:

  1. Call ID 映射。 我们要怎么告诉远程计算机我们需要调用的是 add 方法,而不是 reduce 方法,mult 方法,divi 方法等,在本地调用中,函数体是直接通过函数指针来指定的,当我们调用本地 add 方法时,编译器会自动给我们调用到它相应的函数指针,而在远程调用中,使用指针明显是不行的,因为两个进程的地址不同。所以,在 RPC 中,所有函数都必须有一个唯一的 ID,这个 ID 在所有进程中都是唯一确定的,客户端在调用时都必须附加上这个 ID,然后我们还需要在客户端和服务端分别维护一个 {函数 <—–> Call ID } 的对应表,两者的表不一定需要完全相同,但相同的函数对应的 Call ID 必须相同,当客户端需要进行远程调用时,它就查一下这个表,找出相应的 Call ID,然后把它传给服务端,服务端也通过查表,来确定客户端需要调用的函数,然后执行相应函数的代码。
  2. 序列化及反序列化。客户端怎么把参数值传给远程的函数呢?在本地调用中,我们只需要把参数压到栈里,然后让函数自己去栈里读就行。但是在远程过程调用时,客户端跟服务端是不同的进程,不能通过内存来传递参数。甚至有时候客户端和服务端使用的都不是同一种语言(比如服务端用 C++,客户端用 Java 或者 Go)。这时候就需要客户端把参数先转成一个字节流,传给服务端后,再把字节流转成自己能读取的格式。这个过程叫序列化和反序列化。同理,从服务端返回的值也需要序列化反序列化的过程

整个流程如下:
在这里插入图片描述
3. 网络传输。远程调用往往用在网络上,客户端和服务端是通过网络连接的。所有的数据都需要通过网络传输,因此就需要有一个网络传输层。网络传输层需要把 Call ID 和序列化后的参数字节流传给服务端,然后再把序列化后的调用结果传回客户端。只要能完成这两者的,都可以作为传输层使用。因此,它所使用的协议其实是不限的,能完成传输就行。尽管大部分 RPC 框架都使用 TCP 协议,但其实 UDP 也可以,而 gRPC 干脆就用了 HTTP2。Java 的 Netty 也属于这层的东西。

解决了上面三个问题,我们就能实现 RPC 了,现在我们再看看,客户端和服务端在 RPC 中的工作是什么:

客户端 (client):

1. 将这个调用映射为Call ID。这里假设用最简单的字符串当Call ID的方法,例如这里可以:http://127.0.0.1:8080/add?a=1&b=1,即直接使用add作为path,又或者http://127.0.0.1:8080/?method=add&a=1
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值