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

什么是RPC?有哪些RPC框架?

定义

RPC(Remote Procedure Call,远程过程调用)是一种允许运行在一台计算机上的程序调用另一台计算机上子程序的技术。这种技术屏蔽了底层的网络通信细节,使得程序间的远程通信如同本地调用一样简单。RPC机制使得开发者能够构建分布式计算系统,其中不同的组件可以分布在不同的计算机上,但它们之间可以像在同一台机器上一样相互调用。


工作流程

  1. 客户端(Client)调用:客户端应用程序调用本地的一个存根(Stub)函数,该函数是一个本地函数,但其实现会触发远程调用。
  2. 存根(Stub)处理:存根函数负责将调用参数打包成一种可以在网络上传输的格式(如序列化),并通过网络发送给服务器。
  3. 网络传输:打包后的数据通过网络发送到服务器。
  4. 服务器端接收:服务器端接收并解包这些数据,调用实际的服务端程序或函数,处理请求。
  5. 结果返回:服务端将处理结果打包,通过网络发送回客户端。
  6. 客户端接收结果:客户端的存根函数接收并解包结果,然后返回给原始的调用者。
    在这里插入图片描述

RPC 框架提供了一系列的功能来支持上述过程,包括但不限于:

  • 接口定义:定义服务端和客户端之间的接口,确保双方能够正确理解和调用。
  • 数据序列化与反序列化:将调用信息和结果转换为网络可传输的格式,并在接收时进行还原。
  • 网络通信:封装底层的网络通信逻辑,使得开发者无需关心具体的网络细节。
  • 负载均衡:在多个服务实例之间分配请求,提高系统的可扩展性和可用性。
  • 服务注册与发现:在分布式系统中,自动发现可用的服务实例。

RPC的发展过程

RPC(Remote Procedure Call,远程过程调用)的发展历程可以追溯到计算机网络的早期阶段,随着分布式计算和网络技术的不断发展,RPC技术也逐渐演化和完善。以下是RPC发展历程的主要阶段和特点:

早期阶段

起源:RPC的概念最早可以追溯到1960年代,随着ARPANET(美国国防部高级研究计划局网络)的建立,人们开始探索如何在分布式系统中进行远程通信。
RFC 674和RFC 684:1974年,Jon Postel和Jim White发表了RFC 674,这是最早关于过程调用协议的文档之一。然而,该协议引起了争议,随后在1975年发布了RFC 684作为RFC 674的注释,对争议进行了讨论。

发展与标准化

  • ONC RPC和OSF RPC:随着分布式计算环境的兴起,RPC技术得到了进一步发展。ONC RPC(开放网络计算的远程过程调用)和OSF RPC(开放软件基金会的远程过程调用)是早期RPC技术的代表。这些RPC实现主要关注于支持异构型分布式系统间的通信。
  • CORBA:CORBA(Common Object Request Broker Architecture,公共对象请求代理体系结构)是另一个重要的分布式计算技术,它提供了跨语言、跨平台的对象通信机制。虽然CORBA与RPC在目标上相似,但CORBA更加复杂,且不同实现之间可能存在不兼容的问题。

互联网时代的RPC

  • Web Services:随着互联网的发展,Web Services成为了一种流行的分布式计算技术。Web Services通过SOAP(简单对象访问协议)或REST(表述性状态转移)等协议实现了跨语言和跨平台的通信。其中,SOAP可以看作是RPC在Web环境中的一种实现方式,它允许开发者像调用本地方法一样调用远程的Web服务。
  • 新兴RPC框架:随着分布式系统和微服务架构的普及,出现了许多新的RPC框架,如Apache Thrift、gRPC、Dubbo等。这些框架通常具有更高的性能、更好的可扩展性和更丰富的功能特性。

现代化RPC框架的特点

  • 高性能:现代RPC框架通常采用高效的序列化协议和网络传输协议,以提高通信性能。
  • 跨语言支持:支持多种编程语言,使得不同语言编写的服务可以无缝通信。
  • 可扩展性:提供负载均衡、服务注册与发现等功能,以支持大规模分布式系统的部署和运维。
  • 安全性:支持加密传输和身份验证等安全机制,保障通信过程中的数据安全和隐私保护。

总之,RPC技术从最初的简单过程调用协议发展到如今的现代化RPC框架,经历了多个阶段和不断的改进与创新。随着分布式计算和微服务架构的不断发展,RPC技术将继续在分布式系统中发挥重要作用。


常见RPC框架的对比

