远程过程调用RPC知识科普
文章目录
- 什么是RPC
- RPC的基本原理
- RPC的应用场景
- RPC的优势
- 常见的RPC框架
- 常见的RPC协议
- 1. gRPC
- 2. Apache Thrift
- 3. Dubbo
- 4. JSON-RPC
- 5. XML-RPC
- 6. SOAP
- springboot环境下常用的RPC框架使用
- 1. Apache Dubbo
- 2. Apache Thrift
- 3. gRPC
- 4. Spring Cloud OpenFeign
什么是RPC
RPC(Remote Procedure Call,远程过程调用)是一种计算机通信协议,它允许一个计算机程序通过网络调用另一个计算机程序中的子程序(即远程过程),并获取返回值。RPC是分布式计算的重要基础,它极大地简化了分布式系统之间的通信和交互过程,使得开发者可以像调用本地方法一样调用远程方法,而无需关心底层的网络通信细节。
RPC的基本原理
- 客户端调用:客户端通过调用本地的客户端代理(或称为stub)来发起远程调用。客户端代理负责将调用请求序列化成网络协议中的消息,并通过网络发送给服务器端。
- 服务器端执行:服务器端接收到请求后,通过服务端代理(或称为skeleton)进行反序列化,根据接口定义执行相应的远程方法。执行完成后,将结果序列化为网络传输格式,并返回给客户端。
- 客户端接收响应:客户端代理接收到服务端的响应后,进行反序列化,将结果返回给客户端,就像调用本地函数一样。
RPC的应用场景
RPC在分布式系统、微服务架构、云计算和容器化部署等场景中有着广泛的应用。它可以用来实现不同进程之间的通信,以及跨越不同的计算机硬件、操作系统和平台的通信。
- 分布式系统:在分布式系统中,RPC是实现不同节点之间数据同步和交互的重要机制。
- 微服务架构:在微服务架构中,每个服务通常都会运行在不同的进程中,通过RPC框架实现服务之间的调用和通信。
- 云计算和容器化部署:在云计算和容器化部署中,RPC框架可以帮助实现不同节点之间的通信,提高系统的可伸缩性和可靠性。
RPC的优势
- 隐藏通信细节:RPC成功隐藏了内部通信的复杂性,为双方提供了稳定统一的接口,使得开发者只需要关注业务逻辑,而无需关注底层网络通信细节。
- 高效性:通过序列化和反序列化技术,RPC能够高效地传输数据,减少网络传输的数据量并节省网络带宽。
- 跨平台性:RPC框架通常支持多种编程语言和平台,可以实现跨平台的远程调用。
常见的RPC框架
- gRPC:由谷歌开发的现代开源高性能RPC框架,采用HTTP/2作为底层传输协议,数据交换采用轻量化的Protobuf序列化协议,具备高效、跨语言等特点。
- Apache Dubbo:一款高性能、轻量级的开源Java RPC框架,支持多种通信协议和序列化方式,广泛应用于微服务架构中。
总之,RPC是一种强大的计算机通信协议,它简化了分布式系统之间的通信和交互过程,为开发者提供了便捷、高效的远程调用机制。
常见的RPC协议
常见的RPC(Remote Procedure Call,远程过程调用)协议及其相关框架多种多样,它们各自具有不同的特点和优势,适用于不同的应用场景。以下是一些常见的RPC协议及其概述:
1. gRPC
- 概述:gRPC是由Google开发的高性能、开源和通用的RPC框架,基于HTTP/2协议标准设计,并默认使用Protocol Buffers作为序列化协议。
- 特点:
- 高性能:支持多路复用、流控、头部压缩等特性,提升网络传输效率。
- 跨语言:支持多种编程语言,如C++、Java、Python、Go等,方便跨语言开发。
- 强类型接口:使用Protocol Buffers定义接口和消息,具有强类型检查,减少错误。
- 双向流:支持双向流通信,适合实时通信场景。
2. Apache Thrift
- 概述:Apache Thrift是Facebook开源的跨语言RPC通信框架,它允许你定义一个简单的定义文件,然后使用Thrift编译器生成不同语言的代码。
- 特点:
- 跨语言:支持多种编程语言和平台,如C++、Java、Python、Ruby等。
- 多协议支持:支持多种传输协议和传输层,如TBinaryProtocol、TCompactProtocol等,灵活性高。
- 高性能:采用自定义的二进制协议,性能较好。
3. Dubbo
- 概述:Dubbo是阿里巴巴开源的高性能Java RPC框架,它提供了三大关键能力:面向接口的远程方法调用、智能负载均衡以及自动服务注册与发现。
- 特点:
- 高性能:基于Netty框架开发,支持多种通信协议和序列化方式。
- 透明化的远程方法调用:就像调用本地方法一样调用远程服务。
- 丰富的服务治理特性:如负载均衡、容错、自动发现等。
4. JSON-RPC
- 概述:JSON-RPC是一种使用JSON(JavaScript Object Notation)进行数据交换的远程过程调用协议。
- 特点:
- 简单易用:基于JSON格式,易于理解和使用。
- 轻量级:协议简单,适合轻量级应用和快速开发。
- 浏览器友好:与HTTP和WebSocket兼容,适合浏览器环境。
5. XML-RPC
- 概述:XML-RPC是基于XML的远程过程调用协议,它使用HTTP作为传输协议,使用XML作为数据交换格式。
- 特点:
- 广泛支持:基于XML和HTTP,几乎所有编程语言和平台都支持。
- 简单易用:协议简单,易于理解和实现。
- 但性能较低:XML格式解析和传输性能较低,且XML格式冗长,占用带宽较大。
6. SOAP
- 概述:SOAP(Simple Object Access Protocol)是一种基于XML的协议,用于在Web上交换结构化信息。尽管它通常与Web服务关联,但也可以用于RPC。
- 特点:
- 标准化:基于W3C标准,具有良好的互操作性和兼容性。
- 丰富功能:支持WS-Security、WS-Transaction等多种扩展规范,功能强大。
- 企业级支持:广泛应用于企业级应用和服务。
- 但同样存在性能较低和复杂性较高的问题。
综上所述,不同的RPC协议和框架各有优劣,选择时应根据具体的应用场景、性能要求、语言支持等因素进行综合考虑。
springboot环境下常用的RPC框架使用
在Spring Boot环境下,常用的RPC(远程过程调用)框架主要包括Apache Dubbo、Apache Thrift(通过Spring Boot Starter集成)、gRPC以及Spring Cloud OpenFeign等。下面我将结合Spring Boot分别介绍这些RPC框架及其使用样例。
1. Apache Dubbo
概述:
Apache Dubbo是一款高性能的Java RPC框架,它提供了面向接口的远程方法调用、智能负载均衡以及服务自动注册与发现等功能。Dubbo非常适合用于构建微服务架构的分布式系统。
使用样例:
-
添加依赖:
在Spring Boot项目的pom.xml中添加Dubbo和Zookeeper的依赖(Zookeeper是Dubbo常用的注册中心)。<!-- Dubbo Spring Boot Starter --> <dependency><groupId>org.apache.dubbo</groupId><artifactId>dubbo-spring-boot-starter</artifactId><version>你的Dubbo版本</version> </dependency> <!-- Zookeeper客户端 --> <dependency><groupId>org.apache.curator</groupId><artifactId>curator-framework</artifactId><version>你的Curator版本</version> </dependency> -
配置Dubbo和Zookeeper:
在application.properties或application.yml中配置Dubbo的扫描包、注册中心地址等。dubbo:application:name: dubbo-consumerregistry:address: zookeeper://127.0.0.1:2181scan:base-packages: com.example.service -
定义服务接口:
在服务提供方和消费方定义相同的接口。package com.example.service; public interface GreetingService {String sayHello(String name); } -
实现服务接口:
在服务提供方实现该接口。package com.example.service.impl; @Service public class GreetingServiceImpl implements GreetingService {@Overridepublic String sayHello(String name) {return "Hello, " + name + "!";} } -
消费服务:
在服务消费方通过Dubbo的@Reference注解注入服务接口。package com.example.controller; @RestController public class GreetingController {@Referenceprivate GreetingService greetingService;@GetMapping("/sayHello")public String sayHello(@RequestParam String name) {return greetingService.sayHello(name);} }
2. Apache Thrift
概述:
Apache Thrift是一个跨语言的RPC框架,它允许你定义一个简单的服务接口(使用Thrift IDL),然后自动生成多种语言的RPC客户端和服务器代码。
使用样例(通过Spring Boot Starter集成):
由于Thrift本身并不直接支持Spring Boot,但可以通过Spring Boot Starter或其他集成方式来实现。这里主要描述Thrift的基本使用流程,而非直接集成到Spring Boot。
-
定义Thrift IDL:
编写Thrift接口定义文件(.thrift)。 -
生成代码:
使用Thrift编译器生成代码。 -
实现服务:
在服务提供方实现Thrift生成的接口。 -
配置服务:
设置Thrift服务器,如TNonblockingServer或THsHaServer。 -
客户端调用:
在服务消费方创建Thrift客户端,并调用服务。
3. gRPC
概述:
gRPC是一个高性能、开源和通用的RPC框架,由Google主导开发。它支持多种语言,并基于HTTP/2协议标准设计,以Protocol Buffers作为接口定义语言(IDL)。
使用样例(结合Spring Boot):
-
添加依赖:
在Spring Boot项目的pom.xml中添加gRPC和Spring Cloud gRPC Starter的依赖。<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-grpc</artifactId><version>你的版本</version> </dependency> -
定义gRPC服务:
使用Protocol Buffers定义gRPC服务接口和消息格式。 -
实现服务:
在服务提供方实现gRPC服务接口。 -
配置gRPC服务器:
在Spring Boot中配置gRPC服务器,并注册服务。 -
客户端调用:
在服务消费方生成gRPC客户端代码,并调用服务。
4. Spring Cloud OpenFeign
概述:
Spring Cloud OpenFeign是Spring Cloud对Feign的封装,它提供了声明式的Web服务客户端,使得编写Web服务客户端变得更加简单。虽然Feign本身不是RPC框架,但它常用于微服务之间的HTTP调用。
使用样例:
-
添加依赖:
在Spring Boot项目的pom.xml中添加Spring Cloud OpenFeign的依赖。<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-openfeign</artifactId><version>你的Spring Cloud版本</version> </dependency> -
启用Feign:
在Spring Boot启动类上添加@EnableFeignClients注解。 -
定义Feign客户端:
使用@FeignClient注解定义Feign客户端,并指定服务名或URL。 -
调用服务:
在Feign客户端接口中定义调用远程服务的方法,并通过Spring MVC注解指定HTTP请求方式和路径。
以上就是在Spring Boot环境下,几种常用RPC框架的概述及使用样例。请注意,由于技术快速发展,具体依赖版本和配置方式可能会有所变化,建议参考官方文档和最新资源。
相关文章:
远程过程调用RPC知识科普
文章目录 什么是RPCRPC的基本原理RPC的应用场景RPC的优势常见的RPC框架 常见的RPC协议1. gRPC2. Apache Thrift3. Dubbo4. JSON-RPC5. XML-RPC6. SOAP springboot环境下常用的RPC框架使用1. Apache Dubbo2. Apache Thrift3. gRPC4. Spring Cloud OpenFeign 什么是RPC RPC&…...
Java - LeetCode面试经典150题 - 区间 (三)
区间 228. 汇总区间 题目 给定一个 无重复元素 的 有序 整数数组 nums 。 返回 恰好覆盖数组中所有数字 的 最小有序 区间范围列表 。也就是说,nums 的每个元素都恰好被某个区间范围所覆盖,并且不存在属于某个范围但不属于 nums 的数字 x 。 列表中…...
NVIDIA网卡系列之ConnectX-6 DX规格信息(200G-PCIe 4.0x16-8PF1000VF-2019年发布)
背景 NVIDIA ConnectX-6是最大支持200G的产品,有DX LX等系列。LX一般是25G比较便宜。 核心关键点 200GbpsPCIe 4.0,最大lane: x16 (4.0的lane速 16GT/s * 16 256T/s,所以支持的是200G的网卡用PCIe4.0)QSFPPF,VF数量࿱…...
【案例】平面云
教程案例视频:Unity Shader Graph - 云教程 开发平台:Unity 2022 开发工具:Unity ShaderGraph 一、效果展示 二、ShaderGraph 路线图 三、案例分析 核心思路:使用 Noise(噪声)模拟云层状态 3.1 说明…...
测试用例的进阶二
1. 按开发阶段划分 1.1 测试金字塔 从上到下,对于测试人员代码就是要求越来越低; 从下到上,越来越靠近用户; 从下到上,定位问题的成本越来越高; 1.2 单元测试(Unit Testing) 单元测试是对软件组成单元进…...
zotero WebDAV同步忘记密码
https://www.jianguoyun.com/#/safety 找到应用密码...
如何在 SQL 中创建一个新的数据库?
在SQL中创建一个新的数据库,首先你需要有一个可以执行SQL语句的环境。 这通常意味着你已经有了一个数据库管理系统(DBMS),如MySQL、PostgreSQL、Oracle或Microsoft SQL Server等。 不同的DBMS可能有不同的细节,但基本…...
《Linux从小白到高手》理论篇:Linux的进程管理详解
本篇将介绍Linux的进程管理相关知识,并将深入介绍Linux的进程间相互通信。 进程就是运行中的程序,一个运行着的程序,可能有多个进程。 比如Oracle DB,启动Oracle实例服务后,就会有多个进程。 Linux进程分类 在 Linux…...
【Qt】控件概述(3)—— 显示类控件
显示类控件 1. QLabel——标签1.1 setPixmap设置图片1.2 setAlignment设置文本对齐方式1.3 setWordWrap设置自动换行1.4 setIndent设置缩进1.5 setMargin设置边距1.6 body 2. QLCDNumber2.1 使用QTimer实现一个倒计时效果2.2 使用循环的方式实现倒计时 3. QProgressBar——进度…...
数据库管理-第247期 23ai:全球分布式数据库-Schema对象(20241004)
数据库管理247期 2024-10-04 数据库管理-第247期 23ai:全球分布式数据库-Schema对象(20241004)1 分区、表空间和Chunk(块)2 表空间组3 分片表4 分片表族5 复制表6 在所有分片上创建的非表对象总结 数据库管理-第247期 …...
Docker搭建一款开源的文档管理系统
1.系统介绍 Wizard是一款开源的文档管理系统,它支持多种格式类型的文档管理,包括Markdown、Swagger和Table,以适应不同场景和需求下的文档管理需求。 1.1功能特点 开源免费:Wizard是一款完全免费的开源项目,用户可以…...
软件验证与确认实验一:静态分析
目录 1. 实验目的及要求.................................................................................................... 3 2. 实验软硬件环境.................................................................................................... 3 …...
基于SpringBoot+Vue的高校运动会管理系统
作者:计算机学姐 开发技术:SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等,“文末源码”。 专栏推荐:前后端分离项目源码、SpringBoot项目源码、Vue项目源码、SSM项目源码、微信小程序源码 精品专栏:…...
什么东西可以当做GC Root,跨代引用如何处理?
引言 在Java的垃圾回收机制中,GC Root(Garbage Collection Root,垃圾回收根)是垃圾回收器判断哪些对象是可达的,哪些对象可以被回收的起点。GC Root通过遍历对象图,标记所有可达的对象,而那些不…...
Python深度学习:从神经网络到循环神经网络
Python深度学习:从神经网络到循环神经网络 目录 ✨ 神经网络基础 1.1 🔍 前向传播与反向传播🎨 卷积神经网络(CNN) 2.1 🖼️ 图像分类任务的实现 2.2 🚀 常用架构(LeNet、VGG、Res…...
C++输⼊输出
1.<iostream> 是 Input Output Stream 的缩写,是标准的输⼊、输出流库,定义了标准的输⼊、输 出对象 2.std::cin 是 istream 类的对象,它主要⾯向窄字符(narrow characters (of type char))的标准输 ⼊流。 3…...
卡码网KamaCoder 117. 软件构建
题目来源:117. 软件构建 C题解(来源代码随想录):拓扑排序:给出一个 有向图,把这个有向图转成线性的排序。拓扑排序也是图论中判断有向无环图的常用方法。 拓扑排序的过程,其实就两步࿱…...
Acwing 线性DP
状态转移方程呈现出一种线性的递推形式的DP,我们将其称为线性DP。 Acwing 898.数字三角形 实现思路: 对这个三角形的数字进行编号,状态表示依然可以用二维表示,即f(i,j),i表示横坐标(横线),j表…...
Docker面试-24年
1、Docker 是什么? Docker一个开源的应用容器引擎,是实现容器技术的一种工具,让开发者可以打包他们的应用以及环境到一个镜像中,可以快速的发布到任何流行的操作系统上。 2、Docker的三大核心是什么? 镜像:Docker的…...
ubuntu 安装k8s
#关闭 Swap 内存,配置完成建议重启一下 nano /etc/fstab #注释下面相似的一行 #/swapfile none swap sw 0 0 #重启 reboot#部属k8s apt update && apt install -y apt-transport-https 下载 gpg 密钥 curl https://mi…...
深入浅出Asp.Net Core MVC应用开发系列-AspNetCore中的日志记录
ASP.NET Core 是一个跨平台的开源框架,用于在 Windows、macOS 或 Linux 上生成基于云的新式 Web 应用。 ASP.NET Core 中的日志记录 .NET 通过 ILogger API 支持高性能结构化日志记录,以帮助监视应用程序行为和诊断问题。 可以通过配置不同的记录提供程…...
从零实现富文本编辑器#5-编辑器选区模型的状态结构表达
先前我们总结了浏览器选区模型的交互策略,并且实现了基本的选区操作,还调研了自绘选区的实现。那么相对的,我们还需要设计编辑器的选区表达,也可以称为模型选区。编辑器中应用变更时的操作范围,就是以模型选区为基准来…...
java 实现excel文件转pdf | 无水印 | 无限制
文章目录 目录 文章目录 前言 1.项目远程仓库配置 2.pom文件引入相关依赖 3.代码破解 二、Excel转PDF 1.代码实现 2.Aspose.License.xml 授权文件 总结 前言 java处理excel转pdf一直没找到什么好用的免费jar包工具,自己手写的难度,恐怕高级程序员花费一年的事件,也…...
【大模型RAG】Docker 一键部署 Milvus 完整攻略
本文概要 Milvus 2.5 Stand-alone 版可通过 Docker 在几分钟内完成安装;只需暴露 19530(gRPC)与 9091(HTTP/WebUI)两个端口,即可让本地电脑通过 PyMilvus 或浏览器访问远程 Linux 服务器上的 Milvus。下面…...
1688商品列表API与其他数据源的对接思路
将1688商品列表API与其他数据源对接时,需结合业务场景设计数据流转链路,重点关注数据格式兼容性、接口调用频率控制及数据一致性维护。以下是具体对接思路及关键技术点: 一、核心对接场景与目标 商品数据同步 场景:将1688商品信息…...
dedecms 织梦自定义表单留言增加ajax验证码功能
增加ajax功能模块,用户不点击提交按钮,只要输入框失去焦点,就会提前提示验证码是否正确。 一,模板上增加验证码 <input name"vdcode"id"vdcode" placeholder"请输入验证码" type"text&quo…...
04-初识css
一、css样式引入 1.1.内部样式 <div style"width: 100px;"></div>1.2.外部样式 1.2.1.外部样式1 <style>.aa {width: 100px;} </style> <div class"aa"></div>1.2.2.外部样式2 <!-- rel内表面引入的是style样…...
Rust 异步编程
Rust 异步编程 引言 Rust 是一种系统编程语言,以其高性能、安全性以及零成本抽象而著称。在多核处理器成为主流的今天,异步编程成为了一种提高应用性能、优化资源利用的有效手段。本文将深入探讨 Rust 异步编程的核心概念、常用库以及最佳实践。 异步编程基础 什么是异步…...
Spring AI 入门:Java 开发者的生成式 AI 实践之路
一、Spring AI 简介 在人工智能技术快速迭代的今天,Spring AI 作为 Spring 生态系统的新生力量,正在成为 Java 开发者拥抱生成式 AI 的最佳选择。该框架通过模块化设计实现了与主流 AI 服务(如 OpenAI、Anthropic)的无缝对接&…...
鸿蒙DevEco Studio HarmonyOS 5跑酷小游戏实现指南
1. 项目概述 本跑酷小游戏基于鸿蒙HarmonyOS 5开发,使用DevEco Studio作为开发工具,采用Java语言实现,包含角色控制、障碍物生成和分数计算系统。 2. 项目结构 /src/main/java/com/example/runner/├── MainAbilitySlice.java // 主界…...
