三天三夜总算是搞懂了RPC远程过程调用,SpringCloud集成gRPC

本文介绍了如何将gRPC与Spring Cloud集成,重点讲解了grpc-spring-boot-starter项目,包括服务定义、服务端和客户端实现。gRPC使用HTTP 2协议,ProtoBuf作为接口定义语言,支持多语言,具有高性能和跨平台特性。此外,还解析了gRPC服务调用的过程和核心概念。
摘要由CSDN通过智能技术生成

Spring Cloud集成gRPC

gRPC本身的跨平台特性及性能上的优势都促使很多大公司采用gRPC的RPC解决方案作为微服务交互的标准交互集成方式。

到目前为止,Spring Cloud官方并没有支持gRPC,但是在GitHub上有非常多的第三方开源项目支持gRPC与Spring Cloud的集成,start数 目 最 多 的 开 源 项 目 是 grpc-spring-boot-starter 。 该 项 目 也 是Spring Cloud社区推荐的gRPC项目。下面是这个项目的主要特性:

● 在Spring Boot应用中,通过@GrpcService自动配置并运行一个嵌入式的gRPC服务。

● 使用@GrpcClient自动创建和管理gRPC通道(Channels)和桩代码(Stub)。

● 支持Spring Sleuth作为分布式链路跟踪解决方案。

● 支持全局和自定义的gRPC服务端/客户端拦截器。

● 支持Spring Security。

● 支持Metric(基于micrometer/actuator)。

● 适用于(non-shaded)grpc-netty。

Spring Boot中gRPC的接入gRPC接入Spring Cloud主要分为三个工程模块,即服务定义模块、服务提供模块和服务消费模块。下面是接入gRPC的主要步骤。

1.服务定义

和其他RPC框架类似,gRPC需要做接口定义规范,默认情况下,会使用Protocal Buffers作为接口定义语言(IDL)。

首先,引入Maven依赖:

然后,编写一个.proto文件,定义好服务端的请求数据和响应数据,执行mvn clean install命令,protobuf-maven-plugin插件会根据.proto文件生成对应的Java代码,Maven的install命令会将接口工程打包上传到代码中央仓库,服务端和客户端可以通过Maven将远程中央 仓 库 加 载 到 本 地 并 打 包 到 各 自 的 工 程 中 。 下 面 是 IDL 的 定 义(demo.proto):

2.gRPC Server实现

首先,引入Maven依赖:

其次,使用注解@GrpcService实现服务暴露:

然后

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值