JAVA grpc調(diào)用方式

代碼已上傳代碼倉庫GITHUB:https://github.com/LynHB/ProjectA/tree/master/src/main/java/study/grpc

工具準(zhǔn)備

1.通過proto文件生成java類

命令:
[protobuf exe path] --java_out=[需要生成java的位置]

protoc.exe ./TestUser.proto --java_out=./

2.通過proto文件生成java grpc類

命令:
[protobuf exe path] --plugin=[protoc-gen-grpc-java exe path] --grpc-java_out=[需要生成java的位置] [proto文件位置]

D:\protobuf\bin\protoc --plugin=protoc-gen-grpc-java=D:\protobuf\bin\protoc-gen-grpc-java-1.30.2-windows-x86_64.exe --grpc-java_out=./ ./scheduler.proto

3 Java maven 依賴

<properties>
        <grpc.version>1.30.2</grpc.version>
    </properties>


    <dependencies>
        <dependency>
            <groupId>io.grpc</groupId>
            <artifactId>grpc-stub</artifactId>
            <version>${grpc.version}</version>
        </dependency>
        <dependency>
            <groupId>io.grpc</groupId>
            <artifactId>grpc-netty-shaded</artifactId>
            <version>${grpc.version}</version>
        </dependency>
        <dependency>
            <groupId>io.grpc</groupId>
            <artifactId>grpc-protobuf</artifactId>
            <version>${grpc.version}</version>
        </dependency>
    </dependencies>

4.Server端編寫

4.1 編寫protobuf文件

下面是定義一個簡單的protobuf grpc文件,service塊內(nèi)定義調(diào)用的function钥平,message定義的是結(jié)構(gòu)體。

syntax = "proto3";

// The greeting service definition.
service Greeter {
  // Sends a greeting
  rpc SayHello (HelloRequest) returns (HelloReply) {}
}

// The request message containing the user's name.
message HelloRequest {
  string name = 1;
}

// The response message containing the greetings
message HelloReply {
  string message = 1;
}

4.2 創(chuàng)建grpc和protobuf java類

先根據(jù)1和2生成對應(yīng)的實體和rpc服務(wù)類

cd D:\IDEAData\ProjectA1\src\main\java\study\grpc\proto\
D:\IDEAData\ProjectA1\src\main\java\study\grpc\proto>D:\protobuf\bin\protoc --plugin=protoc-gen-grpc-java=D:\protobuf\bin\protoc-gen-grpc-java-1.30.2-windows-x86_64.exe --grpc-java_out=./ Greeter.proto
D:\protobuf\bin\protoc --java_out=./ Greeter.proto

GreeterOuterClass和GreeterGrpc就是對應(yīng)命令生成的java文件。


文件目錄結(jié)構(gòu)

4.3 編寫GreeterServiceImpl

package study.grpc.service;

import io.grpc.stub.StreamObserver;
import study.grpc.pojo.GreeterOuterClass.*;
import study.grpc.rpc.GreeterGrpc;

/**
 * @Author LynHB
 * @Description : grpc實現(xiàn)接口
 * @Date 19:53 2020/7/29
 **/
public class GreeterServiceImpl extends GreeterGrpc.GreeterImplBase {
    @Override
    public void sayHello(HelloRequest req, StreamObserver<HelloReply> responseObserver) {
        HelloReply reply = HelloReply.newBuilder().setMessage("Hello " + req.getName()).build();
        responseObserver.onNext(reply);
        responseObserver.onCompleted();
    }
}

4.4 編寫Server入口類

package study.grpc;

import io.grpc.Server;
import io.grpc.ServerBuilder;
import lombok.extern.log4j.Log4j2;
import study.grpc.service.GreeterServiceImpl;

import java.io.IOException;
import java.util.concurrent.TimeUnit;

/**
 * @Author LynHB
 * @Description :g rpc server入口類
 * @Date 19:55 2020/7/29
 **/
@Log4j2
public class ServerMain {
    private final int port;
    private final Server server;

    public ServerMain(int port){
        this.port = port;
        /*
         * 創(chuàng)建Server
         * addService()添加對應(yīng)的服務(wù)
         * forPort()指定端口
         */
        this.server = ServerBuilder.forPort(port).addService(new GreeterServiceImpl()).build();
    }


    public void start() throws IOException{
        server.start();
        log.info("Started server listening on " + port);
        Runtime.getRuntime().addShutdownHook(new Thread(() -> {
            try {
                ServerMain.this.stop();
            } catch (InterruptedException e) {
                e.printStackTrace(System.err);
            }
            log.error("Server shut down.");
        }));
    }

    public void stop() throws InterruptedException{
        if(server != null){
            server.shutdown().awaitTermination(30,TimeUnit.SECONDS);
        }
    }

