自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

gRPC入門指南之簡(jiǎn)單RPC

開發(fā) 前端
這篇文章主要介紹了 gRPC 第一種交互模式 - Simple RPC,演示了最基礎(chǔ)的 demo,大家重點(diǎn)需要掌握以下兩點(diǎn):服務(wù)端和客戶端的實(shí)現(xiàn)流程;simple.pb.go 的內(nèi)容;

[[404879]]

本文轉(zhuǎn)載自微信公眾號(hào)「Golang來(lái)啦」,作者Seekload 。轉(zhuǎn)載本文請(qǐng)聯(lián)系Golang來(lái)啦公眾號(hào)。   

你好,我是 Seekload!

接下來(lái)一段時(shí)間我們來(lái)一段 gRPC 之旅,歡迎入坑!

需要的背景知識(shí)

學(xué)習(xí) gRPC 需要提前掌握的背景知識(shí):

  • Protocol Buffer 協(xié)議;
  • 安裝 protoc 和 protoc-gen-go;

這兩部分知識(shí)不會(huì)重點(diǎn)講解,需要自行學(xué)習(xí),我們把重點(diǎn)放在 gRPC。

介紹

gRPC 有四種數(shù)據(jù)交互模式:

  • 簡(jiǎn)單模式(Simple RPC),客戶端發(fā)起請(qǐng)求并等待服務(wù)端響應(yīng);
  • 服務(wù)端流式 RPC(Server-side streaming RPC),客戶端發(fā)起一個(gè)請(qǐng)求到服務(wù)端,服務(wù)端返回一段連續(xù)的數(shù)據(jù)流響應(yīng);
  • 客戶端流式 RPC(Client-side streaming RPC),與服務(wù)端流式相反,客戶端流式是客戶端不斷地向服務(wù)端發(fā)送數(shù)據(jù)流,最后由服務(wù)端返回一個(gè)響應(yīng);
  • 雙向流式 RPC(Bidirectional streaming RPC),客戶端和服務(wù)端可同時(shí)向?qū)Ψ桨l(fā)送數(shù)據(jù)流,同時(shí)也可以接收數(shù)據(jù);

先從簡(jiǎn)單的入手,我們先來(lái)看下簡(jiǎn)單模式 RPC,這種交互模式就是客戶端請(qǐng)求一次,服務(wù)端回應(yīng)一次,雙方一來(lái)一回就算單次通信結(jié)束了。

新建并編譯 proto 文件

