赞
踩
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实现服务暴露:
然后&
赞
踩
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。