gRPC 快速入门 — SpringBoot 实现(1)

目录

一、什么是 RPC 框架 ?

二、什么是 gRPC 框架 ?

三、传统 RPC 与 gRPC 对比

四、gRPC 的优势和适用场景

五、gRPC 在分布式系统中应用场景

六、什么是 Protocol Buffers(ProtoBuf)?

特点

使用场景

简单的使用模拟

七、写一个gRPC 服务的基本流程

①、定义服务和消息

②、生成代码

③、实现服务接口

④、创建 gRPC 服务器

⑤、创建 gRPC 客户端


一、什么是 RPC 框架 ?

  RPC(Remote Procedure Call)描绘了ClientServer之间点对点调用流程,包括stub、通信、RPC消息解析等部分,实际应用中,还需要考虑服务的高可用、负载均衡等问题,所以产品级的RPC框架除了点对点的RPC协议具体实现外,还包括服务的发现与注销、提供服务多台Server的负载均衡、服务的高可用等更多功能。

目前RPC框架大致有两种不同的侧重方向,一种偏重于服务治理,另一种偏重于跨语言调用。

服务治理型RPC框架有:DubboDubboXMotan等,这类RPC框架的特点是功能丰富,提供高性能的远程调用以及服务发现及治理功能,适用于大型服务的微服务化拆分以及管理,对于特定语言(如Java)的项目可以十分友好的透明化接入。但缺点是语言耦合度较高,跨语言支持难度较大。

跨语言调用型RPC框架有:ThriftgRPCHessianHprose等,这一类RPC框架重点关注于服务跨语言调用,能够支持大部分的语言进行语言无关的调用,非常适合于为不同语言提供通用远程服务的场景。但这类框架没有服务发现相关机制,实际使用时一般需要代理层进行请求转发和负载均衡策略控制。

二、什么是 gRPC 框架 ?

        gRPC 是一种高性能、开源的远程过程调用(RPC)框架。它允许分布在不同计算机上的应用程序能够像调用本地方法一样进行通信,从而实现了在分布式系统中进行高效的通信。

三、传统 RPC 与 gRPC 对比

        传统的 RPC 模型使用各种协议和编码方式进行通信,这可能导致跨语言通信困难、性能不佳等问题。与此不同,gRPC 使用 Google 开发的 Protocol Buffers(ProtoBuf)进行数据序列化,同时基于 HTTP/2 协议进行通信,从而提供了更高效的通信方式。

四、gRPC 的优势和适用场景

  • 高性能: gRPC 使用二进制的 ProtoBuf 编码和 HTTP/2 多路复用等技术,从而实现低延迟和高吞吐量的通信。

  • 多语言支持: gRPC 支持多种编程语言,包括 Java、Python、Go 等,使得不同团队可以选择自己擅长的语言进行开发。

  • 强类型: 使用 ProtoBuf 定义消息和接口,消除了手动解析数据的麻烦。

  • 双向流式通信: gRPC 支持双向流式数据传输,适用于实时性要求高的场景。

  • 自动代码生成: 根据定义的服务接口和消息,gRPC 可以自动生成客户端和服务端代码,简化开发流程。

五、gRPC 在分布式系统中应用场景

  • 微服务通信: gRPC 适用于微服务架构中各个服务之间的通信,能够有效减少通信开销。

  • 跨数据中心通信: gRPC 的性能优势使其适用于跨多个数据中心进行通信,提供更好的用户体验。

  • 实时通信: 借助双向流式通信,gRPC 适合实时通信场景,如聊天应用和实时数据推送。

  • 通过了解 gRPC 的基本概念、与传统 RPC 的不同之处以及它在分布式系统中的优势,你将能够更好地理解为什么 gRPC 是一个值得学习和应用的强大工具。

六、什么是 Protocol Buffers(ProtoBuf)?

        Protocol Buffers(简称Protobuf)是由Google开发的一种用于数据序列化技术。与传统的XMLJSON相比,Protobuf具有更高的性能和更小的消息体积,特别适用于需要高效数据交换的场景。

        初由 Google 开发,用于解决跨平台、跨语言通信以及数据持久化的问题。ProtoBuf 使用简单的接口描述语言来定义数据结构和服务接口,并生成相应代码用于数据的序列化和反序列化。在 gRPC 中,使用 Protocol Buffers(ProtoBuf)进行数据传输非常简单,因为 gRPC 针对 ProtoBuf 提供了内置支持。

protoc 是 protobuf 定义数据结构的一种格式,用.proto后缀的文件保存,使用proto编译器可以把对应的proto结构编译为各目标语言的序列化与反序列化代码库

