what`s rpc

在计算机术语中,RPC 指的是 Remote Procedure Call(远程过程调用) 。它是一种进程间通信(IPC)机制,允许程序在不同的计算机或不同的进程上调用函数或方法,就像调用本地函数一样,而不需要关心底层的网络通信细节。

我给你分几个关键点解释:


1️⃣ 基本概念

  • 远程:调用的函数可能在另一台机器上或另一进程中。
  • 过程调用:程序调用一个函数,获取结果。
  • 透明性:调用方感觉像调用本地函数一样,但实际上网络或跨进程在背后完成了通信。

2️⃣ 工作原理

RPC 的流程一般如下:

  1. 客户端调用本地的"代理函数"(stub)。
  2. 代理函数打包参数(序列化)成消息,通过网络发送到远程服务器。
  3. 服务器端接收消息,反序列化得到参数。
  4. 服务器调用实际函数,执行逻辑,得到结果。
  5. 服务器序列化返回值,发回客户端。
  6. 客户端反序列化返回值,得到结果,调用完成。

⚡ 总结:RPC 把"跨网络调用函数"的复杂过程封装起来,让开发者感觉像调用本地函数。


3️⃣ RPC 的典型应用

  • 分布式系统:微服务之间的通信。
  • 数据库远程访问。
  • 云服务调用(例如 AWS Lambda 调用外部服务)。
  • 各种客户端-服务器架构。

4️⃣ 常见的 RPC 框架 / 协议

  • gRPC(Google 开发,支持多语言)
  • Thrift(Apache 项目)
  • JSON-RPC / XML-RPC(基于文本的轻量级 RPC)
  • Dubbo(阿里巴巴开源的 RPC 框架,Java 生态)

简单理解:RPC 就是让"远程的函数"调用像本地函数一样简单,底层通过网络、序列化、反序列化、代理函数来实现。

相关推荐
苍煜5 小时前
Docker容器网络详解+端口映射原理(系列第二篇:实战核心)
网络·docker·容器
初願致夕霞6 小时前
基于系统调用的Linux网络编程——UDP与TCP
linux·网络·c++·tcp/ip·udp
数智化精益手记局8 小时前
什么是设备维护管理?设备维护管理包含哪些内容?
大数据·网络·人工智能·安全·信息可视化
salipopl10 小时前
FPGA中AXI-FIFO主机接口的自定义实现与versal读写工程分析
网络·fpga开发
会周易的程序员12 小时前
aiDgeScanner 工业设备网络扫描与管理工具
网络·c++·物联网·架构·electron·node.js·iot
CableTech_SQH12 小时前
F5G 全光网,赋能智慧校园数字化建设
大数据·网络·5g·运维开发·信息与通信
hellojackjiang201112 小时前
socket长连接在手游场景下的技术实践
网络·网络协议·tcp/ip·架构·网络编程
精益数智小屋13 小时前
设备维护方案核心功能拆解:一套好的设备维护方案如何解决设备突发故障
大数据·运维·网络·数据库·人工智能·面试·自动化
其实防守也摸鱼13 小时前
VS code怎么使用 Conda 安装预编译包
开发语言·网络·c++·vscode·安全·web安全·conda