maven?grpc整合springboot?demo
1. 說明
GRPC基于protobuf來定義接口。分為server端和client端。其中server端提供接口實(shí)現(xiàn),client通過調(diào)用server端接口從而獲取期望數(shù)據(jù)。
2. 公共部分
2.1 添加依賴
<dependency>
<groupId>net.devh</groupId>
<artifactId>grpc-spring-boot-starter</artifactId>
<version>2.12.0.RELEASE</version>
</dependency>
<dependency>
<!-- Java 9+ compatibility -->
<groupId>javax.annotation</groupId>
<artifactId>javax.annotation-api</artifactId>
</dependency>
添加插件(注意:如果wagon-provider-api無法自動(dòng)引入,可以現(xiàn)在依賴中引入,以便于依賴的下載,然后在刪除依賴坐標(biāo)即可)
<plugin>
<!-- protobuf生成插件-->
<groupId>org.xolstice.maven.plugins</groupId>
<artifactId>protobuf-maven-plugin</artifactId>
<version>0.6.1</version>
<configuration>
<protocArtifact>com.google.protobuf:protoc:3.17.3:exe:${os.detected.classifier}
</protocArtifact>
<pluginId>grpc-java</pluginId>
<pluginArtifact>io.grpc:protoc-gen-grpc-java:1.39.0:exe:${os.detected.classifier}
</pluginArtifact>
<!--默認(rèn)值-->
<protoSourceRoot>${project.basedir}/src/main/proto</protoSourceRoot>
<outputDirectory>${project.basedir}/src/main/java</outputDirectory>
<clearOutputDirectory>false</clearOutputDirectory>
</configuration>
<executions>
<execution>
<goals>
<goal>compile</goal>
<goal>compile-custom</goal>
</goals>
</execution>
</executions>
</plugin>
2.2 添加proto依賴文件
添加目錄src/main/proto,并將目錄設(shè)置為Source Root,然后在目錄src/main/proto下添加文件hello.proto,內(nèi)容如下
syntax = "proto3"; //指定proto版本
package com.server;
// 生成的Java代碼的包名
option java_package = "com.grpc.server";
// 請(qǐng)求參數(shù)
message HelloReq{
string name = 1;
}
// 返回參數(shù)
message HelloResp{
string ret = 1;
}
// rpc service
service HelloService{
// service中需要進(jìn)行調(diào)用的具體方法
rpc hello(HelloReq) returns (HelloResp){}
}
2.3 通過protobuf生成Java代碼
插件導(dǎo)入成功后,點(diǎn)擊下圖選中的protobuf:compile和protbuf:compile-custom 依次生成對(duì)應(yīng)的Java代碼(也就是接口依賴代碼)

3. server端接口具體實(shí)現(xiàn)
service代碼如下
import io.grpc.stub.StreamObserver;
import net.devh.boot.grpc.server.service.GrpcService;
@GrpcService
public class HelloService extends HelloServiceGrpc.HelloServiceImplBase {
@Override
public void hello(Hello.HelloReq request, StreamObserver<Hello.HelloResp> responseObserver) {
Hello.HelloResp resp = Hello.HelloResp.newBuilder().setRet("你好-->"+request.getName()).build();
responseObserver.onNext(resp);
responseObserver.onCompleted();
}
}
4 client端接口具體實(shí)現(xiàn)
client端測試調(diào)用代碼如下
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
@SpringBootTest
public class GrpcTest {
@Autowired
private HelloSerivce helloSerivce;
@Test
public void test1() throws Exception{
helloSerivce.haha("牛哈哈");
}
}
以上就是maven grpc整合springboot demo的詳細(xì)內(nèi)容,更多關(guān)于maven grpc整合springboot 的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
詳解JAVA如何實(shí)現(xiàn)樂觀鎖以及CAS機(jī)制
悲觀鎖和樂觀鎖其實(shí)本質(zhì)都是一種思想,在JAVA中對(duì)于悲觀鎖的實(shí)現(xiàn)大家可能都很了解,可以通過synchronized、ReentrantLock加鎖實(shí)現(xiàn),本文不展開講解了。那么樂觀鎖在JAVA中是如何實(shí)現(xiàn)的呢?底層的實(shí)現(xiàn)機(jī)制又是什么呢?本文就來和大家詳細(xì)講講2022-12-12
springboot 實(shí)現(xiàn)Http接口加簽、驗(yàn)簽操作方法
這篇文章主要介紹了springboot 實(shí)現(xiàn)Http接口加簽、驗(yàn)簽操作,服務(wù)之間接口調(diào)用,通過簽名作為安全認(rèn)證來保證API的安全性,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2023-09-09
Java中ThreadLocal避免內(nèi)存泄漏的方法詳解
ThreadLocal是Java中的一個(gè)線程本地存儲(chǔ)機(jī)制,它允許每個(gè)線程擁有一個(gè)獨(dú)立的本地存儲(chǔ)空間,用于存儲(chǔ)該線程的變量,本文主要介紹了ThreadLocal如何避免內(nèi)存泄漏,需要的朋友可以參考下2023-05-05
一文帶你深入理解Java?AbstractQueuedSynchronizer
在并發(fā)編程中,鎖是一種保證線程安全的方式,這篇文章主要為大家介紹了AbstractQueuedSynchronizer(AQS)的數(shù)據(jù)結(jié)構(gòu)及實(shí)現(xiàn)原理,感興趣的小伙伴可以了解一下2023-07-07
SpringBoot整合chatGPT的項(xiàng)目實(shí)踐
本文主要介紹了SpringBoot整合chatGPT的項(xiàng)目實(shí)踐,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-03-03

