一般方式
通过protoc.exe在命令行生成java代码,然后将java代码copy到项目中。
缺点:
- 当proto进行变化时,需要再次生成
- 生成的java代码中因为兼容性,很多新的java特性没有如 @Override,IDE中会提示错误. 有洁癖的很难受。
通过maven构建模块,每次编译动态生成
- maven配置
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
<grpc.version>1.22.1</grpc.version>
<protobuf.version>3.7.1</protobuf.version>
</properties>
<dependencies>
<dependency>
<groupId>io.grpc</groupId>
<artifactId>grpc-netty</artifactId>
<version>${grpc.version}</version>
</dependency>
<dependency>
<groupId>io.grpc</groupId>
<artifactId>grpc-protobuf</artifactId>
<version>${grpc.version}</version>
</dependency>
<dependency>
<groupId>io.grpc</groupId>
<artifactId>grpc-stub</artifactId>
<version>${grpc.version}</version>
</dependency>
<dependency>
<groupId>com.google.protobuf</groupId>
<artifactId>protobuf-java</artifactId>
<version>${protobuf.version}</version>
</dependency>
</dependencies>
<build>
<extensions>
<extension>
<groupId>kr.motd.maven</groupId>
<artifactId>os-maven-plugin</artifactId>
<version>1.5.0.Final</version>
</extension>
</extensions>
<plugins>
<!-- grpc 生成后就可以注释掉了-->
<plugin>
<groupId>org.xolstice.maven.plugins</groupId>
<artifactId>protobuf-maven-plugin</artifactId>
<version>0.5.1</version>
<configuration>
<protocArtifact>com.google.protobuf:protoc:${protobuf.version}:exe:${os.detected.classifier}
</protocArtifact>
<pluginId>grpc-java</pluginId>
<pluginArtifact>io.grpc:protoc-gen-grpc-java:${grpc.version}:exe:${os.detected.classifier}
</pluginArtifact>
</configuration>
<executions>
<execution>
<goals>
<goal>compile</goal>
<goal>compile-custom</goal>
</goals>
</execution>
</executions>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
</plugins>
</build>
- example proto
syntax = "proto3";
package msg_proxy;
option java_package = "xxx";
option java_outer_classname = "GrpcService";
message Msg {
//client-side send
string SecretId = 1; //用户申请appid对应的secret_id,用作签名
}
message Filter {
string Key = 1;
string Value = 2;
string Op = 3;
}
service MsgReadProxy {
rpc ReadTopic(stream Msg) returns (stream Msg) {}
rpc ReadSubscribeTopic(stream Msg) returns (stream Msg) {}
}
service MsgWriteProxy {
rpc WriteTopic(stream Msg) returns (Msg) {}
}
通过模块引入的方式引入即可
or deploy到服务器