RPC相关知识

文章目录


1、RPC是什么?

RPC即远程过程调用,不同于本地调用,他调用的是远端机器的函数或方法,且不需要关心底层的实现细节,如传输协议和网络协议。对于调用者来说,和调用本地方法一样,RPC调用的是一个远端对象,调用者和被调用者是处于不同的地址空间,要想完成调用,必须实现以下几个能力:
服务发现

由于调用的是远端对象,因此需要一个进程可以定位到调用的服务器地址以及调用的具体方法,一般可以通过注册中心或者哈希查找来实现,将被调的接口注册到某个地方,比如使用CallerId和函数名作为映射,调用者通过CallerId进行调用,服务端收到调用请求后,通过CallerId查找到对应函数,再执行后续处理流程。

序列化和反序列化

调用者和被调用者处于不同的机器上,因此函数参数及其他一些Context信息需要经过网络传输才能到达服务端,网络传输的是二进制数据,因此RPC需要支持将函数参数(如基本类型int、long、map以及自定义类型等)可以序列化为网络可以传输的二进制数据,同时,也需要支持将二进制数据反序列化为程序可以处理的数据类型,是序列化的逆过程。

网络传输

网络传输协议和RPC本身没有关系,一般使用TCP进行网络传输,通过HTTP或者UDP也是可以完成RPC所需要的功能的。

如上,如果某个服务框架实现了上述这些功能,就是一个RPC框架,通过此框架便可以像调用本地方法一样来调用远端方法。

2、为什么使用RPC?

如果是一个功能比较简单的应用,可以将所有功能实现在一个服务中或者实现在多个服务中,但是部署在一个机器上,如此,接口间调用要么在同一进程内或者是本地进程间通信。随着业务的发展,服务功能持续迭代,单体应用出现性能瓶颈,因此需要考虑对服务进行拆分,根据业务功能划分为不同的模块,不同的模块部署到不同集群上,模块间进行通信完成功能。如将服务的管理域和执行域进行拆分,不仅是服务架构更合理清晰,也方便根据不同的模块划分不同的资源,保证服务的整体性能。

一个服务拆分为不同的模块,或者单体应用拆分为多个微服务时,此时便需要RPC出场了,不同模块及不同服务间都需要RPC才能完成通信。可以说RPC是分布式系统架构或者微服务架构必不可少的实现手段。

3、RPC过程

客户端调用远程方法

client stub客户端存根序列化消息

协议编码

client stub找到服务器地址,网络传输

服务端收到反序列化

调用本地方法返回结果

服务端序列化传给客户端

客户端反序列化给调用者

面试相关

相关推荐
.千余4 分钟前
【Linux】Socket编程UDP
linux·运维·服务器·开发语言·网络协议·学习·udp
AI云原生25 分钟前
远程控制软件进入协作阶段:ToDesk、向日葵、AnyDesk、RustDesk怎么选?
运维·服务器·网络·windows·docker·云原生·开源软件
小辰记事本9 小时前
从零读懂RoCEv2数据包构造:从WQE到线缆上的完整旅程
服务器·网络·网络协议·rdma
北京耐用通信10 小时前
全域适配工业场景耐达讯自动化Modbus TCP 转 PROFIBUS 网关轻松实现以太网与现场总线互通
网络·人工智能·网络协议·自动化·信息与通信
在角落发呆11 小时前
Linux转发配置:解锁网络互联的核心密码
linux·运维·网络
YMWM_13 小时前
UDP协议详解:从原理到Python实践
网络·网络协议·udp
pengyi87101513 小时前
共享 IP 与独享 IP 怎么选?被封后升级方案避坑
网络·网络协议·tcp/ip
YuanDaima204813 小时前
Linux 进阶运维与 AI 环境实战:进程管理、网络排错与 GPU 监控
linux·运维·服务器·网络·人工智能
凯勒姆15 小时前
网工网络设备原理及配置
网络·智能路由器
上海云盾-小余15 小时前
网站恶意爬虫拦截策略:智能识别与封禁实操方案
网络·爬虫·安全·web安全