什么是RPC?有哪些RPC框架?
定义
RPC(Remote Procedure Call,远程过程调用)是一种允许运行在一台计算机上的程序调用另一台计算机上子程序的技术。这种技术屏蔽了底层的网络通信细节,使得程序间的远程通信如同本地调用一样简单。RPC机制使得开发者能够构建分布式计算系统,其中不同的组件可以分布在不同的计算机上,但它们之间可以像在同一台机器上一样相互调用。
工作流程
- 客户端(Client)调用:客户端应用程序调用本地的一个存根(Stub)函数,该函数是一个本地函数,但其实现会触发远程调用。
- 存根(Stub)处理:存根函数负责将调用参数打包成一种可以在网络上传输的格式(如序列化),并通过网络发送给服务器。
- 网络传输:打包后的数据通过网络发送到服务器。
- 服务器端接收:服务器端接收并解包这些数据,调用实际的服务端程序或函数,处理请求。
- 结果返回:服务端将处理结果打包,通过网络发送回客户端。
- 客户端接收结果:客户端的存根函数接收并解包结果,然后返回给原始的调用者。
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)
#下班之前写了两个题,后面继续发 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 是一个高吞吐量的分布式消息系统,但在实际应用中,用户经常会遇到一些性能问题和消息堆积的问题。本文将介绍 Kafka 中一些典型问题的原因和排查方法,帮助用户解决问题并优化 Kafka 集群的性能。 一、Topic 消息发送慢,并发性…...

C# 策略模式(Strategy Pattern)
策略模式定义了一系列的算法,并将每一个算法封装起来,使它们可以相互替换。策略模式让算法的变化独立于使用算法的客户。 // 策略接口 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,如果你是小程序的开发者,就必须要这个id。 申请步骤 到小程序注册页面,注册一个小程序账号 微信公众平台 填完信息后提交注册 会在邮箱收到 链接激活账号 确认。邮箱打开链接后,会输入实…...

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

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

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

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

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

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

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

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

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

使用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上采集…...

爆破器材期刊
《爆破器材》简介 《爆破器材》自1958年创刊以来,深受广大读者喜爱,是中国兵工学会主办的中央级技术刊物,在国内外公开发行,近几年已发行到10个国家和地区。《爆破器材》杂志被美国著名检索机构《化学文摘》(CA&a…...

Nginx Websocket 协议配置支持
前后分离的 Web 架构应用,在开发环境启动是可以直接连接支持 websocket 协议,因为没有中间件做转发处理。 当我们对前端进行编译后,通过 nginx 反向代理访问时,需要在nginx 配置文件中增加一些特定的头信息,让服务端识…...

【生成式对抗网络】GANs在数据生成、艺术创作,以及在增强现实和虚拟现实中的应用
一、GANs在数据生成中的应用 生成对抗网络(Generative Adversarial Networks, GANs)在数据生成领域具有显著的应用价值。GANs通过生成器(Generator)和判别器(Discriminator)两个相互竞争的神经网络&#x…...

大模型面试(三)
这次是某家公司的一个电话面试,问的过程还比较简单直接。 问:我们在大模型开源项目的应用上遇到了什么困难? 这个。。有两个困难,一个是RAG的优化,一开始RAG是比较慢的,而且召回率不高; 后来…...

pycharm中快捷键汇总
Pycarm指令汇总 Ctrl鼠标 单击,能直接查看其用法 Ctrl/ 快速注释 CtrlC 在pycharm的terminal中可以停止运行, 其他的地方可以复制。 CtrlV 粘贴 CtrlA 全选 CtrlP 查看()中需要填写什么参数 Altenter 自动不补全所需要的库...

TCP/IP协议族结构和协议
TCP/IP协议族是互联网及许多其他网络的基础,它由一系列相互关联的协议组成,用于实现网络通信。TCP/IP协议族采用ARPANET参考模型,大致可以分为四个层次:链路层、网络层、传输层和应用层。每个层次都有特定的协议和功能,确保数据能够从一个网络设备传输到另一个网络设备。 …...

大模型一些概念的理解 - 线性层、前向传播、后向传播
文章目录 前言一、线性层1. 什么是线性层?2. 通俗解释3. 示例 二、前向传播1. 什么是前向传播?2. 通俗解释3. 示例 三、后向传播1. 什么是后向传播?2. 通俗解释3. 具体步骤 四、示例五、在 PyTorch 中的后向传播 前言 最近提问里有问到一些名…...

AWS 云安全性:检测 SSH 暴力攻击
由于开源、低成本、可靠性和灵活性等优势,云基础设施主要由基于linux的机器主导,然而,它们也不能幸免于黑客的攻击,从而影响云的安全性。攻击Linux机器最流行的方法之一是通过SSH通道。 什么是 SSH 安全外壳协议(Sec…...

7.9数据结构
思维导图 作业 doubleloop.h #ifndef __DOUBLELOOP_H__ #define __DOUBLELOOP_H__#include <stdio.h> #include <stdlib.h>typedef int datatype; typedef struct node {union{int len;datatype data;};struct node *pri;//前驱指针struct node *next;//后继指针…...

Python 文件操作:打开数据处理的大门
在 Python 的学习之旅中,文件操作是一个非常实用且必不可少的技能。不论是数据分析还是日常的数据处理,良好的文件操作技巧都能让你的编程之路更加顺畅。今天,我将带你走进 Python 文件操作的世界,不仅教你如何读写文件࿰…...