1. gRPC

  • 开发者:由Google开发。
  • 协议基础:基于HTTP/2协议,并使用Protocol Buffers(ProtoBuf)作为序列化协议。
  • 支持语言:支持多语言,包括C++、Java、Python、Go、Ruby、C#、Node.js等。
  • 特点:
    • 提供强大的IDL(接口定义语言)和自动代码生成工具。
    • 支持双向流、流式传输等特性。
    • 适用于大规模分布式系统,要求高性能和跨语言支持的场景。
    • 适用于需要使用Protocol Buffers进行高效数据序列化的场景。

2. Apache Dubbo

  • 开发者:由阿里巴巴开发。
  • 协议:支持多种协议,包括Dubbo自定义协议、REST、HTTP等。
  • 支持语言:主要基于Java,但可以通过扩展支持其他语言。
  • 特点:
    • 提供高性能、透明化的远程方法调用。
    • 支持负载均衡、服务发现、集群容错等特性。
    • 提供了REST风格的远程调用。
    • 适用于Java生态系统中的分布式应用,尤其是基于Spring的应用。
    • 适用于需要提供多协议支持和高度可扩展性的场景。

3. Apache Thrift

  • 开发者:由Apache开发。
  • 协议:支持多种传输协议和序列化协议,如TBinaryProtocol、TCompactProtocol等。
  • 支持语言:支持多语言,包括C++、Java、Python、Go、Ruby、C#、Node.js等。
  • 特点:
    • 使用IDL进行接口定义,提供代码生成工具。
    • 支持异步和同步的通信方式。
    • 可以在不同语言之间进行跨语言通信。
    • 适用于异构系统中不同语言之间的远程调用。
    • 适用于需要高度定制和支持多种传输协议的场景。

4. Motan

  • 开发者:新浪微博开源。
  • 特点:
    • 是一个Java框架,具有高性能和可扩展性。
    • 在微博平台中已经广泛应用,每天为数百个服务完成近千亿次的调用。
    • 提供了丰富的功能和良好的性能表现。

5. 其他RPC框架

  • 其他框架:如Tars(腾讯内部使用并开源)、ZeroMQ(高性能异步消息传递库,非专门RPC框架)、Akka(并发编程框架,提供Actor模型实现)等。
  • 特点:
    • 这些框架各有特色,如Tars特别支持C++语言,适合高性能要求的应用场景。
    • ZeroMQ适用于构建高度异步、消息驱动的系统。
    • Akka适用于构建高并发、分布式、容错性强的系统。

以上就是本文的全部内容,感谢阅读。

相关文章:

什么是RPC?有哪些RPC框架?

定义 RPC(Remote Procedure Call,远程过程调用)是一种允许运行在一台计算机上的程序调用另一台计算机上子程序的技术。这种技术屏蔽了底层的网络通信细节,使得程序间的远程通信如同本地调用一样简单。RPC机制使得开发者能够构建分…...

HTTP有哪些请求方式?

GET:请求指定的资源。例如,用于获取网页内容。POST:向指定资源提交数据(例如表单提交)。POST请求的数据通常在请求体中。PUT:将请求体中的数据放置到请求URI指定的位置,如果该资源不存在则创建&…...

接口测试课程结构

