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

news2024/10/2 16:24:53

定义

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适用于构建高并发、分布式、容错性强的系统。

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

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

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

相关文章

leetcode--恢复二叉搜索树

leetcode地址:恢复二叉搜索树 给你二叉搜索树的根节点 root ,该树中的 恰好 两个节点的值被错误地交换。请在不改变其结构的情况下,恢复这棵树 。 示例 1: 输入:root [1,3,null,null,2] 输出:[3,1,null…

Mac下flutter运行iOS模拟器

上篇flutter环境安装(Macvscode)已经将vscode和xcode等开发环境都搭建起来了,vscode新建工程还是比较方便的,那么,建立好了之后,我们怎么看效果呢? 1. vscode新建项目 通过 vscode的命令命板(…

Collection 和 Collections 的区别与用法

Collection 和 Collections 的区别与用法 1、Collection 接口1.1 主要特点1.2 常见方法 2、 Collections 工具类2.1 主要特点2.2 常见方法 3、示例代码3.1 使用 Collection 接口3.2 使用 Collections 工具类 4、总结 💖The Begin💖点点关注,收…

JAVA从入门到精通之入门初阶(一)

1. 认识变量 一、 首先变量名要遵循如下命名规则: 1. 变量名只能由字母、数字和下划线组成 2. 变量名必须以字母或下划线开头 3. 变量名大小写敏感 4. 变量名不能使用关键字,如const、static等 5. 变量名应具有描述性,以便于代码的可读性…

三级_网络技术_12_路由设计技术基础

1.R1、R2是一个自治系统中采用RIP路由协议的两个相邻路由器,R1的路由表如下图(a)所示,当R1收到R2发送的如下图(b)的(V.D)报文后,R1更新的4个路由表项中距离值从上到下依次为0、3、3、4 那么,①②③④可能的取值依次为()。 0、4、…

240709_昇思学习打卡-Day21-文本解码原理--以MindNLP为例

240709_昇思学习打卡-Day21-文本解码原理–以MindNLP为例 今天做根据前文预测下一个单词,仅作简单记录及注释。 一个文本序列的概率分布可以分解为每个词基于其上文的条件概率的乘积 𝑊_0:初始上下文单词序列𝑇: 时间步当生成EOS标签时&a…

使用OpenCV的absdiff函数报错

1.absdiff用法 absdiff函数用于计算两个输入图像之间每个像素的差异,并返回结果图像。 void cv::absdiff ( InputArray src1,InputArray src2,OutputArray dst ) //eg:比较两图像的差异 /*cv::Mat diff;cv::absdiff(depLeft32, imDepth, diff…

Spring MVC深入理解之源码实现

1、SpringMVC的理解 1)谈谈对Spring MVC的了解 MVC 是模型(Model)、视图(View)、控制器(Controller)的简写,其核心思想是通过将业务逻辑、数据、显示分离来组织代码。 Model:数据模型,JavaBean的类,用来进行数据封装…

CLion学习笔记-cmake编译和多main函数编译

这里就不讲怎么配置clion了 项目名字 pcl_kdtree_search 1.新建一个工程名字自己取,我这里用自己学习pcl的,加一个main函数,这个时候Cmake里边就是这样的。 #声明要求的cmake最低版本 cmake_minimum_required(VERSION 3.19) #声明一个工程…

【每日一练】python基础入门实例

""" 幼儿园加法练习题 题数不限 每满100分奖励10个棒棒糖 要求: 1.使用三目运算符与基础运算的对比 2.随机数字相加 3.调用函数 4.循环执行练习题 5.有计算分数 6.有时间停止休眠 """ #导入随机模块 import random #导入时间模块 imp…

华为乾崑智驾加持:深蓝S07首次亮相

最近,特斯拉FSD即将入华的消息,让智能驾驶成为了汽车行业热议的焦点,而当新能源汽车的代表企业深蓝汽车,与全球领先的华为乾崑智驾强强联手,一场颠覆性的智能出行变革也已蓄势待发。 7月8日,深蓝汽车携其最…

uniapp自动升级

一、创建云服务空间(https://unicloud.dcloud.net.cn) 云空间用于关联需要版本控制升级的项目,如果已拥有云空间则省略此步骤。 二、搭建 uni升级中心 - 后台管理系统(升级中心 uni-upgrade-center - Admin) uni-adm…

DDR3 SO-DIMM 内存条硬件总结(一)

最近在使用fpga读写DDR3,板子上的DDR3有两种形式与fpga相连,一种是直接用ddr3内存颗粒,另一种是通过内存条的形式与fpga相连。这里我们正好记录下和ddr3相关的知识,先从DDR3 SO-DIMM 内存条开始。 1.先看内存条的版本 从JEDEC下载…

Elasticsearch:深度学习与机器学习:了解差异

作者:来自 Elastic Elastic Platform Team 近年来,两项突破性技术一直站在创新的最前沿 —— 机器学习 (machine learning - ML) 和深度学习 (deep learning - DL)。人工智能 (AI) 的这些子集远不止是流行语。它们是推动医疗保健、金融等各行业进步的关键…

vue3 antdv Modal通过设置内容里的容器的最小高度,让Modal能够适当的变高一些

1、当收款信息Collapse也折叠的时候,我们会发现Modal的高度也变成了很小。 2、我们希望高度稍微要高一些,这样感觉上面显示的Modal高度太小了,显示下面的效果。 3、初始的时候,想通过class或者style或者wrapClassName来实现&#…

理解局域网技术:从基础到进阶

局域网(LAN)是在20世纪70年代末发展起来的,起初主要用于连接单位内部的计算机,使它们能够方便地共享各种硬件、软件和数据资源。局域网的主要特点是网络为一个单位所拥有,地理范围和站点数目均有限。 局域网技术在计算…

【排序算法】快速排序(详解+各版本实现)

目录 一.交换排序 1.基本思想 2.冒泡排序 二.快速排序 1.hoare版本 2.挖坑法 3.前后指针版本 4.优化 优化①:三数取中 优化②:小区间优化 5.非递归版本 6.特性总结 ①效率 ②时间复杂度:O(N*logN) ③空间复杂度:O(l…

拓展神经网络八股(入门级)

自制数据集 minst等数据集是别人打包好的,如果是本领域的数据集。自制数据集。 替换 把图片路径和标签文件输入到函数里,并返回输入特征和标签 只需要把图片灰度值数据拼接到特征列表,标签添加到标签列表,提取操作函数如下: def…

STM32快速搭建项目框架

注:编写本博客的原因,学习期间基于复习之前知识点的需要,故撰写本教程,即是复习前面的知识点也是作为博客的补充 1.0 文件夹的创建 创建一个STM32项目为模版工程,问价夹下分别包含4个子文件夹,一个是Librar…

【初阶数据结构】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.空间复杂…