RPC 简介

devtools/2025/1/19 3:39:14/

RPCRemote Procedure Call,远程过程调用)是一种通过网络请求执行远程服务器上的代码的技术,使得开发者可以调用远程系统中的函数,就像调用本地函数一样。它隐藏了底层网络通信的细节,简化了分布式系统的开发。


RPC 的工作原理

  1. 客户端调用本地代理(Stub)

    • 客户端调用一个本地函数。
    • 本地代理负责将函数调用转换为网络请求。
  2. 序列化请求

    • 调用的参数和函数信息被打包(序列化)成网络数据包。
  3. 发送请求

    • 数据包通过网络传输到服务器。
  4. 服务器处理

    • 服务器的代理(Stub)接收到请求,反序列化为本地调用。
    • 调用相应的函数并返回结果。
  5. 返回结果

    • 返回值通过相同的流程(序列化、传输、反序列化)回到客户端。

常见的 RPC 框架

1. gRPC
  • 开发者:Google。
  • 特点
    • 使用 Protocol Buffers(protobuf)作为数据交换格式。
    • 支持多种编程语言(如 Python、Java、Go)。
    • 高效的二进制序列化格式。
  • 应用场景
    • 微服务架构、实时通信。
2. Thrift
  • 开发者:Apache。
  • 特点
    • 支持多语言代码生成。
    • 提供灵活的传输和序列化协议。
  • 应用场景
    • 跨语言通信。
3. JSON-RPC / XML-RPC
  • 特点
    • 轻量级,使用 JSON 或 XML 格式传输数据。
  • 应用场景
    • 简单的远程调用场景。
4. Dubbo
  • 开发者:阿里巴巴。
  • 特点
    • 专注于 Java 服务之间的 RPC 调用。
    • 支持服务发现和治理。
  • 应用场景
    • 分布式系统。

RPC 的优势

  1. 透明性:调用远程函数与本地函数无异,屏蔽底层网络细节。
  2. 高效性:支持二进制协议(如 gRPC)以提高性能。
  3. 跨语言支持:许多 RPC 框架支持多种编程语言。

RPC 的挑战

  1. 网络问题:调用可能因网络问题而失败。
  2. 调试复杂性:排查远程调用失败的原因可能较复杂。
  3. 序列化/反序列化开销:需要额外的计算和带宽。

RPC 与其他技术的对比

  • 与 REST
    • RPC 更注重函数调用,REST 是以资源为中心。
    • RPC 通常使用二进制协议,REST 使用 JSON 或 XML。
  • 与消息队列
    • RPC 是同步调用,消息队列一般是异步通信。

示例(使用 gRPC 的简单例子)

定义服务(.proto 文件):
syntax = "proto3";service Greeter {rpc SayHello (HelloRequest) returns (HelloReply);
}message HelloRequest {string name = 1;
}message HelloReply {string message = 1;
}
生成代码并实现服务(Python 示例):
import grpc
from concurrent import futures
import greeter_pb2
import greeter_pb2_grpcclass GreeterService(greeter_pb2_grpc.GreeterServicer):def SayHello(self, request, context):return greeter_pb2.HelloReply(message=f"Hello, {request.name}!")server = grpc.server(futures.ThreadPoolExecutor(max_workers=10))
greeter_pb2_grpc.add_GreeterServicer_to_server(GreeterService(), server)
server.add_insecure_port('[::]:50051')
server.start()
server.wait_for_termination()
客户端调用:
import grpc
import greeter_pb2
import greeter_pb2_grpcchannel = grpc.insecure_channel('localhost:50051')
stub = greeter_pb2_grpc.GreeterStub(channel)
response = stub.SayHello(greeter_pb2.HelloRequest(name="World"))
print(response.message)

RPC 是现代分布式系统的重要基础设施之一,适用于需要高效、透明调用的场景。


http://www.ppmy.cn/devtools/151731.html

相关文章

C++学习记录

本文章建立在已学C语言的基础上 第一阶段 生成随机数函数&#xff1a;rand()。rand()%100指的是生成0~99的随机数。这样生成的随机数每次都是一样顺序出现的&#xff0c;为了防止这个问题出现&#xff0c;我们可以使用随机数种子&#xff0c;如下代码 #include<iostream&…

使用 Golang 编译 Linux 可运行文件

Golang&#xff08;或 Go&#xff09;是一种开源编程语言&#xff0c;因其简单、高效、并发编程支持而备受欢迎。本文将详细介绍如何使用 Golang 编译生成可以在 Linux 上运行的可执行文件。 一、安装 Golang 1.1 下载 Golang 从 Golang 官方网站下载适合你操作系统的安装包…

【STM32-学习笔记-7-】USART串口通信

文章目录 USART串口通信Ⅰ、硬件电路Ⅱ、常见的电平标准Ⅲ、串口参数及时序Ⅳ、STM32的USART简介数据帧起始位侦测数据采样波特率发生器 Ⅴ、USART函数介绍Ⅵ、USART_InitTypeDef结构体参数1、USART_BaudRate2、USART_WordLength3、USART_StopBits4、USART_Parity5、USART_Mode…

多态(4)

大家好&#xff0c;今天我们来讲讲向下转型这个知识点&#xff0c;这个知识点并没有向上转型用得那么频繁&#xff0c;但是也需要了解一下。 2.4.2向下转型 当一个子类对象经过向上转型之后当成父类方法使用,再无法调用子类的属性和方法。但有时候可能需要调用子类的属性和方…

PyTorch 中的 Dropout 解析

文章目录 一、Dropout 的核心作用数值示例&#xff1a;置零与缩放**训练阶段****推理阶段** 二、Dropout 的最佳使用位置与具体实例解析1. 放在全连接层后2. 卷积层后的使用考量3. BatchNorm 层与 Dropout 的关系4. Transformer 中的 Dropout 应用 三、如何确定 Dropout 的位置…

MinerU:高效智能PDF文档解析工具完全指南

引言 MinerU是一款开源的智能文档解析工具&#xff0c;专注于将PDF等文档高效转换为Markdown和JSON等结构化格式。在当前大语言模型(LLM)蓬勃发展的时代&#xff0c;高质量的结构化数据对于训练和微调LLM至关重要。MinerU通过其强大的智能文档解析能力&#xff0c;不仅可以为L…

Visual Studio环境搭建Qgis二次开发环境

QGIS&#xff08;Quantum GIS&#xff09;是一款开源的地理信息系统软件&#xff0c;支持二次开发以满足特定的地理信息处理需求。二次开发通常涉及到使用QGIS提供的API和SDK来创建自定义插件或独立应用程序。以下是关于如何搭建QGIS二次开发环境的一些关键步骤和注意事项。 1…

sqlite3.OperationalError: database is locked python-BaseException错误解决

报错有2种&#xff1a; sqlite3.OperationalError: attempt to write a readonly databasesqlite3.OperationalError: database is locked python-BaseException 原因及解决方案&#xff1a; 1、被占用 由于SQLite只支持单线程。SQLite数据库在同一时间只能由一个连接执行写…