当前位置: 首页 > news >正文

rpc的原理

RPC(Remote Procedure Call,远程过程调用)是一种编程模型,它允许开发者像调用本地函数一样调用位于不同进程或者不同机器上的函数或服务。这种抽象简化了分布式系统的开发,使得开发人员无需关注底层网络通信细节,只需关注接口定义和服务逻辑。在 RPC 中,客户端通过指定接口名和参数发起请求,服务端接收到请求后执行相应功能并返回结果。

接口定义

  • 使用接口定义语言(IDL,Interface Definition Language)定义客户端和服务器之间的通信接口。IDL文件描述了可调用的远程方法及其参数和返回值类型。
  • 根据IDL文件,生成客户端和服务器的代码框架(stub和skeleton)。

客户端存根(Client Stub)

  • 客户端存根是一个本地代理,负责将客户端对远程方法的调用转换为网络消息。
  • 它封装了参数,打包成请求消息,并将消息发送到服务器。
  • 接收从服务器返回的响应消息,并解包响应数据,将结果返回给客户端。

服务器存根(Server Stub)

  • 服务器存根是服务器端的一个代理,负责接收客户端的请求消息。
  • 它解包请求消息,调用实际的服务实现,并将结果封装成响应消息。
  • 将响应消息发送回客户端。

通信模块

  • 客户端和服务器之间的通信通过底层的通信模块进行,如TCP/IP、HTTP、gRPC等。
  • 通信模块负责消息的传输、路由、重试、超时处理等工作。

序列化和反序列化

  • 为了在网络上传输数据,参数和返回值需要进行序列化(将数据结构转换为字节流)和反序列化(将字节流转换回数据结构)。
  • 常用的序列化协议包括JSON、XML、Protobuf等。

调用过程

  • 当客户端调用远程方法时,客户端存根将方法名、参数等信息打包成请求消息并发送到服务器。
  • 服务器接收到请求消息后,服务器存根解包消息,调用实际的服务实现,得到结果后打包成响应消息发送回客户端。
  • 客户端接收到响应消息后,客户端存根解包消息,将结果返回给客户端应用程序。

gRPC 是 Google 开发的一种高性能、开源和通用的 RPC 框架,基于 HTTP/2 协议设计,采用 Protocol Buffers(protobuf)作为接口描述语言(IDL)来定义服务接口和消息结构。gRPC 提供了一种高效、可靠且跨语言的方法来定义服务和实现 RPC。

gRPC 的特点和优势包括:

  • 支持多种开发语言,实现了不同语言之间的互操作性。
  • 使用 Protocol Buffers 进行序列化和反序列化,具有良好的性能和高效的带宽利用率。
  • 基于 HTTP/2 实现,支持多路复用、流式传输和双向流。
  • 客户端和服务端都可以发起流式 RPC,适用于大数据或实时流处理场景。
  • 内置认证和鉴权机制,可以通过 TLS 或其他认证插件保证通信安全。

通过 gRPC,开发者可以方便地创建、部署和调用微服务,大大降低了构建分布式系统时的工作复杂度。

最后给大家推荐一个LinuxC/C++高级架构系统教程的学习资源与课程,可以帮助你有方向、更细致地学习C/C++后端开发,具体内容请见 https://xxetb.xetslk.com/s/1o04uB

http://www.lryc.cn/news/416662.html

相关文章:

  • 【无线通信发展史-第二篇】,带你走进查利·奥古斯丁·库仑的世界,了解(库伦定律)-(扭秤实验)-(如何测量出静电力常量)
  • CAPL使用结构体的方式组装一条DoIP车辆声明消息(方法2)
  • 基于Matlab的车牌识别系统设计与实现
  • 使用Cisco进行模拟RIP路由协议配置
  • 段页式存储-系统架构师(三十七)
  • 通过指令深入了解Linux
  • IP探针双端源码
  • 高中数学学科知识与教学能力
  • Flink 实时数仓(七)【DWS 层搭建(一)流量域汇总表创建】
  • Python和PyCharm的安装激活及Python新手入门指南
  • Apache Flink窗口机制解析:滚动窗口与滑动窗口的比较与应用
  • 为什么《程序员修炼之道》评分能到 9.1?
  • 接口自动化测试框架中动态参数接口,加密接口,签名接口你们是怎么处理的?
  • 【hadoop】常用命令
  • 时间同步--- ntp与ptp
  • CSDN 僵尸粉 机器人
  • 【Material-UI】File Upload Button 组件详解
  • 计算机组成原理 - 中央处理器
  • C++笔试练习笔记【5】:最小花费爬楼梯(有题目链接) 初识动态规划
  • 数据结构----------贪心算法
  • C++初学(11)
  • Vba选择cad中不同类型图元(Select Case True语句和like用法)
  • Kafka基本讲解
  • thinkphp6项目初始化配置方案二次修正版本
  • XXE靶机教学
  • 干货 | 2024步入数字化转型深水区,云原生业务稳定性如何保障(免费下载)
  • for(char c:s),std::vector<int> numbers 和std::int numbers[],.size()和.sizeof()区别
  • 桌面云备份可以删除吗?安不安全
  • 【爬虫实战】利用代理爬取电商数据
  • python如何统计列表中元素出现的次数