新建文件 simple.proto

  1. syntax = "proto3"
  2.  
  3. package proto; 
  4.  
  5. // 定義發(fā)送請(qǐng)求信息 
  6. message SimpleRequest{ 
  7.   // 參數(shù)類型 參數(shù)名稱 標(biāo)識(shí)號(hào) 
  8.   string data = 1; 
  9.  
  10. // 定義響應(yīng)信息 
  11. message SimpleResponse{ 
  12.   int32 code = 1; 
  13.   string value = 2; 
  14.  
  15. // 定義我們的服務(wù)(可以定義多個(gè)服務(wù),每個(gè)服務(wù)可以定義多個(gè)接口) 
  16. service Simple{ 
  17.   rpc GetSimpleInfo(SimpleRequest) returns (SimpleResponse){}; 

進(jìn)入 simple.proto 所在的目錄,使用如下命令編譯文件

  1. protoc --go_out=plugins=grpc:. simple.proto 

執(zhí)行完成之后會(huì)生成 simple.pb.go 文件,文件內(nèi)容會(huì)在文章后半段給大家梳理,我們先把 demo 跑起來(lái)。

創(chuàng)建 server 端

需要在 server 端實(shí)現(xiàn) GetSimpleInfo 方法。

  1. package main 
  2.  
  3. import ( 
  4.  "context" 
  5.  pb "go-grpc-example/1-simple_rpc/proto" 
  6.  "google.golang.org/grpc" 
  7.  "log" 
  8.  "net" 
  9.  
  10. const ( 
  11.  Address string = ":8000" 
  12.  Network string = "tcp" 
  13.  
  14. // 定義我們的服務(wù) 
  15. type SimpleService struct{} 
  16.  
  17. // 實(shí)現(xiàn) GetSimpleInfo 方法 
  18. func (s *SimpleService) GetSimpleInfo(ctx context.Context, req *pb.SimpleRequest) (*pb.SimpleResponse, error) { 
  19.  data := req.Data 
  20.  log.Println("get from client: ", data) 
  21.  resp := &pb.SimpleResponse{ 
  22.   Code:  8888, 
  23.   Value: "grpc"
  24.  } 
  25.  return resp, nil 
  26.  
  27. func main() { 
  28.  
  29.  // 1.監(jiān)聽端口 
  30.  listener, err := net.Listen(Network, Address) 
  31.  if err != nil { 
  32.   log.Fatalf("net.listen err: %v", err) 
  33.  } 
  34.  log.Println(Address, " net listening..."
  35.  // 2.實(shí)例化gRPC服務(wù)端 
  36.  grpcServer := grpc.NewServer() 
  37.  
  38.  // 3.注冊(cè)我們實(shí)現(xiàn)的服務(wù) SimpleService 
  39.  pb.RegisterSimpleServer(grpcServer, &SimpleService{}) 
  40.  
  41.  // 4.啟動(dòng)gRPC服務(wù)端 
  42.  err = grpcServer.Serve(listener) 
  43.  if err != nil { 
  44.   log.Fatalf("grpc server err: %v",err) 
  45.  } 
  46.  

服務(wù)端實(shí)現(xiàn)的主要流程,如上面代碼注釋的:1 -> 2 -> 3 -> 4。

運(yùn)行服務(wù)端:

  1. go run server.go 
  2.  
  3. 輸出: 
  4. :8000  net listening... 

創(chuàng)建 client 端

客戶端可以直接調(diào)用服務(wù)端提供的服務(wù)(接口)

  1. package main 
  2.  
  3. import ( 
  4.  "context" 
  5.  pb "go-grpc-example/1-simple_rpc/proto" 
  6.  "google.golang.org/grpc" 
  7.  "log" 
  8.  
  9. const ( 
  10.  Address string = ":8000" 
  11.  
  12. func main() { 
  13.  // 1.創(chuàng)建于gRPC服務(wù)端的連接 
  14.  conn, err := grpc.Dial(Address, grpc.WithInsecure()) 
  15.  if err != nil { 
  16.   log.Fatalf("dial conn err: %v", err) 
  17.  } 
  18.  defer conn.Close() 
  19.  
  20.  // 2.創(chuàng)建grpc客戶端 
  21.  client := pb.NewSimpleClient(conn) 
  22.  
  23.  // 3.調(diào)用服務(wù)端提供的服務(wù) 
  24.  req := pb.SimpleRequest{ 
  25.   Data: "Hello,Server"
  26.  } 
  27.  resp, err := client.GetSimpleInfo(context.Background(), &req) 
  28.  if err != nil { 
  29.   log.Fatalf("resp err: %v", err) 
  30.  } 
  31.  log.Printf("get from server,code: %v,value: %v", resp.Code, resp.Value) 
  32.  

客戶端實(shí)現(xiàn)的流程如上面注釋:1 -> 2 -> 3。

運(yùn)行客戶端:

  1. go run client.go 
  2.  
  3. 輸出: 
  4. get from server,code: 8888,value: grpc 

成功調(diào)用了服務(wù)端提供的方法并返回?cái)?shù)據(jù)。

simple.pb.go 文件詳解

擼完最基礎(chǔ)的 demo,現(xiàn)在來(lái)看下編譯完的 simple.proto 文件,熟悉這里面的內(nèi)容有助于我們理解 gRPC 的調(diào)用過程。

1.按照 simple.proto 定義的消息類型會(huì)生成不同的 struct。

  1. // 定義發(fā)送請(qǐng)求信息 
  2. type SimpleRequest struct { 
  3.  // 參數(shù)類型 參數(shù)名稱 標(biāo)識(shí)號(hào) 
  4.  Data                 string   `protobuf:"bytes,1,opt,name=data,proto3" json:"data,omitempty"
  5.  
  6. // 定義響應(yīng)信息 
  7. type SimpleResponse struct { 
  8.  Code                 int32    `protobuf:"varint,1,opt,name=code,proto3" json:"code,omitempty"
  9.  Value                string   `protobuf:"bytes,2,opt,name=value,proto3" json:"value,omitempty"

2.為結(jié)構(gòu)體生成了不同的方法。

  1. func (m *SimpleRequest) Reset()         { *m = SimpleRequest{} } 
  2. func (m *SimpleRequest) String() string { return proto.CompactTextString(m) } 
  3.  
  4. func (m *SimpleResponse) Reset()         { *m = SimpleResponse{} } 
  5. func (m *SimpleResponse) String() string { return proto.CompactTextString(m) } 
  6. func (m *SimpleResponse) GetCode() int32 { 
  7.  if m != nil { 
  8.   return m.Code 
  9.  } 
  10.  return 0 
  11.  
  12. func (m *SimpleResponse) GetValue() string { 
  13.  if m != nil { 
  14.   return m.Value 
  15.  } 
  16.  return "" 

3.生成了服務(wù)端和客戶端的接口定義,如下:

  1. // 客戶端 
  2. type SimpleClient interface { 
  3.  GetSimpleInfo(ctx context.Context, in *SimpleRequest, opts ...grpc.CallOption) (*SimpleResponse, error) 
  4.  
  5. // 服務(wù)端 
  6. type SimpleServer interface { 
  7.  GetSimpleInfo(context.Context, *SimpleRequest) (*SimpleResponse, error) 

通信雙方都必須實(shí)現(xiàn)接口里面定義的方法,仔細(xì)的同學(xué)可以發(fā)現(xiàn),客戶端的方法 GetSimpleInfo() 實(shí)際上已經(jīng)自動(dòng)生成了,客戶端只需要調(diào)用即可。

  1. func (c *simpleClient) GetSimpleInfo(ctx context.Context, in *SimpleRequest, opts ...grpc.CallOption) (*SimpleResponse, error) { 
  2.  out := new(SimpleResponse) 
  3.  err := c.cc.Invoke(ctx, "/proto.Simple/GetSimpleInfo"inout, opts...) 
  4.  if err != nil { 
  5.   return nil, err 
  6.  } 
  7.  return out, nil 

但是服務(wù)端的方法需要自己實(shí)現(xiàn),畢竟是服務(wù)提供方,服務(wù)的具體邏輯是由我們自己來(lái)定的。

4.最后還有一個(gè)注冊(cè)服務(wù)的函數(shù),我們需要做的就是,自己去定義一個(gè) struct 對(duì)象,實(shí)現(xiàn)上面提到的 SimpleServer 接口,然后把那個(gè) struct 注冊(cè)到 gRPC 服務(wù)上。

  1. func RegisterSimpleServer(s *grpc.Server, srv SimpleServer) { 
  2.  s.RegisterService(&_Simple_serviceDesc, srv) 

總結(jié)

這篇文章主要介紹了 gRPC 第一種交互模式 - Simple RPC,演示了最基礎(chǔ)的 demo,大家重點(diǎn)需要掌握以下兩點(diǎn):

服務(wù)端和客戶端的實(shí)現(xiàn)流程;

simple.pb.go 的內(nèi)容;

 

責(zé)任編輯:武曉燕 來(lái)源: Golang來(lái)啦
相關(guān)推薦

2021-06-30 07:19:35

雙向流式RPCgRPC

2023-02-07 10:40:30

gRPC系統(tǒng)Mac

2009-04-08 13:22:55

PHPXMLWeb Service

2011-11-29 16:38:58

Knockout

2012-02-29 01:03:10

ubuntuLinux

2011-05-18 15:15:44

MySQL

2010-08-03 15:19:08

FlexBuilder

2021-03-26 10:31:19

人工智能AIOps

2011-03-08 09:22:37

2024-01-02 12:17:44

Go傳統(tǒng)遠(yuǎn)程

2023-06-10 23:01:41

GrpcProtobuf數(shù)據(jù)

2011-03-01 11:28:54

2013-01-08 13:33:07

Android開發(fā)Activity入門指南

2019-10-12 00:24:29

微隔離SDN安全架構(gòu)

2010-07-20 16:13:25

Perl線程

2010-12-31 13:30:12

2011-01-10 13:21:45

linuxsamba

2015-09-24 09:54:32

物聯(lián)網(wǎng)

2019-07-18 07:52:01

路由策略IP路由

2022-05-08 16:42:27

Rust編程語(yǔ)言
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)