在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

什么是gRPC

科技綠洲 ? 來源:Java技術(shù)指北 ? 作者:Java技術(shù)指北 ? 2023-10-07 16:24 ? 次閱讀
  • 相信大家對RPC協(xié)議都有一定的了解,并且或多或少都會在項目中涉及,但可能都和小編類似,都是直接使用平臺封裝的插件,對于其中的原理不是很了解,今天借此機會和大家分享下最近接觸的RPC框架-grpc,一同聊聊那些知其然卻不知其所以然的內(nèi)容。

概述

  • RPC(Remote Procedure Call)遠(yuǎn)程過程調(diào)用協(xié)議,是一種本地可以通過網(wǎng)絡(luò)請求遠(yuǎn)程計算機,完成計算機間的數(shù)據(jù)內(nèi)容的交互的協(xié)議,不需要了解網(wǎng)絡(luò)底層技術(shù)就可以快速上手,使得開發(fā)更加容易,同時提升了交互體驗效率。
  • 為了方便開發(fā),有很多基于RPC協(xié)議實現(xiàn)的RPC框架,比如Thrift、Dubbo,和本文即將要介紹的gRPC。

什么是gRPC

  • gRPC是由google開發(fā)的一種支跨平臺(語言)、高性能、開源通用的RPC框架。
  • 它是基于HTTP2.0協(xié)議的,可以保持客戶端與服務(wù)端長連接,基于二進(jìn)制流(字節(jié)流)傳輸數(shù)據(jù)。
  • 客戶端與服務(wù)端交互過程
    • 客戶端(gRPC Sub)調(diào)用A方法,發(fā)起RPC請求
    • 請求內(nèi)容使用Protobf進(jìn)行對象序列化壓縮
    • 服務(wù)端(gRPC Server)接收請求,解析請求內(nèi)容,業(yè)務(wù)處理后返回
    • 響應(yīng)結(jié)果通過Protobuf進(jìn)行對象序列化壓縮
    • 客戶端接收響應(yīng),解析響應(yīng)內(nèi)容,最終完成交互

實踐案例

小編以java版進(jìn)行案例展示,其它語言類似,可自行測試

  • POM依賴
    • gRPC官方提供完成的依賴配置,按照說明直接引用即可(依賴包含插件),版本僅供參考,也可選擇其它版本。
