最近加班加点一个spring-boot的分布式项目,项目中的其中一个难点就是grpc.现在记录下来,以后可以用的到.
废话少说,直接上步骤:
1.导入jar包
<dependency> <groupId>net.devh</groupId> <artifactId>grpc-server-spring-boot-starter</artifactId> <version>1.2.0.RELEASE</version> </dependency> <dependency> <groupId>io.grpc</groupId> <artifactId>grpc-core</artifactId> <version>1.2.0</version> </dependency> <!-- https://mvnrepository.com/artifact/io.grpc/grpc-stub --> <dependency> <groupId>io.grpc</groupId> <artifactId>grpc-stub</artifactId> <version>1.2.0</version> </dependency> <!-- https://mvnrepository.com/artifact/io.grpc/grpc-netty --> <dependency> <groupId>io.grpc</groupId> <artifactId>grpc-netty</artifactId> <version>1.2.0</version> </dependency> <!-- https://mvnrepository.com/artifact/io.grpc/grpc-protobuf --> <dependency> <groupId>io.grpc</groupId> <artifactId>grpc-protobuf</artifactId> <version>1.2.0</version> </dependency>
2.导入插件
<plugin> <groupId>org.xolstice.maven.plugins</groupId> <artifactId>protobuf-maven-plugin</artifactId> <version>0.5.0</version> <configuration> <!-- The version of protoc must match protobuf-java. If you don't depend on protobuf-java directly, you will be transitively depending on the protobuf-java version that grpc depends on. --> <protocArtifact>com.google.protobuf:protoc:3.2.0:exe:${os.detected.classifier}</protocArtifact> <pluginId>grpc-java</pluginId> <pluginArtifact>io.grpc:protoc-gen-grpc-java:0.15.0:exe:${os.detected.classifier}</pluginArtifact> </configuration> <executions> <execution> <goals> <goal>compile</goal> <goal>compile-custom</goal> </goals> </execution> </executions> </plugin>
1.建立proto文件夹,新建.proto文件,默认配置下文件夹必须建在这一层级
2.在上一步建立好的proto文件夹里新建.proto文件,写需要的方法
syntax = "proto3";
option java_multiple_files = true;
package com.sxy.service;
service Greeter {
rpc getOrderRate(EmpOrderRateRequest) returns (EmpOrderRateReponse){}
}
message EmpOrderRateRequest {
string orderId = 1;
}
message EmpOrderRateReponse{
int32 rateStar = 1;
string memberRate = 2;
string image = 3;
}
3.调出maven插件,搜索maven projects,选择maven projects插件,点开plugins
选择插件
选择protobuf插件
点击protobuf:compile ,绿色三角形执行
在target生成java文件夹
点击protobuf:compile-custom ,绿色三角形执行
在target生成grpc-java文件夹
到这文件都生成了,就取来用就好了