RPC核心原理:组件与调用流程

RPC核心原理:组件与调用流程

RPC(Remote Procedure Call,远程过程调用)的核心价值是屏蔽网络通信的底层复杂性 ,让开发者调用远程服务的方法时,体验与调用本地方法完全一致。其实现可拆解为5个核心组件1个完整调用流程

一、RPC的5个核心组件

1. 客户端(Consumer)

发起远程方法调用的一方,即业务代码中"像调用本地方法一样"调用远程服务的主体。

2. 服务端(Provider)

提供远程方法实现的一方,即实际执行业务逻辑的主体。

3. 客户端Stub(Client Stub)

也称为"客户端代理",是RPC框架在客户端的核心封装:

  • 接收客户端的方法调用请求(方法名、参数等);
  • 将调用信息序列化为可网络传输的二进制数据;
  • 负责服务发现(通过注册中心获取服务端地址);
  • 将序列化后的消息发送给服务端。

4. 服务端Stub(Server Stub)

RPC框架在服务端的核心封装:

  • 接收客户端发送的二进制消息;
  • 将消息反序列化为Java对象(包含方法名、参数等);
  • 根据反序列化后的信息,调用服务端本地的业务方法;
  • 将方法执行结果序列化后返回给客户端。

5. 网络传输层

负责客户端与服务端之间的二进制数据传输:

  • 底层可基于Socket实现,但主流RPC框架(如Dubbo、gRPC)通常使用Netty(高性能NIO网络框架),以提升传输效率和稳定性。

二、RPC的完整调用流程

  1. 客户端发起调用:业务代码像调用本地方法一样,调用远程服务的接口方法。
  2. 客户端Stub处理请求
    • 拦截调用请求,提取方法名、参数等信息;
    • 将信息组装为可传输的结构体,并序列化为二进制数据;
    • 通过注册中心(如Nacos、Zookeeper)获取服务端的IP和端口。
  3. 网络传输:客户端Stub通过Netty等网络框架,将序列化后的消息发送给服务端。
  4. 服务端Stub处理请求
    • 接收二进制消息,反序列化为包含方法名、参数的Java对象;
    • 根据对象信息,调用服务端本地的业务方法。
  5. 服务端返回结果
    • 服务端Stub将方法执行结果组装为结构体,并序列化为二进制数据;
    • 通过网络传输层将结果发送回客户端。
  6. 客户端获取结果
    • 客户端Stub接收二进制消息,反序列化为Java对象;
    • 将结果返回给业务代码,完成整个远程调用。

补充:为什么需要Stub?

Stub的核心作用是**"解耦业务代码与网络细节"**:

  • 对客户端而言,无需关心序列化、服务发现、网络传输等底层逻辑,只需关注业务调用;
  • 对服务端而言,无需关心网络接收、反序列化等逻辑,只需专注于业务方法的实现。

这正是RPC能让远程调用像本地调用一样简单的关键。

相关推荐
皮卡蛋炒饭.1 天前
NAT、代理服务、内网穿透与五种IO模型
网络·智能路由器
振浩微433射频芯片1 天前
工业环境下的“硬核”选择:如何科学评估国产433芯片的可靠性?
网络·人工智能·科技·单片机·物联网·学习
Ha_To1 天前
26.5.19 未授权漏洞
linux·服务器·网络
日取其半万世不竭1 天前
Docker 网络模式详解:bridge、host、overlay 和 macvlan
网络·docker·容器
有个人神神叨叨1 天前
[特殊字符] 东芝天氟地水 + 宏云智能 → 米家/HA 统一控制,智能家居整合方案 - 手残党求骂醒版
网络·智能家居
AI科技星1 天前
全域粒子质量几何曲率统一公式体系(通俗易懂版)
c语言·开发语言·网络·量子计算·agi
minji...1 天前
Linux 网络基础之传输层协议TCP(九)从内核源码的角度打通系统与网络之间的关系,套接字多态的体现
linux·运维·服务器·网络·网络协议·tcp/ip·http
yyuuuzz1 天前
独立开发者线上服务运维的几点实践经验
运维·服务器·网络·云计算·aws
想唱rap1 天前
IO多路转接Select
运维·服务器·网络·数据库·sql·tcp/ip·mysql
沪漂阿龙1 天前
Docker 面试题详解:容器、镜像、Dockerfile、网络、Volume、Compose、安全与生产实践一次讲透
网络·安全·docker