RPC 是什么

RPC 全称:Remote Procedure Call ,中文叫远程过程调用

一句话理解:

像调用本地函数一样,直接调用另一台服务器上的方法 / 函数,不用关心网络请求、协议、数据传输细节。


1. 核心作用

解决分布式系统服务之间的调用问题:

  • 单体项目:所有代码在一台机器,方法直接本地调用;
  • 微服务 / 分布式:用户服务、订单服务、支付服务部署在不同服务器,需要跨机器通信,RPC 就是干这个的。

2. 核心特点

  1. 透明调用调用远程方法 和 调用本地方法写法几乎一致,屏蔽网络底层。
  2. 高性能 相比 HTTP 接口(JSON + 文本、头信息多),RPC 一般用二进制序列化 、长连接、自定义协议,速度更快、开销更小
  3. 跨语言 / 跨服务支持不同开发语言写的服务互相调用。

3. 简单调用流程

  1. 客户端(调用方)发起本地方法调用;
  2. RPC 框架自动封装请求数据、序列化、通过网络发给服务端;
  3. 服务端接收、反序列化、执行目标方法;
  4. 结果原路返回,客户端拿到返回值。

4. RPC 和 HTTP 区别(最常考)

表格

维度 RPC HTTP(RESTful)
协议 自定义 TCP 协议(如 Dubbo、gRPC) 标准 HTTP1.1/2/3
数据格式 二进制(Protobuf、Hessian) JSON/XML 文本
性能 高、延迟低、适合内部服务 一般,适合对外接口
使用场景 微服务内部服务互调 前后端交互、第三方对外接口
可读性 强,调试方便

5. 主流常见 RPC 框架

  1. gRPC:谷歌开源,跨语言,Protobuf 序列化,云原生常用;
  2. Dubbo:阿里开源,Java 微服务经典 RPC 框架;
  3. Spring Cloud Alibaba Dubbo:国内电商、金融系统常用;
  4. Thrift:Facebook 开源,跨语言高性能。

6. 通俗举例

  • 本地调用:你在自己家做饭,直接拿柜子里的锅;
  • RPC 调用:你打电话给隔壁邻居,让邻居帮你拿一口锅送过来,你只需要喊一句(调用方法),不用管走路、敲门、传递过程
相关推荐
北京耐用通信5 分钟前
全域适配工业场景耐达讯自动化Modbus TCP 转 PROFIBUS 网关轻松实现以太网与现场总线互通
网络·人工智能·网络协议·自动化·信息与通信
在角落发呆39 分钟前
Linux转发配置:解锁网络互联的核心密码
linux·运维·网络
YMWM_3 小时前
UDP协议详解:从原理到Python实践
网络·网络协议·udp
pengyi8710153 小时前
共享 IP 与独享 IP 怎么选?被封后升级方案避坑
网络·网络协议·tcp/ip
YuanDaima20483 小时前
Linux 进阶运维与 AI 环境实战:进程管理、网络排错与 GPU 监控
linux·运维·服务器·网络·人工智能
凯勒姆5 小时前
网工网络设备原理及配置
网络·智能路由器
上海云盾-小余5 小时前
网站恶意爬虫拦截策略:智能识别与封禁实操方案
网络·爬虫·安全·web安全
xhbh6665 小时前
网关端口映射和路由器端口转发有什么区别?配置要点全解析
运维·服务器·网络·智能路由器·端口映射·映射·无痕网关
半壶清水6 小时前
用P4 Tutorial、BMv2 和 Mininet‌解析网络第一集------模拟环境搭建
运维·服务器·网络·网络协议·tcp/ip
高翔·权衡之境6 小时前
主题10:实时性——硬实时与软实时
服务器·网络·驱动开发·信息与通信·智能硬件