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

Golang語言實現(xiàn)gRPC的具體使用

 更新時間:2022年08月02日 15:36:59   作者:鹿魚  
本文主要介紹了Golang語言實現(xiàn)gRPC的具體使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

gRPC 是通信協(xié)議基于 HTTP/2,支持多語言的 RPC 框架,使用 Protobuf 作為它的接口設(shè)計語言(IDL),可以通過 protoc 工具生成 Golang 語言的結(jié)構(gòu)體。

RPCRemote Procedure Call 的縮寫,譯為遠程過程調(diào)用(也可譯為遠程方法調(diào)用或遠程調(diào)用),它是計算機通信協(xié)議。該協(xié)議可以實現(xiàn)調(diào)用遠程服務(wù)就像調(diào)用本地服務(wù)一樣簡單,無需關(guān)心跨網(wǎng)絡(luò),跨平臺,跨語言等問題。

gRPC 消息序列化方式通常使用 Protobuf,它是二進制格式,體積小,網(wǎng)絡(luò)傳輸快,占用帶寬流量少,調(diào)用性能更高。

gRPC 的特點

  • IDL

    gRPC 使用 ProtoBuf 來定義服務(wù),ProtoBuf 是由 Google 開發(fā)的一種數(shù)據(jù)序列化協(xié)議(類似于 XML、JSON)。ProtoBuf 能夠?qū)?shù)據(jù)進行序列化,并廣泛應用在數(shù)據(jù)存儲、通信協(xié)議等方面。

  • 多語言支持

    gRPC 支持多種語言,并能夠基于語言自動生成客戶端和服務(wù)端功能庫。目前已提供了 C 版本 grpcJava 版本 grpc-javaGo 版本 grpc-go,其中,grpc 支持 CC++、Node.js、PythonRuby、Objective-CPHPC# 等語言,grpc-java 已經(jīng)支持 Android 開發(fā)。

  • HTTP2

    gRPC基于HTTP2標準設(shè)計,帶來了更多強大功能,如雙向流、頭部壓縮、多復用請求等。這些功能帶來重大益處,如節(jié)省帶寬、降低TCP鏈接次數(shù)、節(jié)省CPU使用和延長電池壽命等。同時,gRPC還能夠提高了云端服務(wù)和Web應用的性能。gRPC既能夠在客戶端應用,也能夠在服務(wù)器端應用,從而以透明的方式實現(xiàn)客戶端和服務(wù)器端的通信和簡化通信系統(tǒng)的構(gòu)建。

使用 gRPC 定義服務(wù)端

gRPC 默認使用 Protobuf 作為接口設(shè)計語言,在 .proto 文件中使用 service 關(guān)鍵字定義服務(wù),使用 rpc 和 returns 關(guān)鍵字定義指定請求參數(shù)和返回結(jié)果的方法。

gRPC 提供了 Protobuf 編譯器插件 protoc-gen-grpc,用于編譯 .proto 文件,生成服務(wù)端和客戶端代碼,我們只需在服務(wù)端編寫實現(xiàn) Api 的代碼,然后在客戶端調(diào)用 Api。

syntax = "proto3";

import "google/protobuf/any.proto";

package hello;

option go_package = "proto/gen/go";

message HelloReq {
  string name = 1;
}

message HelloResp {
  int32 code = 1;
  string greet = 2;
  google.protobuf.Any details = 3;
}

service HelloService {
  rpc Greet(HelloReq) returns (HelloResp);
}

使用 gRPC 的客戶端

通過 protoc 命令編譯 .proto 文件,自動生成服務(wù)端和客戶端代碼。

在服務(wù)端,手動編寫生成的服務(wù)端方法的業(yè)務(wù)邏輯代碼,然后運行 gRPC 服務(wù),接收并處理客戶端請求,gRPC 服務(wù)自動解碼請求參數(shù),然后執(zhí)行服務(wù)的方法,并將返回結(jié)果自動進行編碼。

在客戶端,實現(xiàn)和服務(wù)相同的方法,然后客戶端可以本地調(diào)用這些方法,將請求參數(shù)封裝在 Protobuf 的消息類型中,gRPC 將請求發(fā)送給服務(wù)器,并返回服務(wù)器的 Protobuf 序列化方式的響應消息。

參考文章:

Golang 語言 gRPC 到底是什么?

gRPC簡介

到此這篇關(guān)于Golang語言實現(xiàn)gRPC的具體使用的文章就介紹到這了,更多相關(guān)Golang gRPC內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Go常用技能日志log包創(chuàng)建使用示例

    Go常用技能日志log包創(chuàng)建使用示例

    這篇文章主要為大家介紹了Go常用技能日志log包創(chuàng)建使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • Go語言拼接URL路徑的三種方法

    Go語言拼接URL路徑的三種方法

    本文主要介紹了Go語言拼接URL路徑的三種方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-03-03
  • Golang中使用不定數(shù)量空格分割字符串的方法

    Golang中使用不定數(shù)量空格分割字符串的方法

    有這樣一個使用空格分割字符串的場景,字符串中被分割的子串之間的空格數(shù)量不確定,有一個兩個或者多個空格,這種場景下,使用最容易想到的strings.Split函數(shù)就做不到了,本文接下來就介紹幾種行之有效的方法,需要的朋友可以參考下
    2023-07-07
  • Go語言學習教程之反射的示例詳解

    Go語言學習教程之反射的示例詳解

    這篇文章主要通過記錄對reflect包的簡單使用,來對反射有一定的了解。文中的示例代碼講解詳細,對我們學習Go語言有一定幫助,需要的可以參考一下
    2022-09-09
  • Golang服務(wù)的請求調(diào)度的實現(xiàn)

    Golang服務(wù)的請求調(diào)度的實現(xiàn)

    Golang服務(wù)請求調(diào)度是一種使用Go語言實現(xiàn)的服務(wù)請求管理方法,本文主要介紹了Golang服務(wù)的請求調(diào)度的實現(xiàn),具有一定的參考價值,感興趣的可以了解一下
    2023-08-08
  • 深入了解Golang中reflect反射的使用

    深入了解Golang中reflect反射的使用

    這篇文章主要介紹了深入了解Golang中reflect反射的使用,Go語言中的反射是一種機制,可以在運行時動態(tài)地獲取類型信息和操作對象,以及調(diào)用對象的方法和屬性等,需要詳細了解可以參考下文
    2023-05-05
  • Go 語言中的 http.FileSystem詳細解析

    Go 語言中的 http.FileSystem詳細解析

    在本文中,我們深入探討了 Go 語言中的 http.FileSystem 接口,并介紹了它的基本原理、使用方法以及實際應用場景,感興趣的朋友跟隨小編一起看看吧
    2024-03-03
  • golang 如何用反射reflect操作結(jié)構(gòu)體

    golang 如何用反射reflect操作結(jié)構(gòu)體

    這篇文章主要介紹了golang 用反射reflect操作結(jié)構(gòu)體的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-04-04
  • golang 如何獲取文件夾下面的文件列表

    golang 如何獲取文件夾下面的文件列表

    這篇文章主要介紹了golang 獲取文件夾下面的文件列表方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-05-05
  • 帶你在Go?test中體驗jest的安裝使用

    帶你在Go?test中體驗jest的安裝使用

    這篇文章帶你在Go?test中體驗jest的安裝使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08

最新評論