特点

  1. 速度快Protobuf在序列化与反序列化数据时速度极快
  2. 占空间小Protobuf序列化后的二进制数据非常小,可节省大量的存储和带宽
  3. 跨平台Protobuf支持多种编程语言(常见的几乎都支持),兼容性好
  4. 易扩展:使用.proto文件定义数据结构(包括字段类型、默认值和验证规则等),添加新内容时,也可以轻松做到,不会破坏现有系统
  5. 简单易用:只需专注.proto数据结构文件的编写,对应的序列化与反序列化代码可自动生成

使用场景

  • 分布式系统:各服务之间需要频繁地进行数据交换,Protobuf可以显著提高通信效率
  • 存储和持久化Protobuf能节省很多存储空间,常用于日志记录、配置文件和数据持久化
  • 移动应用:在网络带宽和存储空间有限的情况下,Protobuf能更好地提高性能

protobuf使用非常广泛,如很多平台的视频、直播间弹幕流即是使用这种技术传输,如有需要,还可对序列化消息进行gzip压缩,进一步减少消息体积,节省带宽,提高传输速度 。

Protocol Buffers 编译器 (protoc)在 Windows 中怎么安装

protoc下载地址:https://github.com/protocolbuffers/protobuf/releases

protoc编译js文档:JavaScript Generated Code | protobuf-javascript

protoc编译js插件下载地址:https://github.com/protocolbuffers/protobuf-javascript/releases

简单的使用模拟

  • 使用proto语法(规则)定义我们的数据结构,保存在.proto后缀的文件内

  • 使用proto编译器编译.proto文件,指定要编译成目标语言环境(JavaPython等)

    结果将会生成对应语言的一个代码文件(内包含对应数据序列化与反序列化相关操作的类或函数)
  • 接着使用生成的代码文件即可。

七、写一个gRPC 服务的基本流程

①、定义服务和消息

首先,你需要创建一个 .proto 文件来定义服务接口和消息类型。在这个文件中,你可以定义服务方法、请求消息和响应消息。这些定义将用于生成服务端和客户端的代码。

②、生成代码

使用 Protocol Buffers 编译器(protoc)来生成对应编程语言的代码

③、实现服务接口

在服务端,你需要创建一个类来实现定义的服务接口。这个类应该继承自生成的服务接口,并实现相应的方法。

④、创建 gRPC 服务器

在服务端代码中,你需要创建一个 gRPC 服务器,将服务实现类注册到服务器中。

⑤、创建 gRPC 客户端

在客户端,你可以使用生成的客户端代码来调用 gRPC 服务方法

至此,理论部分介绍完毕,后续将使用SpringBoot具体代码实现gRPC四种通信模式。

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

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

相关文章

工具篇--GitHub Desktop 使用

文章目录 前言一、GitHub Desktop 的使用:1.1 通过官网下载GitHub Desktop和安装:1.2 安装和使用:1.2.1 填充自己的标识:1.2.3 克隆项目:1.2.4 git 常用忽略项配置: 二、代码的更新和提交:2.1 代…

MySQL事物隔离级别详细解释

目录 事务隔离级别总结 实际情况演示 脏读(读未提交) 避免脏读(读已提交) 不可重复读 可重复读 幻读 解决幻读的方法 事务隔离级别总结 SQL 标准定义了四个隔离级别: READ-UNCOMMITTED(读取未提交) :最低的隔离级别,允许读取尚未提…

[每周一更]-(第126期):MQ解耦场景

消息队列(MQ)解耦是一种软件架构设计模式,主要通过中间件将系统中的生产者和消费者模块分离,减少模块之间的直接依赖,使系统具有更高的扩展性和灵活性。这种模式尤其适用于需要处理复杂业务逻辑、频繁请求或异步处理的…

Redis的高可用之哨兵模式

Redis哨兵主要是解决Redis主从同步时主数据库宕机问题,使其能够自动进行故障恢复,提高Redis系统的高可用性。 1. 哨兵的作用: 监控:哨兵通过心跳机制监控主库和从库的存活性。 选主:当主库宕机时,哨兵会选举出一个领…

知识分享|一文了解实时荧光定量PCR(qPCR)技术的原理与分类

实时荧光定量PCR技术(Realtime quantitative PCR,qPCR)是在PCR反应体系中添加荧光报告基团和荧光淬灭基团,通过荧光信号来实现对核酸分子的定量检测过程在反应过程中,PCR产物随着扩增反应的进行不断生成,荧光信号不断增加&#xf…

【MySQL】环境变量配置

环境变量英文名SystemRoot,直译为“系统总(根)目录",主要指明操作系统的重要目录在哪里。那么配置MySQL的环境变量,就是在程序运行时,告诉操作系统你的MySQL目录位置。 复制MySQL安装目录:…

高级 CEF 内核集成与 VC++——开发环境搭建与配置

