RPC实现原理,怎么跟调用本地一样

news2025/1/15 2:21:39

回答1

要让⽹络通信细节对使⽤者透明,我们需要对通信细节进⾏封装,我们先看下⼀个 RPC 调⽤的流程涉及到哪些通
信细节:
1. 服务消费⽅( client )调⽤以本地调⽤⽅式调⽤服务;
2. client stub 接收到调⽤后负责将⽅法、参数等组装成能够进⾏⽹络传输的消息体;
3. client stub 找到服务地址,并将消息发送到服务端;
4. server stub 收到消息后进⾏解码;
5. server stub 根据解码结果调⽤本地的服务;
6. 本地服务执⾏并将结果返回给 server stub
7. server stub 将返回结果打包成消息并发送⾄消费⽅;
8. client stub 接收到消息,并进⾏解码;
9. 服务消费⽅得到最终结果。

chatGpt

RPC(Remote Procedure Call,远程过程调用)是一种允许程序调用位于不同机器上的函数或方法,就像调用本地函数一样透明和简单的通信协议。RPC的实现原理依赖于以下几个核心要素:

1. 客户端和服务端的角色

  • 客户端:发起调用请求的一方,它像调用本地方法一样发起RPC请求,但该请求实际上会通过网络发送到远程服务。
  • 服务端:提供实际服务的一方,接收客户端请求,处理并返回结果。

2. 透明性:如何像本地调用一样

RPC的一个关键目标是让远程调用看起来和本地调用没有差别。为了实现这种透明性,RPC通常采用了以下技术:

2.1. 代理与存根(Stub)
  • 客户端存根(Stub):客户端通过调用存根就像调用本地方法一样。这些存根充当客户端与远程服务之间的代理。存根负责将方法参数打包,并通过网络发送到远程服务端,然后返回结果给客户端。
  • 服务端存根(Skeleton):服务端存根接收远程调用,将请求解包并调用实际的服务方法,然后将返回结果发送给客户端。
2.2. 序列化和反序列化
  • 当客户端调用远程服务时,它首先将调用的参数和方法信息序列化(例如,转化成二进制流)。序列化后,数据可以通过网络传输到远程服务端。
  • 服务端接收到请求后,需要反序列化请求数据,将其还原为可调用的本地方法及参数,之后执行方法,处理结果,并将结果序列化发送回客户端。
  • 常见的序列化方式包括 JSON、Protocol Buffers、Thrift 等。
2.3. 网络通信
  • 客户端和服务端之间的通信通常是通过 TCP、HTTP 或其他协议来实现的。RPC框架提供了网络层的通信管理,确保请求能够正确发送到目标机器并返回。

3. RPC的工作流程

  1. 客户端调用存根:客户端调用存根中的方法。此时,客户端并不知晓该方法是远程方法,它只是像本地方法一样进行调用。

  2. 序列化和网络传输:客户端存根负责将方法的参数序列化为适合网络传输的格式,并通过网络发送到服务端。该请求通常包括方法名、参数类型和参数值等信息。

  3. 服务端接收请求:服务端通过网络接收到请求后,服务端的存根将请求反序列化,还原成原始的调用信息,然后找到相应的方法并调用。

  4. 方法执行和返回结果:服务端方法执行完毕后,将结果序列化并发送回客户端。

  5. 客户端接收并解包结果:客户端存根接收到响应数据后,反序列化并将结果返回给客户端,客户端就像调用本地方法一样,直接使用返回结果。

4. 透明性如何实现

要实现透明性,RPC需要确保以下几点:

  • 接口一致性:客户端调用的接口与服务端实现的接口一致。客户端只需关心接口定义,而不需要了解底层的远程调用机制。
  • 自动化的序列化和反序列化:RPC框架负责在客户端和服务端之间进行数据的自动序列化与反序列化。客户端不需要手动处理这些操作。
  • 网络通信封装:网络通信和协议的细节被隐藏,客户端和服务端的通信是由框架自动管理的,客户端只需要关注方法调用。

5. 举例说明:一个简单的RPC调用流程

