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找到服务器地址,网络传输

服务端收到反序列化

调用本地方法返回结果

服务端序列化传给客户端

客户端反序列化给调用者

面试相关

相关推荐
H Journey26 分钟前
网络编程:Boost.Asio实现跨平台的TCP服务器
服务器·网络·tcp/ip·boost.asio
H Journey7 小时前
网络编程-创建SOCKET套接字
网络·socket
一袋米扛几楼987 小时前
【高级网络】虚拟化与云计算 (Virtualization & Cloud) 深度解析
网络·网络工程
wdfk_prog10 小时前
正常关闭虚拟机时,不要点“关机”,而要点“关闭客户机”
linux·c语言·网络·ide·vscode
bzmK1DTbd11 小时前
Servlet 4.0新特性:HTTP/2与异步处理支持
网络协议·http·servlet
@insist12312 小时前
信息安全工程师-网络安全审计产品图谱与实战应用全解
网络·安全·软考·信息安全工程师·软件水平考试
梵豪12 小时前
太原市政府办公网络规划与设计
网络
近墨者缺黑12 小时前
关于Modbus RTU和TCP协议的一些简要笔记
网络协议
yantaohk12 小时前
一键下载微信视频号所有页面视频,支持批量下载、加密视频解密、自动去重
网络·微信·音视频
其实防守也摸鱼13 小时前
无线网络安全--实验 规避WLAN验证之发现隐藏的SSID
java·开发语言·网络·安全·web安全·智能路由器·无线网络安全