开发环境的搭建是 CEF 浏览器开发中至关重要的一步。正确配置开发环境不仅能提高开发效率,也能确保开发过程中的稳定性与可靠性。本文将结合最新的资料和技术方案,深入讲解如何搭建 CEF 编译与配置环境,正确配置 Windows SDK 与依赖库&#x…

【React】组件通讯有哪几种方式?

文章目录 一、父子组件通讯二、兄弟组件通讯3、context 跨级组件通讯 提示:以下是本篇文章正文内容,下面案例可供参考 一、父子组件通讯 父组件 ----> 子组件: props 父组件提供要传递的 state 数据 给子组件标签添加属性,值…

huggingface-cli下载数据(含下载指定数据教程)

在国内,推荐使用:HF-Mirror 1.尝试下载大模型相关文件 在huggingface镜像首页,可以看到如图: 2.使用huggingface-cli下载文件 2.1 首先激活自己的虚拟环境,然后安装环境,使用如下命令: pip …

生产慎用之调试日志对空间矢量数据批量插入的性能影响-以MybatisPlus为例

目录 前言 一、一些缘由 1、性能分析 二、插入方式调整 1、批量插入的实现 2、MP的批量插入实现 3、日志的配置 三、默认处理方式 1、基础程序代码 2、执行情况 四、提升调试日志等级 1、在logback中进行设置 2、提升后的效果 五、总结 前言 在现代软件开发中&…

Linux下编译安装METIS

本文记录Linux下编译安装METIS的流程。 零、环境 操作系统Ubuntu 22.04.4 LTSVS Code1.92.1Git2.34.1GCC11.4.0CMake3.22.1 一、安装依赖 1.1 下载GKlib sudo apt-get install build-essential sudo apt-get install cmake 2.2 编译安装GKlib 下载GKlib代码, …

数据链路层总结

- - 链路、物理链路:两节点间物理线路(有线、无线),中间没有任何其他的交换节点 数据链路、逻辑链路: 链路 协议需要的硬件、软件 网络适配器(网卡):包含物理层、数据链路层 网络适配器软件驱动程…

基于Java和Vue开发的漫画阅读软件漫画阅读小程序漫画APP

前景分析 受众广泛:漫画的受众群体广泛,不仅限于青少年,还涵盖了成年人等多个年龄层和社会阶层。漫画文化在全球范围内的影响力不断扩大,未来漫画软件创业可以考虑全球市场的拓展。 市场需求大:数字化阅读趋势下&…

LoRa无线空调计费系统都应用在哪里

中央空调计费系统由于布线方式需要消耗大量的人力及成本,LoRa在楼宇自控及智能家居中的应用越来越广泛,成为当前普遍应用的通信技术。 LoRa模块无线传输技术的不断完善,逐步解决了温控器通信方面布线困难、施工成本高的问题,促进…

4.STM32通信接口之SPI通信---硬件SPI的介绍

上一节,我们学会软件的SPI,本节,我们将学习STM32的SPI硬件收发电路,虽然STM32的硬件收发电路很强大,但是,很多我们都用不到,我们只需会最基本的就可以。硬件的好处就是稳定,功能模块…

Open AI 推出 ChatGPT Pro

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗?订阅我们的简报,深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同,从行业内部的深度分析和实用指南中受益。不要错过这个机会,成为AI领…

洛谷P1030 [NOIP2001 普及组] 求先序排列(c嘎嘎)

题目链接:P1030 [NOIP2001 普及组] 求先序排列 - 洛谷 | 计算机科学教育新生态 题目难度:普及 解题思路:这道题和之前做过的一道题很像,举一反三就行 相似题目:P1827 [USACO3.4] 美国血统 American Heritage - 洛谷 |…

创意型广告如何配音梨花声音研修院退费

张弛播音5天训练营靠谱吗,在当今竞争激烈的广告市场中,创意型广告以其独特的构思和表现形式脱颖而出。而配音作为广告的重要组成部分,对于创意型广告的成功起着至关重要的作用。 在为创意型广告配音之前,首先要深入理解广告的创意…

探索 Python 应用的分层依赖:解决 UOS 环境中的 libvirt-python 安装问题

探索 Python 应用的分层依赖:解决 UOS 环境中的 libvirt-python 安装问题 背景Python 版本升级 问题描述原因分析与解决方案 Python 应用的分层依赖:安装与部署的视角libvirt-python的分层依赖尝试的解决方案 使用编译好的 .whl 文件"嫁接"整个…

SpringBoot+ENC实现密钥加密及使用原理

?? 作者: ?? 主页: https://blog.csdn.net/zhuocailing3390 ?? 社区: Java技术栈交流 ?? 主题: SpringBootENC实现密钥加密及使用原理 创作时间: 2024年06月23日 目录 前言1、整合SpringBoot 1.1、POM…