    private void blockUntilShutdown() throws InterruptedException {
        if (server != null) {
            server.awaitTermination();
        }
    }


    public static void main(String[] args) throws IOException, InterruptedException {
        ServerMain server = new ServerMain(10000);
        server.start();
        server.blockUntilShutdown();
    }
}

4.5 啟動Server

image.png

5.Client端編寫

package study.grpc;


import io.grpc.Channel;
import io.grpc.ManagedChannel;
import io.grpc.ManagedChannelBuilder;
import io.grpc.internal.ClientStream;
import lombok.extern.log4j.Log4j2;
import study.grpc.pojo.GreeterOuterClass.*;
import study.grpc.rpc.GreeterGrpc.*;

import java.util.concurrent.TimeUnit;

import static study.grpc.rpc.GreeterGrpc.newBlockingStub;

/**
 * @Author LynHB
 * @Description : g rpc 客戶端入口類
 * @Date 19:56 2020/7/29
 **/
@Log4j2
public class ClientMain {

    private final GreeterBlockingStub blockingStub;
    private final ManagedChannel managedChannel;


    public ClientMain(String ip,int port) {
        this.managedChannel = ManagedChannelBuilder.forTarget(ip+":"+port).usePlaintext().build();
        this.blockingStub = newBlockingStub(this.managedChannel);
        log.info("Connected to server at "+ip+":"+port);

        Runtime.getRuntime().addShutdownHook(new Thread(() -> {
            try {
                this.managedChannel.shutdownNow().awaitTermination(5, TimeUnit.SECONDS);

            } catch (InterruptedException e) {
                e.printStackTrace(System.err);
            }
            System.err.println("Client shut down.");
        }));
    }

    private void shutdown() throws InterruptedException {
        this.managedChannel.shutdown().awaitTermination(5L, TimeUnit.SECONDS);
    }

    public static void main(String[] args) throws InterruptedException {
        ClientMain clientMain = new ClientMain("0.0.0.0",10000);

        HelloReply helloReply = clientMain.blockingStub.sayHello(HelloRequest.newBuilder().setName("測試").build());
        log.info(helloReply.getMessage());
        clientMain.shutdown();

    }
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末瘫析,一起剝皮案震驚了整個濱河市扫腺,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌虏缸,老刑警劉巖沧卢,帶你破解...
    沈念sama閱讀 207,248評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蚁堤,死亡現(xiàn)場離奇詭異,居然都是意外死亡但狭,警方通過查閱死者的電腦和手機(jī)披诗,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,681評論 2 381
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來熟空,“玉大人藤巢,你說我怎么就攤上這事搞莺∠⒙蓿” “怎么了?”我有些...
    開封第一講書人閱讀 153,443評論 0 344
  • 文/不壞的土叔 我叫張陵才沧,是天一觀的道長迈喉。 經(jīng)常有香客問我,道長温圆,這世上最難降的妖魔是什么挨摸? 我笑而不...
    開封第一講書人閱讀 55,475評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮岁歉,結(jié)果婚禮上得运,老公的妹妹穿的比我還像新娘。我一直安慰自己锅移,他們只是感情好熔掺,可當(dāng)我...
    茶點故事閱讀 64,458評論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著非剃,像睡著了一般置逻。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上备绽,一...
    開封第一講書人閱讀 49,185評論 1 284
  • 那天券坞,我揣著相機(jī)與錄音,去河邊找鬼肺素。 笑死恨锚,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的倍靡。 我是一名探鬼主播猴伶,決...
    沈念sama閱讀 38,451評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了蜗顽?” 一聲冷哼從身側(cè)響起布卡,我...
    開封第一講書人閱讀 37,112評論 0 261
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎雇盖,沒想到半個月后忿等,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,609評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡崔挖,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,083評論 2 325
  • 正文 我和宋清朗相戀三年贸街,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片狸相。...
    茶點故事閱讀 38,163評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡薛匪,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出脓鹃,到底是詐尸還是另有隱情逸尖,我是刑警寧澤,帶...
    沈念sama閱讀 33,803評論 4 323
  • 正文 年R本政府宣布瘸右,位于F島的核電站娇跟,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏太颤。R本人自食惡果不足惜苞俘,卻給世界環(huán)境...
    茶點故事閱讀 39,357評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望龄章。 院中可真熱鬧吃谣,春花似錦、人聲如沸做裙。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,357評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽菇用。三九已至澜驮,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間惋鸥,已是汗流浹背杂穷。 一陣腳步聲響...
    開封第一講書人閱讀 31,590評論 1 261
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留卦绣,地道東北人耐量。 一個月前我還...
    沈念sama閱讀 45,636評論 2 355
  • 正文 我出身青樓,卻偏偏與公主長得像滤港,于是被迫代替她去往敵國和親廊蜒。 傳聞我的和親對象是個殘疾皇子趴拧,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,925評論 2 344