欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

教你在Spring Boot微服務(wù)中集成gRPC通訊的方法

 更新時(shí)間:2021年09月09日 10:44:35   作者:麥神-mirson  
這篇文章主要介紹了教你在Spring Boot微服務(wù)中集成gRPC通訊的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

一、首先聲明gRPC接口

這里引入的是最新的gRpc-core 1.37版本, 采用的grcp-spring-boot-starter封裝的版本進(jìn)行實(shí)現(xiàn),github地址:

https://github.com/yidongnan/grpc-spring-boot-starter

要實(shí)現(xiàn)gRpc通訊, 先定義接口以及入?yún)⒊鰠⑿畔?/p>

syntax = "proto3";

option java_multiple_files = true;
option java_package = "com.grpc.spring.api.order";
option java_outer_classname = "OrderServiceProto";

// The service definition.
service OrderService {
    // The service method
    rpc GetOrderInfo (GetOrderRequest) returns (GetOrderReply) {
    }
}

// The request message
message GetOrderRequest {
    string orderNo = 1;
}

// The response message
message GetOrderReply {
    string orderNo = 1;
    string userName = 2;
    string address = 3;
    int64 price = 4;
}

定義好之后, 就需要通過(guò)protoc工具,生成對(duì)應(yīng)的JAVA代碼。

為便于使用, 這里封裝了bat腳本,并提供了對(duì)應(yīng)的protoc執(zhí)行程序。