< !-- gRPC配置 -- >
        < dependency >
            < groupId >io.grpc< /groupId >
            < artifactId >grpc-netty-shaded< /artifactId >
            < version >1.29.0< /version >
        < /dependency >
        < dependency >
            < groupId >io.grpc< /groupId >
            < artifactId >grpc-protobuf< /artifactId >
            < version >1.29.0< /version >
        < /dependency >
        < dependency >
            < groupId >io.grpc< /groupId >
            < artifactId >grpc-services< /artifactId >
            < version >1.29.0< /version >
        < /dependency >
        < dependency >
            < groupId >io.grpc< /groupId >
            < artifactId >grpc-stub< /artifactId >
            < version >1.29.0< /version >
        < /dependency >

        < !-- proto插件 -- >
                < plugins >
            < plugin >
                < groupId >org.xolstice.maven.plugins< /groupId >
                < artifactId >protobuf-maven-plugin< /artifactId >
                < version >0.6.1< /version >
                < configuration >
                    < protocArtifact >com.google.protobuf:protoc:3.11.0:exe:${os.detected.classifier}< /protocArtifact >
                    < pluginId >grpc-java< /pluginId >
                    < pluginArtifact >io.grpc:protoc-gen-grpc-java:1.29.0:exe:${os.detected.classifier}< /pluginArtifact >
                < /configuration >
                < executions >
                    < execution >
                        < goals >
                            < goal >compile< /goal >
                            < goal >compile-custom< /goal >
                        < /goals >
                    < /execution >
                < /executions >
            < /plugin >
        < /plugins >
  • 編寫protobuf文件
    • 小編使用的是proto3版本,需要注意固定的目錄結(jié)構(gòu)(src/proto/*.proto),否則會編譯失敗。
    • proto文件有固定的編寫格式,可以自行上網(wǎng)搜索即可
syntax = "proto3";
//包所在路徑
option java_package = "com.greatom.dockerdemo.rule";
option java_multiple_files = true;
package rule;
//聲明服務(wù)和方法
service RuleService {
    //查詢并更新規(guī)則
    rpc getArchivesDic (RuleRequest) returns (RuleResponse);
    //獲取當(dāng)前規(guī)則字典
    rpc getRule (Request) returns (Response);
}
//定義請求對象
message RuleRequest {
    //    message RuleRPCDTO {
    //        int32 ruleCode = 1;
    //        string administrativeCost = 2;
    //    }
    Response ruleRPCDTO = 1;
    int32 basicId = 2;
}
//定義響應(yīng)對象
message RuleResponse {
    int32 id = 1;
}
message Request {
}
//定義響應(yīng)消息
message Response {
    int32 ruleCode = 1;
    string administrativeCost = 2;
}
  • 使用maven插件編譯,雙擊執(zhí)行(生成Bean,maven->Plugins->protobuf->protobuf:compile;生成具體接口,maven->Plugins->protobuf->protobuf:compile-custom)。
  • 小編只執(zhí)行protobuf:compile命令,然后在target目錄(targetgenerated-sourcesprotobuf)下就找到了生成的java文件,復(fù)制出來粘貼到項目執(zhí)行目錄下即可。
  • 編寫接口實現(xiàn)類
  • 編譯完后會生成RuleServiceGrpc接口,接下來就是按照自己的業(yè)務(wù)需求編寫邏輯即可。小編定義的兩個接口分別是 getArchivesDic(更新規(guī)則)、getRule(查詢規(guī)則)。具體實現(xiàn)如下
// 繼承生成的RuleServiceGrpc.RuleServiceImplBase
// 實現(xiàn)接口具體邏輯
@Component
public class RuleGRPCServer extends RuleServiceGrpc.RuleServiceImplBase {
    // 更新規(guī)則字典
    @Override
    public void getArchivesDic(RuleRequest request, StreamObserver< RuleResponse > responseObserver) {
        Response ruleRPCDTO = request.getRuleRPCDTO();
        RuleDTO ruleDTO = new RuleDTO();
        BeanUtils.copyProperties(ruleRPCDTO, ruleDTO);
        RuleResponse ruleResponse = RuleResponse.newBuilder().setId(1).build();
        responseObserver.onNext(ruleResponse);
        responseObserver.onCompleted();
    }
    // 查詢規(guī)則字典
    @Override
    public void getRule(Request request, StreamObserver< Response > responseObserver) {
        Response response = Response.newBuilder().setRuleCode(1)
                .setAdministrativeCost("2222").build();
        responseObserver.onNext(response);
        responseObserver.onCompleted();
    }
}
  • 服務(wù)端與客戶端
    • 服務(wù)端啟動類
public static void main(String[] args) throws Exception {
        // 設(shè)置service接口.
        Server server = ServerBuilder.forPort(9999).addService(new RuleGRPCServiceImpl()).build().start();
        System.out.println(String.format("GRpc服務(wù)端啟動成功, 端口號: %d.", port));
        server.awaitTermination();
    }

    日志 --- GRpc服務(wù)端啟動成功, 端口號: 9999.
  • 客戶端啟動類
public static void main(String[] args) throws Exception {
        // 1. 拿到一個通信的channel
        ManagedChannel managedChannel = ManagedChannelBuilder.forAddress("localhost", 9999).usePlaintext().build();
        try {
            // 2.拿到道理對象
            RuleServiceGrpc.RuleServiceBlockingStub rpcDateService = RuleServiceGrpc.newBlockingStub(managedChannel);
            Request rpcDateRequest = Request
                    .newBuilder()
                    .build();
            // 3. 請求
            Response rpcDateResponse = rpcDateService.getRule(rpcDateRequest);
            // 4. 輸出結(jié)果
            System.out.println(rpcDateResponse.getRuleCode());
        } finally {
            // 5.關(guān)閉channel, 釋放資源.
            managedChannel.shutdown();
        }
    }

    日志:
    - 16:05:44.628 [grpc-nio-worker-ELG-1-2] DEBUG io.grpc.netty.shaded.io.grpc.netty.NettyClientHandler - [id: 0x8447cc92, L:/127.0.0.1:60973 - R:localhost/127.0.0.1:9999] INBOUND DATA: streamId=3 padding=0 endStream=false length=12 bytes=0000000007086f1203323232
    - 16:05:44.648 [grpc-nio-worker-ELG-1-2] DEBUG io.grpc.netty.shaded.io.grpc.netty.NettyClientHandler - [id: 0x8447cc92, L:/127.0.0.1:60973 - R:localhost/127.0.0.1:9999] INBOUND HEADERS: streamId=3 headers=GrpcHttp2ResponseHeaders[grpc-status: 0] padding=0 endStream=true
    - 輸出結(jié)果-----111
    - 16:05:44.664 [grpc-nio-worker-ELG-1-2] DEBUG io.grpc.netty.shaded.io.grpc.netty.NettyClientHandler - [id: 0x8447cc92, L:/127.0.0.1:60973 - R:localhost/127.0.0.1:9999] OUTBOUND GO_AWAY: lastStreamId=0 errorCode=0 length=0 bytes=
  • 客戶端日志輸出結(jié)果即表示客戶端通過gRPC調(diào)用服務(wù)端成功,并返回結(jié)果。

總結(jié)

  • gRPC本質(zhì)上就是傳統(tǒng)的C|S模型,這樣看角色分的清楚,也很容易理解。
  • 還有就是它很聰明的點是基于HTTP2.0協(xié)議的,而不是自己制定,這就對未來的網(wǎng)絡(luò)開發(fā)很友好,降低了門檻。
  • 比較難上手的點在于proto文件的編寫和使用,這部分需要插件等依賴,過程相對復(fù)雜,但也可能會出現(xiàn)工具或腳本,可以簡化下這部分。但生成代碼確實是真香~ 減少了一部分工作量。
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 計算機
    +關(guān)注

    關(guān)注

    19

    文章

    7638

    瀏覽量

    90377
  • 網(wǎng)絡(luò)
    +關(guān)注

    關(guān)注

    14

    文章

    7783

    瀏覽量

    90532
  • 客戶端
    +關(guān)注

    關(guān)注

    1

    文章

    298

    瀏覽量

    17025
  • 編譯
    +關(guān)注

    關(guān)注

    0

    文章

    676

    瀏覽量

    33831
收藏 人收藏

    評論

    相關(guān)推薦
    熱點推薦

    GRPC的基礎(chǔ)使用方法

    gRPC 是 Google 開源的高性能、通用的 RPC 框架,它采用了基于 HTTP/2 協(xié)議的二進(jìn)制傳輸協(xié)議,支持多種語言,包括 Rust。Rust 語言 GRPC 模塊是一個用于 Rust
    的頭像 發(fā)表于 09-19 16:08 ?1289次閱讀

    請問如何從YOLOv8輸出張量結(jié)果中獲取邊界框?

    imagenet_classes from ovmsclient import make_grpc_client client = make_grpc_client(\"localhost:9000\"
    發(fā)表于 03-06 06:58

    153.RPC:11.3 gRPC說明

    服務(wù)器代碼
    充八萬
    發(fā)布于 :2023年07月12日 19:39:46

    REST、gRPC、GraphQL及WebHook的對比和選型

    首先REST--Resource Representational State Transfer, 中文直譯就是資源在網(wǎng)絡(luò)中以某種表現(xiàn)形式進(jìn)行狀態(tài)轉(zhuǎn)移。
    發(fā)表于 06-13 10:34 ?2642次閱讀

    Dubbo 在跨語言和協(xié)議穿透性方向的探索:支持 HTTP/2 gRPC

    Dubbo 在跨語言和協(xié)議穿透性方向上的探索:支持 HTTP/2 gRPC 和 Protobuf 本文整理自劉軍在 Dubbo 成都 meetup 上分享的《Dubbo 在多語言和協(xié)議穿透性方向
    發(fā)表于 12-02 23:07 ?3966次閱讀
    Dubbo 在跨語言和協(xié)議穿透性方向的探索:支持 HTTP/2 <b class='flag-5'>gRPC</b>

    谷歌開源高性能通用RPC框架gRPC

    谷歌開源了 gRPC-Kotlin/JVM,讓開發(fā)者可以在 Kotlin 項目中更方便地使用 gRPC,以更簡單的方式構(gòu)建可靠的網(wǎng)絡(luò)連接服務(wù)。
    的頭像 發(fā)表于 04-20 14:43 ?2968次閱讀
    谷歌開源高性能通用RPC框架<b class='flag-5'>gRPC</b>

    現(xiàn)代的服務(wù)端技術(shù)棧:Golang/Protobuf/gRPC詳解

    Golang又稱Go語言,是一個開源的、多用途的編程語言,由Google研發(fā),并由于種種原因,正在日益流行。Golang已經(jīng)有10年的歷史,并且據(jù)Google稱已經(jīng)在生產(chǎn)環(huán)境中使用了接近7年的時間,這一點可能讓大多數(shù)人大跌眼鏡。
    的頭像 發(fā)表于 12-25 17:32 ?1372次閱讀

    IP知識百科之什么是gRPC

    gRPC Google遠(yuǎn)程過程調(diào)用(Google Remote Procedure Call,gRPC)協(xié)議是谷歌發(fā)布的高性能、通用的開源RPC軟件框架。gRPC提供了多種編程語言,同時gRP
    的頭像 發(fā)表于 11-16 15:13 ?3558次閱讀

    gWhisper gRPC命令行工具

    ./oschina_soft/gWhisper.zip
    發(fā)表于 06-15 09:28 ?1次下載
    gWhisper <b class='flag-5'>gRPC</b>命令行工具

    gRPC-Nebula微服務(wù)框架

    ./oschina_soft/grpc-nebula.zip
    發(fā)表于 06-22 14:59 ?0次下載
    <b class='flag-5'>gRPC</b>-Nebula微服務(wù)框架

    gRPC-Web訪問gRPC服務(wù)的Web客戶端

    ./oschina_soft/grpc-web.zip
    發(fā)表于 06-22 09:25 ?0次下載
    <b class='flag-5'>gRPC</b>-Web訪問<b class='flag-5'>gRPC</b>服務(wù)的Web客戶端

    正確使用gRPC與GraphQL

    TLDR:使用 GraphQL 進(jìn)行客戶端-服務(wù)器通信,使用 gRPC 進(jìn)行服務(wù)器到服務(wù)器通信。有關(guān)此規(guī)則的例外情況,請參閱“判定”部分。 我已經(jīng)閱讀了很多關(guān)于這兩種協(xié)議的比較,并想寫一個全面和公正
    的頭像 發(fā)表于 12-08 15:47 ?1332次閱讀

    搞一個grpc動態(tài)代理的想法,并初步實現(xiàn)

    本人之前很長一段時間從事saas,paas的開發(fā)。對于一些服務(wù)而言,既要提供grpc訪問的能力,也要對外提供http訪問的能力(做saas就是這么卑微)。并且這種需求通常不是一開始就提出來的
    的頭像 發(fā)表于 02-08 16:13 ?1613次閱讀

    gRPC內(nèi)存馬研究與查殺

    遠(yuǎn)程過程調(diào)用(Remote Procedure Call,縮寫為 RPC)是一個計算機通信協(xié)議。
    的頭像 發(fā)表于 06-01 11:24 ?1615次閱讀
    <b class='flag-5'>gRPC</b>內(nèi)存馬研究與查殺

    使用go語言實現(xiàn)一個grpc攔截器

    在開發(fā)grpc服務(wù)時,我們經(jīng)常會遇到一些通用的需求,比如:日志、鏈路追蹤、鑒權(quán)等。這些需求可以通過grpc攔截器來實現(xiàn)。本文使用go語言來實現(xiàn)一個 grpc一元模式(Unary)攔截器,上報鏈路追蹤信息。
    的頭像 發(fā)表于 12-18 10:13 ?905次閱讀
    使用go語言實現(xiàn)一個<b class='flag-5'>grpc</b>攔截器
    主站蜘蛛池模板: 欧美ol丝袜高跟秘书在线观看 | 国产精品久久久久久久久福利 | 成人国产三级在线播放 | 激情综合亚洲 | aika中文字幕永久在线 | 免费永久欧美性色xo影院 | 久草资源网站 | 亚洲a在线播放 | 国产美女影院 | 亚洲视频在线一区二区 | 天天躁天天狠天天透 | 亚洲一区二区三区在线 | 久久天天躁狠狠躁夜夜呲 | 色男人的天堂 | 国产精品高清久久久久久久 | 在线视频免费播放 | 欧美视频一区二区三区在线观看 | 亚色影视| 夜夜操美女| 劳拉淫欲护士bd字幕 | 91免费视频网站 | 在线观看www妖精免费福利视频 | 亚洲综合一二三区 | 夜夜视频 | 亚洲激情婷婷 | 天天摸夜夜爽 | 中文字幕1区2区 | 七月婷婷在线视频综合 | 热99re久久精品2久久久 | 狠狠色丁香婷婷综合视频 | 天天插插插 | 亚洲成人黄色网址 | 拍拍拍交性免费视频 | 日韩a毛片免费全部播放完整 | 午夜手机福利视频 | 久久人人爽爽爽人久久久 | 亚洲精品中文字幕乱码三区一二 | 欧色美| 国产午夜视频在线观看 | 国产精品久久久久久久午夜片 | 日本特黄特色 |