grpc入門(mén)Unary模式使用方法示例教程
gRPC支持類(lèi)型方法
gRPC支持四種類(lèi)型的方法,分別是:
- Unary模式
- 客戶端流模式
- 服務(wù)端流模式
- 雙向流模式
其中最常見(jiàn)的是Unary模式(即一元模式),我們?cè)诒菊鹿?jié)僅介紹Unary模式。
Unary模式,也可以稱為“一問(wèn)一答模式”,客戶端發(fā)送一個(gè)請(qǐng)求給服務(wù)端,服務(wù)端返回一個(gè)響應(yīng),和一次普通的函數(shù)調(diào)用類(lèi)似。
示意圖如下:
下面我們來(lái)實(shí)現(xiàn)一個(gè)簡(jiǎn)單的Unary接口。
要通過(guò)grpc提供接口,可以分為以下三個(gè)步驟:
- 接口定義(.proto文件)。
- 生成相關(guān)代碼。
- 服務(wù)端開(kāi)發(fā)。
- 客戶端開(kāi)發(fā)。
接口定義
我們這里實(shí)現(xiàn)一個(gè)簡(jiǎn)單的greet功能,項(xiàng)目目錄結(jié)構(gòu)如下:
proto 存放proto文件。
pb 存放生成的go文件。
server 服務(wù)端代碼。
client 客戶端代碼。
bin 可執(zhí)行文件。
proto文件定義如下(greet.proto):
syntax = "proto3"; package proto; option go_package = "git.gqnotes.com/guoqiang/grpcexercises/greet/pb"; service GreetService { rpc Greet(GreetRequest) returns(GreetResponse) {} } message GreetRequest { string greeting = 1; } message GreetResponse { string result = 1; }
定義Makefile,方便執(zhí)行相關(guān)操作:
tidy: go mod tidy greet-gen: protoc -Igreet/proto/ --go_out=./greet --go_opt=module=git.gqnotes.com/guoqiang/grpcexercises/greet --go-grpc_out=./greet --go-grpc_opt=module=git.gqnotes.com/guoqiang/grpcexercises/greet greet/proto/*.proto greet-build: go build -o ./greet/bin/server-osx ./greet/server go build -o ./greet/bin/client-osx ./greet/client .PHONY: tidy greet-gen greet-build
生成相關(guān)代碼
在項(xiàng)目目錄(greet上級(jí)目錄)下執(zhí)行如命令:
make greet-gen
執(zhí)行成功,在pb目錄下生成相關(guān)文件。
服務(wù)端開(kāi)發(fā)
在server目錄下添加兩個(gè)文件:
- main.go,服務(wù)入口文件。
- Greet.go,Greet方法實(shí)現(xiàn)。
代碼如下:
<details>
<summary>main.go</summary>
package main import ( "git.gqnotes.com/guoqiang/grpcexercises/greet/pb" "google.golang.org/grpc" "google.golang.org/grpc/reflection" "log" "net" ) func main() { // 實(shí)現(xiàn)服務(wù)端邏輯,監(jiān)聽(tīng)5632端口 lis, err := net.Listen("tcp", ":5632") if err != nil { log.Fatalf("failed to listen: %v", err) return } s := grpc.NewServer() // 注冊(cè)服務(wù) pb.RegisterGreetServiceServer(s, &Server{}) reflection.Register(s) log.Println("grpc server start") if err = s.Serve(lis); err != nil { log.Fatalf("failed to serve: %v", err) return } } type Server struct { pb.UnimplementedGreetServiceServer }
</details>
<details>
<summary>Greet.go</summary>
package main import ( "context" "git.gqnotes.com/guoqiang/grpcexercises/greet/pb" "log" "time" ) // Greet greet func (s *Server) Greet(ctx context.Context, req *pb.GreetRequest) (*pb.GreetResponse, error) { log.Printf("Greet function was invoked with %v\n", req) result := "Hello " + req.GetGreeting() + ", now time is:" + time.Now().String() res := &pb.GreetResponse{ Result: result, } return res, nil }
</details>
客戶端開(kāi)發(fā)
在client目錄下添加客戶端代碼,有兩個(gè)文件:
- main.go,程序入口文件。
- Greet.go,具體方法文件。
文件內(nèi)容如下:
<details>
<summary>main.go</summary>
package main import ( "git.gqnotes.com/guoqiang/grpcexercises/greet/pb" "google.golang.org/grpc" "google.golang.org/grpc/credentials/insecure" "log" ) func main() { conn, err := grpc.Dial(":5632", grpc.WithTransportCredentials(insecure.NewCredentials())) if err != nil { log.Fatalf("failed to dial: %v", err) return } defer conn.Close() // 實(shí)例化客戶端 client := pb.NewGreetServiceClient(conn) // 調(diào)用方法 Greet(client) }
</details>
<details>
<summary>Greet.go</summary>
package main import ( "context" "git.gqnotes.com/guoqiang/grpcexercises/greet/pb" "log" ) func Greet(client pb.GreetServiceClient) { response, err := client.Greet(context.Background(), &pb.GreetRequest{ Greeting: "xiaoming", }) if err != nil { log.Fatalf("failed to call Greet: %v", err) return } log.Printf("response:%+v\n", response) }
</details>
執(zhí)行
在項(xiàng)目目錄下執(zhí)行make tidy,拉取相關(guān)庫(kù),然后執(zhí)行 make greet-build,生成可執(zhí)行文件。
然后在命令行下執(zhí)行如下命令,啟動(dòng)服務(wù)端程序:
./greet/bin/server-osx
執(zhí)行如下命令,測(cè)試客戶端文件:
./greet/bin/client-osx
執(zhí)行結(jié)果如下:
2023/12/02 15:02:26 response:result:"Hello xiaoming now time is:2023-12-02 15:02:26.443767 +0800 CST m=+1268.825308543"
代碼地址 https://git.gqnotes.com/guoqiang/grpcexercises
以上就是grpc入門(mén)Unary模式使用方法示例教程的詳細(xì)內(nèi)容,更多關(guān)于grpc Unary模式的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
golang實(shí)戰(zhàn)之truncate日志文件詳解
這篇文章主要給大家介紹了關(guān)于golang實(shí)戰(zhàn)之truncate日志文件的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2018-07-07go實(shí)現(xiàn)thrift的網(wǎng)絡(luò)傳輸性能及需要注意問(wèn)題示例解析
這篇文章主要為大家介紹了go實(shí)現(xiàn)thrift的網(wǎng)絡(luò)傳輸性能及需要注意問(wèn)題示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09Golang中的archive/zip包的常用函數(shù)詳解
Golang 中的 archive/zip 包用于處理 ZIP 格式的壓縮文件,提供了一系列用于創(chuàng)建、讀取和解壓縮 ZIP 格式文件的函數(shù)和類(lèi)型,下面小編就來(lái)和大家講解下常用函數(shù)吧2023-08-08Go語(yǔ)言Http?Server框架實(shí)現(xiàn)一個(gè)簡(jiǎn)單的httpServer
這篇文章主要為大家介紹了Go語(yǔ)言Http?Server框架實(shí)現(xiàn)一個(gè)簡(jiǎn)單的httpServer抽象,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04夯實(shí)Golang基礎(chǔ)之?dāng)?shù)據(jù)類(lèi)型梳理匯總
這篇文章主要8為大家介紹了夯實(shí)Golang基礎(chǔ)之?dāng)?shù)據(jù)類(lèi)型梳理匯總,有需要的朋友可以借鑒參考下,希望能夠有所幫助2023-10-10