Golang語(yǔ)言實(shí)現(xiàn)gRPC的具體使用
gRPC 是通信協(xié)議基于 HTTP/2,支持多語(yǔ)言的 RPC 框架,使用 Protobuf 作為它的接口設(shè)計(jì)語(yǔ)言(IDL),可以通過 protoc 工具生成 Golang 語(yǔ)言的結(jié)構(gòu)體。
RPC:Remote Procedure Call 的縮寫,譯為遠(yuǎn)程過程調(diào)用(也可譯為遠(yuǎn)程方法調(diào)用或遠(yuǎn)程調(diào)用),它是計(jì)算機(jī)通信協(xié)議。該協(xié)議可以實(shí)現(xiàn)調(diào)用遠(yuǎn)程服務(wù)就像調(diào)用本地服務(wù)一樣簡(jiǎn)單,無(wú)需關(guān)心跨網(wǎng)絡(luò),跨平臺(tái),跨語(yǔ)言等問題。
gRPC 消息序列化方式通常使用 Protobuf,它是二進(jìn)制格式,體積小,網(wǎng)絡(luò)傳輸快,占用帶寬流量少,調(diào)用性能更高。

gRPC 的特點(diǎn)
IDLgRPC使用ProtoBuf來定義服務(wù),ProtoBuf是由Google開發(fā)的一種數(shù)據(jù)序列化協(xié)議(類似于XML、JSON)。ProtoBuf能夠?qū)?shù)據(jù)進(jìn)行序列化,并廣泛應(yīng)用在數(shù)據(jù)存儲(chǔ)、通信協(xié)議等方面。多語(yǔ)言支持
gRPC支持多種語(yǔ)言,并能夠基于語(yǔ)言自動(dòng)生成客戶端和服務(wù)端功能庫(kù)。目前已提供了C版本grpc、Java版本grpc-java和Go版本grpc-go,其中,grpc支持C、C++、Node.js、Python、Ruby、Objective-C、PHP和C#等語(yǔ)言,grpc-java已經(jīng)支持Android開發(fā)。HTTP2
gRPC基于HTTP2標(biāo)準(zhǔn)設(shè)計(jì),帶來了更多強(qiáng)大功能,如雙向流、頭部壓縮、多復(fù)用請(qǐng)求等。這些功能帶來重大益處,如節(jié)省帶寬、降低TCP鏈接次數(shù)、節(jié)省CPU使用和延長(zhǎng)電池壽命等。同時(shí),gRPC還能夠提高了云端服務(wù)和Web應(yīng)用的性能。gRPC既能夠在客戶端應(yīng)用,也能夠在服務(wù)器端應(yīng)用,從而以透明的方式實(shí)現(xiàn)客戶端和服務(wù)器端的通信和簡(jiǎn)化通信系統(tǒng)的構(gòu)建。
使用 gRPC 定義服務(wù)端
gRPC 默認(rèn)使用 Protobuf 作為接口設(shè)計(jì)語(yǔ)言,在 .proto 文件中使用 service 關(guān)鍵字定義服務(wù),使用 rpc 和 returns 關(guān)鍵字定義指定請(qǐng)求參數(shù)和返回結(jié)果的方法。
gRPC 提供了 Protobuf 編譯器插件 protoc-gen-grpc,用于編譯 .proto 文件,生成服務(wù)端和客戶端代碼,我們只需在服務(wù)端編寫實(shí)現(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 文件,自動(dòng)生成服務(wù)端和客戶端代碼。
在服務(wù)端,手動(dòng)編寫生成的服務(wù)端方法的業(yè)務(wù)邏輯代碼,然后運(yùn)行 gRPC 服務(wù),接收并處理客戶端請(qǐng)求,gRPC 服務(wù)自動(dòng)解碼請(qǐng)求參數(shù),然后執(zhí)行服務(wù)的方法,并將返回結(jié)果自動(dòng)進(jìn)行編碼。
在客戶端,實(shí)現(xiàn)和服務(wù)相同的方法,然后客戶端可以本地調(diào)用這些方法,將請(qǐng)求參數(shù)封裝在 Protobuf 的消息類型中,gRPC 將請(qǐng)求發(fā)送給服務(wù)器,并返回服務(wù)器的 Protobuf 序列化方式的響應(yīng)消息。
參考文章:
到此這篇關(guān)于Golang語(yǔ)言實(shí)現(xiàn)gRPC的具體使用的文章就介紹到這了,更多相關(guān)Golang gRPC內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Go語(yǔ)言實(shí)現(xiàn)本地緩存的策略詳解
今天給大家分享的是Go語(yǔ)言本地緩存的一些內(nèi)容,主要是結(jié)合bigcache和fastcache兩個(gè)優(yōu)秀的開源代碼庫(kù),總結(jié)一些設(shè)計(jì)思路和感悟,文章通過代碼示例介紹的非常詳細(xì),需要的朋友可以參考下2023-07-07
Go實(shí)現(xiàn)基于RSA加密算法的接口鑒權(quán)
這篇文章主要介紹了Go實(shí)現(xiàn)基于RSA加密算法的接口鑒權(quán),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-06-06
Windows上安裝Go并配置環(huán)境變量(圖文步驟)
開始使用Go創(chuàng)建應(yīng)用程序之前,需要設(shè)置開發(fā)環(huán)境,本文主要介紹了Windows上安裝Go并配置環(huán)境變量,具有一定的參考價(jià)值,感興趣的可以了解一下2023-08-08
Golang中優(yōu)秀的消息隊(duì)列NSQ基礎(chǔ)安裝及使用詳解
這篇文章主要介紹了Golang中優(yōu)秀的消息隊(duì)列NSQ基礎(chǔ)安裝及使用詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-12-12
Golang HTTP 服務(wù)平滑重啟及升級(jí)的思路
Golang HTTP服務(wù)在上線時(shí),需要重新編譯可執(zhí)行文件,關(guān)閉正在運(yùn)行的進(jìn)程,然后再啟動(dòng)新的運(yùn)行進(jìn)程。這篇文章主要介紹了Golang HTTP 服務(wù)平滑重啟及升級(jí),需要的朋友可以參考下2020-04-04
golang 并發(fā)編程之生產(chǎn)者消費(fèi)者詳解
這篇文章主要介紹了golang 并發(fā)編程之生產(chǎn)者消費(fèi)者詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-05-05