课程大纲 如图,接下来的阶段课程,依次专项讲解如下专题,能力级别为中级,进阶后基本为中高级: 1.接口基础知识; 2.抓包工具; 3.接口工具; 4.mock服务搭建(数据模拟服务&am…...

leetcode--从中序与后序遍历序列构造二叉树

leeocode地址:从中序与后序遍历序列构造二叉树 给定两个整数数组 inorder 和 postorder ,其中 inorder 是二叉树的中序遍历, postorder 是同一棵树的后序遍历,请你构造并返回这颗 二叉树 。 示例 1: 输入:inorder …...

西瓜杯CTF(1)

#下班之前写了两个题&#xff0c;后面继续发 Codeinject <?php#Author: h1xaerror_reporting(0); show_source(__FILE__);eval("var_dump((Object)$_POST[1]);"); payload 闭合后面的括号来拼接 POST / HTTP/1.1 Host: 1dc86f1a-cccc-4298-955d-e9179f026d54…...

Kafka 典型问题与排查以及相关优化

Kafka 是一个高吞吐量的分布式消息系统&#xff0c;但在实际应用中&#xff0c;用户经常会遇到一些性能问题和消息堆积的问题。本文将介绍 Kafka 中一些典型问题的原因和排查方法&#xff0c;帮助用户解决问题并优化 Kafka 集群的性能。 一、Topic 消息发送慢&#xff0c;并发性…...

C# 策略模式(Strategy Pattern)

策略模式定义了一系列的算法&#xff0c;并将每一个算法封装起来&#xff0c;使它们可以相互替换。策略模式让算法的变化独立于使用算法的客户。 // 策略接口 public interface IStrategy { void Execute(); } // 具体策略A public class ConcreteStrategyA : IStra…...

【初阶数据结构】1.算法复杂度

文章目录 1.数据结构前言1.1 数据结构1.2 算法1.3 如何学好数据结构和算法 2.算法效率2.1 复杂度的概念2.2 复杂度的重要性 3.时间复杂度3.1 大O的渐进表示法3.2 时间复杂度计算示例3.2.1 示例13.2.2 示例23.2.3 示例33.2.4 示例43.2.5 示例53.2.6 示例63.2.7 示例7 4.空间复杂…...

(图文详解)小程序AppID申请以及在Hbuilderx中运行

今天小编给大家带来了如何去申请APPID&#xff0c;如果你是小程序的开发者&#xff0c;就必须要这个id。 申请步骤 到小程序注册页面&#xff0c;注册一个小程序账号 微信公众平台 填完信息后提交注册 会在邮箱收到 链接激活账号 确认。邮箱打开链接后&#xff0c;会输入实…...

科技创新引领水利行业升级:深入分析智慧水利解决方案的核心价值,展望其在未来水资源管理中的重要地位与作用

目录 引言 一、智慧水利的概念与内涵 二、智慧水利解决方案的核心价值 1. 精准监测与预警 2. 优化资源配置 3. 智能运维管理 4. 公众参与与决策支持 三、智慧水利在未来水资源管理中的重要地位与作用 1. 推动水利行业转型升级 2. 保障国家水安全 3. 促进生态文明建设…...

ExcelVBA运用Excel的【条件格式】(三)

ExcelVBA运用Excel的【条件格式】&#xff08;三&#xff09;前面知识点回顾1. 访问 FormatConditions 集合 Range.FormatConditions2. 添加条件格式 FormatConditions.Add 方法语法表达式。添加 (类型、 运算符、 Expression1、 Expression2)其中 TextOperator:***&am…...

coco数据集格式计算mAP的python脚本

目录 背景说明COCOeval 计算mAPtxt文件转换为coco json 格式自定义数据集标注 背景说明 在完成YOLOv5模型移植&#xff0c;运行在板端后&#xff0c;通常需要衡量板端运行的mAP。 一般需要两个步骤 步骤一&#xff1a;在板端批量运行得到目标检测结果&#xff0c;可保存为yol…...

Linux学习——Linux中无法使用ifconfg命令

Linux学习——Linux中无法使用ifconfg命令&#xff1f; &#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅…...

二分查找3

1. 有序数组中的单一元素&#xff08;540&#xff09; 题目描述&#xff1a; 算法原理&#xff1a; 二分查找解题关键就在于去找到数组的二段性&#xff0c;这里数组的二段性是从单个数字a开始出现然后分隔出来的&#xff0c;如果mid落入左半部分那么当mid为偶数时nums[mid1]…...

从零开始学习嵌入式----C语言框架梳理与后期规划

目录 一、环境搭建. 二、见解 三、C语言框架梳理 四、嵌入式学习规划流程图&#xff08;学习顺序可能有变&#xff09; 一、环境搭建. C语言是一门编程语言&#xff0c;在学习的时候要准备好环境。我个人比较喜欢用VS,具体怎么安装请百度。学习C语言的时候&#xff0c;切忌…...

ESP32 步进电机精准控制:打造高精度 DIY 写字机器人,实现流畅书写体验

摘要: 想让你的 ESP32 不再仅仅是控制灯光的工具吗&#xff1f; 本文将带你使用 ESP32 开发板、步进电机和简单的机械结构打造一个能够自动写字的机器人。我们将深入浅出地讲解硬件连接、软件代码以及控制逻辑&#xff0c;并提供完整的项目代码和电路图&#xff0c;即使是 Ardu…...

传知代码-图神经网络长对话理解(论文复现)

代码以及视频讲解 本文所涉及所有资源均在传知代码平台可获取 概述 情感识别是人类对话理解的关键任务。随着多模态数据的概念&#xff0c;如语言、声音和面部表情&#xff0c;任务变得更加具有挑战性。作为典型解决方案&#xff0c;利用全局和局部上下文信息来预测对话中每…...

部署前端项目

常见部署方式有&#xff1a;静态托管服务、服务器部署 1. 静态托管服务 使用平台部署代码&#xff0c;比如 GitHub。 | 创建一个仓库&#xff0c;仓库名一般是 yourGithubName.github.io。 | 将打包后的静态文件文件上传到仓库。 | 在“Settings”&#xff08;选项&#xff0…...

使用POI实现Excel文件的读取(超详细)

目录 一 导入poi相关的maven坐标 二 实现创建并且写入文件 2.1实现步骤 2.2实现代码 2.3效果展示 ​编辑 2.4注意 三 实现从Excel文件中读取数据 3.1实现步骤 3.2实现代码 3.3结果展示 一 导入poi相关的maven坐标 <!-- Apache poi --><dependency><gro…...

Debezium系列之:记录一次数据库某张表部分数据未同步到hive表的原因

Debezium系列之:记录一次数据库某张表部分数据未同步到hive表的原因 一、背景二、查找数据丢失流程三、数据丢失原因四、解决方法一、背景 反馈mysql数据库中某张表的数据没有同步到hive中,现在需要排查定位下原因数据丢失一般常见需求排查的方向: 数据是否采集到hdfs上采集…...

Android Wi-Fi 连接失败日志分析

1. Android wifi 关键日志总结 (1) Wi-Fi 断开 (CTRL-EVENT-DISCONNECTED reason3) 日志相关部分&#xff1a; 06-05 10:48:40.987 943 943 I wpa_supplicant: wlan0: CTRL-EVENT-DISCONNECTED bssid44:9b:c1:57:a8:90 reason3 locally_generated1解析&#xff1a; CTR…...

《通信之道——从微积分到 5G》读书总结

第1章 绪 论 1.1 这是一本什么样的书 通信技术&#xff0c;说到底就是数学。 那些最基础、最本质的部分。 1.2 什么是通信 通信 发送方 接收方 承载信息的信号 解调出其中承载的信息 信息在发送方那里被加工成信号&#xff08;调制&#xff09; 把信息从信号中抽取出来&am…...

Python爬虫(二):爬虫完整流程

爬虫完整流程详解&#xff08;7大核心步骤实战技巧&#xff09; 一、爬虫完整工作流程 以下是爬虫开发的完整流程&#xff0c;我将结合具体技术点和实战经验展开说明&#xff1a; 1. 目标分析与前期准备 网站技术分析&#xff1a; 使用浏览器开发者工具&#xff08;F12&…...

【C++从零实现Json-Rpc框架】第六弹 —— 服务端模块划分

一、项目背景回顾 前五弹完成了Json-Rpc协议解析、请求处理、客户端调用等基础模块搭建。 本弹重点聚焦于服务端的模块划分与架构设计&#xff0c;提升代码结构的可维护性与扩展性。 二、服务端模块设计目标 高内聚低耦合&#xff1a;各模块职责清晰&#xff0c;便于独立开发…...

稳定币的深度剖析与展望

一、引言 在当今数字化浪潮席卷全球的时代&#xff0c;加密货币作为一种新兴的金融现象&#xff0c;正以前所未有的速度改变着我们对传统货币和金融体系的认知。然而&#xff0c;加密货币市场的高度波动性却成为了其广泛应用和普及的一大障碍。在这样的背景下&#xff0c;稳定…...

python执行测试用例,allure报乱码且未成功生成报告

allure执行测试用例时显示乱码&#xff1a;‘allure’ &#xfffd;&#xfffd;&#xfffd;&#xfffd;&#xfffd;ڲ&#xfffd;&#xfffd;&#xfffd;&#xfffd;ⲿ&#xfffd;&#xfffd;&#xfffd;Ҳ&#xfffd;&#xfffd;&#xfffd;ǿ&#xfffd;&am…...

React---day11

14.4 react-redux第三方库 提供connect、thunk之类的函数 以获取一个banner数据为例子 store&#xff1a; 我们在使用异步的时候理应是要使用中间件的&#xff0c;但是configureStore 已经自动集成了 redux-thunk&#xff0c;注意action里面要返回函数 import { configureS…...

mac 安装homebrew (nvm 及git)

mac 安装nvm 及git 万恶之源 mac 安装这些东西离不开Xcode。及homebrew 一、先说安装git步骤 通用&#xff1a; 方法一&#xff1a;使用 Homebrew 安装 Git&#xff08;推荐&#xff09; 步骤如下&#xff1a;打开终端&#xff08;Terminal.app&#xff09; 1.安装 Homebrew…...

Linux部署私有文件管理系统MinIO

最近需要用到一个文件管理服务&#xff0c;但是又不想花钱&#xff0c;所以就想着自己搭建一个&#xff0c;刚好我们用的一个开源框架已经集成了MinIO&#xff0c;所以就选了这个 我这边对文件服务性能要求不是太高&#xff0c;单机版就可以 安装非常简单&#xff0c;几个命令就…...

git: early EOF

macOS报错&#xff1a; Initialized empty Git repository in /usr/local/Homebrew/Library/Taps/homebrew/homebrew-core/.git/ remote: Enumerating objects: 2691797, done. remote: Counting objects: 100% (1760/1760), done. remote: Compressing objects: 100% (636/636…...