以一个常见的 RPC 框架(例如 gRPC)为例,解释整个过程:

  • 客户端调用:客户端调用某个远程服务的方法 sayHello("Alice")

     

    java

    // 客户端代码 HelloRequest request = HelloRequest.newBuilder().setName("Alice").build(); HelloResponse response = blockingStub.sayHello(request); System.out.println(response.getMessage());
  • 序列化请求sayHello("Alice") 方法会被序列化成请求消息并通过网络发送。

  • 服务端处理:服务端接收到请求后,解包消息,调用实际的 sayHello 方法,然后序列化结果返回。

  • 客户端接收并解包结果:客户端接收到响应数据,反序列化并获取返回的消息,像调用本地方法一样使用它。

6. RPC框架的关键特性

不同的RPC框架(如gRPC、Apache Thrift、Dubbo等)提供了不同的实现和功能,但它们通常包含以下基本功能:

  • 自动生成代码:大多数RPC框架都提供IDL(接口定义语言)和工具,通过描述服务接口生成客户端和服务端的代码(存根和服务端存根)。
  • 支持多种传输协议:如 HTTP、TCP、WebSocket 等。
  • 错误处理机制:当远程调用发生错误时,RPC框架会捕获异常并将其转化为本地异常,客户端可以像处理本地异常一样处理远程异常。

总结

RPC的核心目标是让远程调用尽可能像本地调用一样透明和简单。它通过客户端存根和服务端存根、序列化和反序列化、网络通信等技术,将复杂的远程调用过程封装起来,使得开发人员在编写代码时不需要关心网络、序列化等细节。通过这些机制,RPC能够实现远程服务的调用,仿佛调用本地方法一样。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2276751.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

FPGA的 基本结构(Xilinx 公司Virtex-II 系列FPGA )

