当前位置:   article > 正文

三天三夜总算是搞懂了RPC远程过程调用,SpringCloud集成gRPC_下篇文章给大家讲解的内容是rpc远程过程调用,spring cloud集成grpc

下篇文章给大家讲解的内容是rpc远程过程调用,spring cloud集成grpc

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实现服务暴露:

然后&

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/繁依Fanyi0/article/detail/146007
推荐阅读
相关标签
  

闽ICP备14008679号