@echo off
for %%i in (proto/*.proto) do (
  d:/TestCode/protoc.exe --plugin=protoc-gen-grpc-java=d:/TestCode/protoc-grpc.exe --java_out=../java --grpc-java_out=../java ./proto/%%i
  echo generate %%i to java file successfully!
)

該腳本意思, 會(huì)掃描當(dāng)前proto目錄下的所有proto腳本文件, 通過(guò)protoc-grpc插件, 在指定目錄下生成gRpc通訊接口的JAVA代碼。

生成后的JAVA代碼

file

執(zhí)行成功后, 會(huì)生成GPRC通訊接口, 入?yún)⒑统鰠⑿畔ⅰ?/p>

二、如何在服務(wù)端集成gRPC

首先整理配置好POM依賴,這里將共用的依賴抽取到父級(jí)POM文件中。

父級(jí)POM依賴:

<dependencies>
    <dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>javax.servlet-api</artifactId>
        <version>3.1.0</version>
    </dependency>
    <!-- spring boot grpc 依賴 -->
    <dependency>
        <groupId>net.devh</groupId>
        <artifactId>grpc-spring-boot-starter</artifactId>
        <version>${gprc.spring.version}</version>
    </dependency>
    <!-- jackson -->
    <dependency>
        <groupId>com.fasterxml.jackson.core</groupId>
        <artifactId>jackson-databind</artifactId>
        <version>${jackson.verson}</version>
    </dependency>
    <dependency>
        <groupId>com.fasterxml.jackson.core</groupId>
        <artifactId>jackson-core</artifactId>
        <version>${jackson.verson}</version>
    </dependency>
    <dependency>
        <groupId>com.fasterxml.jackson.core</groupId>
        <artifactId>jackson-annotations</artifactId>
        <version>${jackson.verson}</version>
    </dependency>
    <!-- lombok 插件, 簡(jiǎn)化開(kāi)發(fā)代碼 -->
    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
        <optional>true</optional>
        <version>1.18.8</version>
    </dependency>
</dependencies>

<dependencyManagement>
    <dependencies>
        <dependency>
            <groupId>com.grpc.spring</groupId>
            <artifactId>grpc-spring-api</artifactId>
            <version>${grpc.api.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-parent</artifactId>
            <version>${spring.boot.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <version>${spring.boot.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-dependencies</artifactId>
            <version>2020.0.2</version>
        </dependency>
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-alibaba-dependencies</artifactId>
            <version>2021.1</version>
        </dependency>
    </dependencies>
</dependencyManagement>

服務(wù)端POM配置

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>net.devh</groupId>
        <artifactId>grpc-server-spring-boot-starter</artifactId>
        <version>${gprc.spring.version}</version>
    </dependency>
    <dependency>
        <groupId>com.grpc.spring</groupId>
        <artifactId>grpc-spring-api</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        <version>3.0.2</version>
        <exclusions>
            <exclusion>
                <artifactId>servlet-api</artifactId>
                <groupId>javax.servlet</groupId>
            </exclusion>
        </exclusions>
    </dependency>
</dependencies>   

作為服務(wù)端, 需要加入gRpc服務(wù)端的依賴grpc-server-spring-boot-starter, 同時(shí)引入eureka, 可以實(shí)現(xiàn)微服務(wù)之間的調(diào)用以及負(fù)載。

服務(wù)端接口實(shí)現(xiàn)

這里為作測(cè)試驗(yàn)證, 定義個(gè)訂單服務(wù)接口, GrpcOrderService:

/**
 * 訂單服務(wù)接口實(shí)現(xiàn)
 */
@GrpcService
public class GrpcOrderService extends OrderServiceGrpc.OrderServiceImplBase {

    @Value("${server.port}")
    private String serverPort;

    @Override
    public void getOrderInfo(GetOrderRequest request, StreamObserver<GetOrderReply> responseObserver) {
        GetOrderReply reply =GetOrderReply.newBuilder().setOrderNo(request.getOrderNo())
                .setAddress("廣東省深圳市,端口號(hào)" + serverPort)
                .setUserName("tester")
                .setPrice(System.currentTimeMillis())
                .build();
        responseObserver.onNext(reply);
        responseObserver.onCompleted();
    }
}

要實(shí)現(xiàn)gRpc服務(wù)端接口, 必須做聲明, 采用@GrpcService注解, 然后繼承g(shù)Rpc生成的接口OrderServiceGrpc,重新getOrderInfo獲取訂單信息接口, 實(shí)現(xiàn)具體的處理邏輯。

服務(wù)端的配置

application.yml

server:
  port: 18082
spring:
  application:
    name: grpc-spring-server
grpc:
  server:
    port: 0
eureka:
  instance:
    prefer-ip-address: true
  client:
    register-with-eureka: true
    fetch-registry: false
    service-url:
      defaultZone: http://${eureka.instance.hostname:eureka.kyeapi.com}:${eureka.server.port:18761}/eureka/

服務(wù)端的gRpc端口配置為0代表隨機(jī)分配, gRpc服務(wù)信息會(huì)注冊(cè)至eureka。

三、 如何在客戶單集成gRPC:

客戶端的POM依賴配置

<dependencies>
    <dependency>
        <groupId>com.grpc.spring</groupId>
        <artifactId>grpc-spring-api</artifactId>
    </dependency>
    <dependency>
        <groupId>net.devh</groupId>
        <artifactId>grpc-client-spring-boot-starter</artifactId>
        <version>${gprc.spring.version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        <version>3.0.2</version>
    </dependency>

    <!-- 添加 Spring Boot 依賴 -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>

    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        <version>3.0.2</version>
        <exclusions>
            <exclusion>
                <artifactId>servlet-api</artifactId>
                <groupId>javax.servlet</groupId>
            </exclusion>
        </exclusions>
    </dependency>
</dependencies>

加入提供的客戶端依賴grpc-client-spring-boot-starter,這里注意,添加的eureka-client依賴, 要排除servlet-api, 以免啟動(dòng)沖突。

客戶端調(diào)用實(shí)現(xiàn)

GrpcOrderClientService:

/**
 *  訂單信息獲取客戶端接口
 */
@Service
@Log4j2
public class GrpcOrderClientService {

    @GrpcClient("grpc-server")
    private OrderServiceGrpc.OrderServiceBlockingStub orderServiceBlockingStub;

    /**
     * 獲取訂單信息
     * @param orderNo
     * @return
     */
    public String getOrderInfo(String orderNo) {
        try {
            //將遠(yuǎn)程調(diào)用的Grpc服務(wù)端接口信息, 返回給客戶端。
            GetOrderRequest request  = GetOrderRequest.newBuilder().setOrderNo(orderNo).build();
            final GetOrderReply response = orderServiceBlockingStub.getOrderInfo(request);
            String result = "orderNo: " + response.getOrderNo() + ", userName: " + response.getUserName() + ", address: " + response.getAddress();
            return result;
        }catch (Exception e) {
            log.error(e.getMessage(), e);
            return "error! " + e.getMessage();
        }
    }
}

這里通過(guò)@GrpcClient注解, 引入gRpc接口,這里的gRpc服務(wù)端名稱grpc-server要與配置文件的名稱保持一致。

客戶端配置

application.yml

server:
  port: 18080
spring:
  application:
    name: grpc-spring-client
grpc:
  client:
    grpc-server:
      address: 'discovery:///grpc-spring-server'
      enableKeepAlive: true
      keepAliveWithoutCalls: true
      negotiationType: plaintext
eureka:
  instance:
    prefer-ip-address: true
    status-page-url-path: /actuator/info
    health-check-url-path: /actuator/health
  client:
    register-with-eureka: false
    fetch-registry: true
    service-url:
      defaultZone: http://${eureka.instance.hostname:eureka.kyeapi.com}:${eureka.server.port:18761}/eureka/

這里定義了一個(gè)gRpc的連接信息grpc-server,與前面注解的名稱保持一致, adress要配置gRpc服務(wù)端的名稱, 不需要配置具體的IP和端口,會(huì)通過(guò)eureka來(lái)拉取服務(wù)端的具體連接信息。

四、 測(cè)試驗(yàn)證

啟動(dòng)服務(wù)

啟動(dòng)Eureka服務(wù)、gRpc服務(wù)端與客戶端,為便于測(cè)試負(fù)載, 這里啟動(dòng)兩個(gè)服務(wù)端實(shí)例, 端口號(hào)分別為18081與108082。

調(diào)用驗(yàn)證

第一調(diào)用:

file

第二次調(diào)用:

file

可以看到, 能夠正常調(diào)用gRpc服務(wù)接口, 同時(shí)gRpc也是可以支持負(fù)載均衡。

最后, 需要的完整的源碼, 可以從以下鏈接獲?。?/p>

http://xiazai.jb51.net/202109/yuanma/grpcv_jb51.rar

到此這篇關(guān)于教你在Spring Boot微服務(wù)中集成gRPC通訊的方法的文章就介紹到這了,更多相關(guān)Spring Boot集成gRPC微服務(wù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 解決idea中yml文件圖標(biāo)問(wèn)題及自動(dòng)提示失效的情況

    解決idea中yml文件圖標(biāo)問(wèn)題及自動(dòng)提示失效的情況

    這篇文章主要介紹了解決idea中yml文件圖標(biāo)問(wèn)題及自動(dòng)提示失效的情況,具有很好的價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-01-01
  • 詳解Java程序啟動(dòng)時(shí)-D指定參數(shù)是什么

    詳解Java程序啟動(dòng)時(shí)-D指定參數(shù)是什么

    java服務(wù)啟動(dòng)的時(shí)候,都會(huì)指定一些參數(shù),下面這篇文章主要給大家介紹了關(guān)于Java程序啟動(dòng)時(shí)-D指定參數(shù)是什么的相關(guān)資料,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2022-12-12
  • 深入介紹Java對(duì)象初始化

    深入介紹Java對(duì)象初始化

    本文對(duì)Java如何執(zhí)行對(duì)象的初始化做一個(gè)詳細(xì)深入地介紹。有需要的小伙伴們可以參考。
    2016-07-07
  • Java深度復(fù)制功能與用法實(shí)例分析

    Java深度復(fù)制功能與用法實(shí)例分析

    這篇文章主要介紹了Java深度復(fù)制功能與用法,簡(jiǎn)單講述了深度復(fù)制的概念、功能并結(jié)合實(shí)例形式分析了java實(shí)現(xiàn)深度復(fù)制的具體操作技巧,需要的朋友可以參考下
    2018-01-01
  • Java使用Gateway自定義負(fù)載均衡過(guò)濾器

    Java使用Gateway自定義負(fù)載均衡過(guò)濾器

    這篇文章主要介紹了Java使用Gateway自定義負(fù)載均衡過(guò)濾器,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • kotlin改善java代碼實(shí)例分析

    kotlin改善java代碼實(shí)例分析

    我們給大家整理了關(guān)于kotlin改善java代碼的相關(guān)實(shí)例以及操作的詳細(xì)方法,有需要的讀者們參考下。
    2018-03-03
  • Java中的Optional處理方法

    Java中的Optional處理方法

    在我們?nèi)粘5拈_(kāi)發(fā)中,我們經(jīng)常會(huì)遇到?NullPointerException,如何才能優(yōu)雅的處理NPE?這里告訴大家一個(gè)較為流行的方法,這篇文章主要介紹了Java中的Optional處理方法,需要的朋友可以參考下
    2022-09-09
  • SpringBoot啟動(dòng)并初始化執(zhí)行sql腳本問(wèn)題

    SpringBoot啟動(dòng)并初始化執(zhí)行sql腳本問(wèn)題

    這篇文章主要介紹了SpringBoot啟動(dòng)并初始化執(zhí)行sql腳本問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • springboot驗(yàn)證碼的生成與驗(yàn)證的兩種方法

    springboot驗(yàn)證碼的生成與驗(yàn)證的兩種方法

    本文主要介紹了springboot驗(yàn)證碼的生成與驗(yàn)證的兩種方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06
  • Hadoop使用hdfs指令查看hdfs目錄的根目錄顯示被拒的原因及解決方案

    Hadoop使用hdfs指令查看hdfs目錄的根目錄顯示被拒的原因及解決方案

    這篇文章主要介紹了Hadoop使用hdfs指令查看hdfs目錄的根目錄顯示被拒的原因及解決方案,分布式部署hadoop,服務(wù)機(jī)只有namenode節(jié)點(diǎn),主機(jī)包含其他所有節(jié)點(diǎn),本文給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-10-10

最新評(píng)論