以Xilinx 公司Virtex-II 系列FPGA 为例,其基本结构由下图所示。它是主要由两大部分组成:可编程输入/输出(Programmable I/Os)部分和内部可配置(Configurable Logic)部分。 可编程输入/输出(I/Os…

【Elasticsearch】批量操作:优化性能

🧑 博主简介:CSDN博客专家,历代文学网(PC端可以访问:https://literature.sinhy.com/#/?__c=1000,移动端可微信小程序搜索“历代文学”)总架构师,15年工作经验,精通Java编程,高并发设计,Springboot和微服务,熟悉Linux,ESXI虚拟化以及云原生Docker和K8s,热衷于探…

C++、Haskell 和 Rust 三种语言实现 Faster Suffix Sort 算法的比较

对 C、Haskell 和 Rust 三种语言实现 Faster Suffix Sort 算法的比较: 1. 编程效率 C: 优点:C 提供了丰富的标准库,如 std::sort,可以方便地结合自定义比较函数对后缀数组进行排序。使用 Lambda 表达式可以简洁地实现…

校园跑腿小程序---轮播图,导航栏开发

hello hello~ ,这里是 code袁~💖💖 ,欢迎大家点赞🥳🥳关注💥💥收藏🌹🌹🌹 🦁作者简介:一名喜欢分享和记录学习的在校大学生…

uniapp实现H5页面内容居中与两边留白,打造类似微信公众号阅读体验

在 UniApp 中,由于需要兼容多端应用,我们通常使用 rpx 作为尺寸单位。然而,在某些情况下,如需要实现内容居中且两边留白时,直接使用 rpx 可能会带来一些限制。这时,我们可以考虑使用 px 或 rem 等单位&…

【Uniapp-Vue3】pages.json页面路由globalStyle的属性

项目的全局配置在pages.json中。 一、导航栏设置 二、下拉刷新设置 下拉就可以看到设置的样式 三、上拉触底 这个页面中,向下滑动页面到底部就会输出“到底了” 现在将触底距离设置为500 走到半路就会输出“到底了”

Type-C双屏显示器方案

在数字化时代,高效的信息处理和视觉体验已成为我们日常生活和工作的关键需求。随着科技的进步,一款结合了便携性和高效视觉输出的设备——双屏便携屏,逐渐崭露头角,成为追求高效工作和娱乐体验人群的新宠。本文将深入探讨双屏便携…

Linux下部署Redis(本地部署超详细)

非docker 1、下载Redis 历史版本: http://download.redis.io/releases 我的: http://download.redis.io/releases/redis-7.0.5.tar.gz 2.安装教程 1.Redis是基于c语言编写的需要安装依赖,需要安装gcc yum install gcc-c 2.查看gcc版…

使用 Multer 上传图片到阿里云 OSS

文件上传到哪里更好? 上传到服务器本地 上传到服务器本地,这种方法在现今商业项目中,几乎已经见不到了。因为服务器带宽,磁盘 IO 都是非常有限的。将文件上传和读取放在自己服务器上,并不是明智的选择。 上传到云储存…

UE5 打包项目

UE5 打包项目 flyfish 通过 “文件”->“打开项目”,然后在弹出的对话框中选择项目文件(通常是以.uproject为后缀的文件) 选择目标平台: 在 UE5 主界面中,找到 “平台”(Platforms)。根据…

自然语言转 SQL:通过 One API 将 llama3 模型部署在 Bytebase SQL 编辑器

使用 Open AI 兼容的 API,可以在 Bytebase SQL 编辑器中使用自然语言查询数据库。 出于数据安全的考虑,私有部署大语言模型是一个较好的选择 – 本文选择功能强大的开源模型 llama3。 由于 OpenAI 默认阻止出站流量,为了简化网络配置&#…

杭州铭师堂的云原生升级实践

作者:升学e网通研发部基建团队 公司介绍 杭州铭师堂,是一个致力于为人的全面发展而服务的在线教育品牌。杭州铭师堂秉持“用互联网改变教育,让中国人都有好书读”的使命,致力于用“互联网教育”的科技手段让更多的孩子都能享有优…

STM32 FreeRTOS移植

目录 FreeRTOS源码结构介绍 获取源码 1、 官网下载 2、 Github下载 源码结构介绍 源码整体结构 FreeRTOS文件夹结构 Source文件夹结构如下 portable文件夹结构 RVDS文件夹 MemMang文件夹 FreeRTOS在基于寄存器项目中移植步骤 目录添加源码文件 工程添加源码文件 …

可以进行重复测量的方差分析的AI agent

可以进行重复测量的方差分析的AI agent 前几天做了机器学习的AI agent,把一个糖尿病机器学习模型采用API的形式接入到LLM模型中,结合LLM的智能性和机器学习模型的准确性,利用两者的有点,有可以避免两者的缺点,是一条合…

OpenCV实现Kuwahara滤波

Kuwahara滤波是一种非线性的平滑滤波技术,其基本原理在于通过计算图像模板中邻域内的均值和方差,选择图像灰度值较为均匀的区域的均值来替代模板中心像素的灰度值。以下是Kuwahara滤波的详细原理说明: 一、基本思想 Kuwahara滤波的基本思想…

[文献精汇]使用 LSTM Networks 的均值回归交易策略

Backtrader 策略实例 [Backtrader]实例:均线策略[Backtrader] 实例:MACD策略[Backtrader] 实例:KDJ 策略[Backtrader] 实例:RSI 与 EMA 结合[Backtrader] 实例:SMA自定义数据源[Backtrader] 实例:海龟策略[Backtrader] 实例:网格交易[Backtrader] 实例: 配对交[Backtrader] 机…

IDEA Maven构建时报错:无效的目标发行版17

报错分析 报错原因:Maven 构建时,Java 版本配置不匹配 我安装的JDK版本是1.8,但由于种种原因,Maven构建时指定了 Java 17 作为目标发行版,从而导致错误 解决方案 首先,java -version,查看环…

计算机网络 (39)TCP的运输连接管理

前言 TCP(传输控制协议)是一种面向连接的、可靠的传输协议,它在计算机网络中扮演着至关重要的角色。TCP的运输连接管理涉及连接建立、数据传送和连接释放三个阶段。 一、TCP的连接建立 TCP的连接建立采用三次握手机制,其过程如下&…

Navicat Premium 16.0.90 for Mac 安装与free使用

步骤 0.下载 通过网盘分享的文件:Navicat Premium 16.0.90 链接: https://pan.baidu.com/s/12O22rXa9MiBPKKTGMELNIg 提取码: yyds 1.打开下好的 dmg 文件 (这个界面不要关闭) 2.将Navicat Premium 拖动至 Applications 这时出现 点击取消。 3.点开…

小创新模型!6种2024算法优化BiTCN-SVM单变量输入单步预测,MATLAB机器学习预测全家桶再更新...

截止到本期MATLAB机器学习预测全家桶,一共发了26篇关于机器学习预测代码的文章。算上这一篇,一共27篇!参考文章如下: 1.五花八门的机器学习预测?一篇搞定不行吗? 2.机器学习预测全家桶,多步预测…