艾巴生活网

您现在的位置是:主页>科技 >内容

科技

什么是RPC(为什么需要RPC)

2023-10-20 16:47:16科技帅气的蚂蚁
RPC是什么?RPC远程过程调用的全名——远程过程调用。在学校学编程,我们写一个函数,在本地调用。但在互联网公司,服务是部署在不同服务器

什么是RPC(为什么需要RPC)

RPC是什么?

RPC远程过程调用的全名——远程过程调用。在学校学编程,我们写一个函数,在本地调用。但在互联网公司,服务是部署在不同服务器上的分布式系统。如何调用它们?

简单来说,RPC就是解决远程调用服务问题的技术,让调用者像调用本地服务一样方便透明。

下图显示了客户端调用远程服务的过程:

1)客户端发起服务调用请求。

2)客户端stub可以理解为代理,它将调用方法和参数封装成一定的格式,通过服务提供的地址发起网络请求。

3)消息通过网络传输到服务器。

4)服务器存根接受来自套接字的消息

5)服务器存根将消息解包,并告诉服务器要调用哪个服务以及参数是什么。

6)结果被返回到服务器存根

7)服务器存根将结果打包并提供给套接字。

8)socket通过网络传输消息。

9)客户端slub从套接字获取消息

10)客户端存根将消息解包,并将结果返回给客户端。

RPC框架封装了步骤2到9。

为什么需要RPC?

1、首先要明确:RPC可以用HTTP协议实现,使用HTTP是基于TCP的应用最广泛的RPC。然而,互联网公司往往使用自己的私有协议,如鹅厂的JCE协议。当私有协议不通用时,为什么要使用私有协议呢?与HTTP协议相比,RPC采用二进制字节码传输,更高效、更安全。

2、现在,业界提倡微服务,而目前服务之间有两种通信方式,RPC就是其中之一。RPC可以保证不同服务之间的相互调用。甚至跨语言、跨平台都不是问题,更容易构建分布式系统。

3、RPC框架将具有服务降级和流量控制功能,以确保服务的高可用性。