RPC核心实现原理

目录

一、基本原理

二、详细步骤

三、额外考虑因素


RPC(Remote Procedure Call,远程过程调用)是一种计算机通信协议,也是一种用于实现分布式系统中不同节点之间进行通信和调用的技术。其实现原理主要可以分为以下几个步骤:

简单介绍就是:

步骤1:服务提供方启动时将服务注册到注册中心。

步骤2:服务消费方启动时从注册中心订阅自己需要服务的地址。

步骤3:注册中心把已经注册的服务提供者地址,返回给消费方。

步骤4:消费方根据路由规则与负载均衡策略,选择一个提供者地址进行调用。

步骤5:调用双方与监控平台建立定时发送机制,用来统计调用次数与耗时等相关数据。

一、基本原理

RPC允许程序在不同的计算机上通过网络进行函数调用,使得分布式系统中的节点可以像调用本地函数一样调用远程函数,提供了一种简单、高效的分布式通信方式。RPC的基本原理是:客户端(Client)通过调用本地的客户端代理(Proxy/Stub)来调用远程服务器(Server)上的服务。客户端代理将调用请求序列化成网络协议中的消息,并通过网络发送给服务器端。服务器端接收到消息后,解析消息,执行相应的服务,并将执行结果序列化成消息返回给客户端。客户端代理再将结果反序列化并返回给客户端,就像调用本地函数一样。

二、详细步骤

  1. 客户端代理:客户端通过调用本地的客户端代理来触发远程函数的调用。客户端代理负责将函数参数进行封装,这通常涉及到将参数序列化为适合网络传输的格式(如JSON、XML、Protobuf等)。
  2. 传输:封装后的请求通过网络传输给服务端。传输是RPC中非常重要的一环,它负责将封装后的请求从客户端传输到服务端,并将服务端的响应传输回客户端。传输可以基于不同的协议和传输层实现,如TCP、UDP、HTTP等。其中,HTTP协议因其跨平台、跨语言的特点,以及较好的可扩展性和安全性,被广泛应用于RPC的实现中。
  3. 服务端代理:在服务端,接收到客户端发送的请求后,服务端代理(Skeleton/Server Stub)负责将请求解析并调用本地的函数进行处理。服务端代理将处理结果封装成响应,这同样涉及到序列化,以便通过网络发送回客户端。
  4. 执行:服务端执行被调用的函数,并将结果返回给服务端代理。
  5. 响应:服务端代理将处理结果封装成响应后,通过传输层发送回客户端。客户端代理接收到服务端的响应后,负责将响应解析(即反序列化)并返回给调用方。

三、额外考虑因素

除了上述的基本原理和步骤外,RPC的实现还需要考虑一些额外的问题:

  1. 数据编码和解码:即将函数参数和返回值进行序列化和反序列化,这是为了在不同的语言和平台之间实现数据的互通。
  2. 服务注册与发现:客户端需要知道服务端的地址才能发起请求。这可以通过中心化的服务注册中心来实现,客户端可以从注册中心获取到可用的服务地址。
  3. 负载均衡:在分布式系统中,可能会有多个服务端实例提供相同的服务。为了优化性能和资源利用,需要引入负载均衡机制,将请求均匀地分发到不同的服务实例上。
  4. 容错机制:由于网络通信的不确定性,RPC调用可能会失败。因此,需要引入重试、超时、熔断等机制来处理这些失败情况,保证系统的可靠性和稳定性。

综上所述,RPC的实现原理是一个复杂而精细的过程,它涉及到网络通信、数据序列化与反序列化、服务注册与发现、负载均衡以及容错机制等多个方面。通过这些机制和技术手段的共同作用,RPC实现了分布式系统中不同节点之间的高效、可靠的函数调用。

参考:

手写RPC框架第三章《RPC中间件》 | 小傅哥 bugstack 虫洞栈

itstack-demo-rpc: RPC是一种远程调用的通信协议,例如dubbo、thrift等,我们在互联网高并发应用开发时候都会使用到类似的服务。本专题主要通过三个章节简单的实现rpc基础功能,来深入学习rpc是如何交互通信的;手写类似dubbo的rpc框架第一章《自定义配置xml》 手写类似dubbo的rpc框架第二章《netty通信》 手写类似dubbo的rpc框架第三章《rpc框架》在这些章节中我们会学习到以下知识点; 1、自定义xml的配置和解析 2、netty 3、JDKProxy 4、客户端通过注册中心,发布和获取链接者 5、服务的通过JDKProxy,进行调用方法

https://gitcode.net/KnowledgePlanet/SpringBootStarter?page=1

一文详解RPC框架核心原理与手写实战

相关推荐
小蜗牛慢慢爬行1 小时前
有关异步场景的 10 大 Spring Boot 面试问题
java·开发语言·网络·spring boot·后端·spring·面试
MARIN_shen1 小时前
Marin说PCB之POC电路layout设计仿真案例---06
网络·单片机·嵌入式硬件·硬件工程·pcb工艺
打鱼又晒网2 小时前
linux网络套接字 | 深度解析守护进程 | 实现tcp服务守护进程化
linux·网络协议·计算机网络·tcp
m0_748240022 小时前
Chromium 中chrome.webRequest扩展接口定义c++
网络·c++·chrome
終不似少年遊*2 小时前
华为云计算HCIE笔记05
网络·华为云·云计算·学习笔记·hcie·认证·hcs
蜜獾云2 小时前
docker 安装雷池WAF防火墙 守护Web服务器
linux·运维·服务器·网络·网络安全·docker·容器
小林熬夜学编程3 小时前
【Linux网络编程】第十四弹---构建功能丰富的HTTP服务器:从状态码处理到服务函数扩展
linux·运维·服务器·c语言·网络·c++·http
Hacker_Fuchen3 小时前
天融信网络架构安全实践
网络·安全·架构
上海运维Q先生3 小时前
面试题整理15----K8s常见的网络插件有哪些
运维·网络·kubernetes
ProtonBase3 小时前
如何从 0 到 1 ,打造全新一代分布式数据架构
java·网络·数据库·数据仓库·分布式·云原生·架构