日本熟妇hd丰满老熟妇,中文字幕一区二区三区在线不卡 ,亚洲成片在线观看,免费女同在线一区二区

在Knative中部署gRPC服務

如果您的Knative服務采用分布式系統或微服務架構場景,您可以使用gRPC協議提升客戶端與服務器端的通訊效率。ACS Knative支持HTTP、HTTP2(包括gRPC)訪問協議。您可以在Knative Service的YAML文件中部署gRPC服務,Knative網關能自動實現對gRPC協議的路由。

前提條件

已在ACS集群中部署Knative。具體操作,請參見部署Knative

步驟一:部署gRPC服務

  1. 登錄容器計算服務控制臺,在左側導航欄選擇集群

  2. 集群頁面,單擊目標集群ID,然后在左側導航欄,選擇應用 > Knative

  3. Knative頁面的服務管理頁簽下,選擇命名空間default,然后單擊使用模板創建,單擊示例模板右側的下拉列表,選擇自定義,將以下示例代碼粘貼至模板,最后單擊創建,創建一個名為helloworld-grpc的Knative服務。

    apiVersion: serving.knative.dev/v1
    kind: Service
    metadata:
      name: helloworld-grpc
    spec:
      template:
        metadata:
          annotations:
            autoscaling.knative.dev/class: mpa.autoscaling.knative.dev
        spec:
          containers:
          - image: docker.io/moul/grpcbin # 該鏡像是一個用于測試gRPC的工具,它通過提供gRPC服務來響應請求。
            env:
            - name: TARGET
              value: "Knative"
            ports:
            - containerPort: 9000
              name: h2c # gRPC服務在Knative服務中port字段下的name設置為h2c。
              protocol: TCP
  4. 在Hosts文件中添加綁定信息。將服務管理頁面的默認域名訪問網關進行Host綁定。

    找到計算機中Hosts文件所在位置,然后在Hosts文件中添加綁定信息,格式為訪問網關+空格+默認域名,然后通過域名直接訪問服務。綁定樣例如下:

    121.xx.xxx.xx helloworld-grpc.default.example.com

步驟二:驗證gRPC服務的可用性

  1. 訪問grpcbin,安裝適用于您操作系統的BloomRPC。

  2. 將以下代碼粘貼至gRPC.proto文件,然后保存至本地。

    syntax = "proto3";
    
    package grpcbin;
    
    service GRPCBin {
      rpc Index(EmptyMessage) returns (IndexReply) {}
      // 無參數調用的方法,調用后回返回一個空響應。
      rpc Empty(EmptyMessage) returns (EmptyMessage) {}
      // 響應會返回請求的參數。
      rpc DummyUnary(DummyMessage) returns (DummyMessage) {}
      // 響應為流式的調用,會分10次響應消息。
      rpc DummyServerStream(DummyMessage) returns (stream DummyMessage) {}
      // 請求為流式的調用,會接受10次請求并返回最后一次的body。
      rpc DummyClientStream(stream DummyMessage) returns (DummyMessage) {}
      // 請求響應都為流式的方法。
      rpc DummyBidirectionalStreamStream(stream DummyMessage) returns (stream DummyMessage) {}
      // 該方法會返回指定的grpc錯誤。
      rpc SpecificError(SpecificErrorRequest) returns (EmptyMessage) {}
      // 該方法調用會隨機返回一個錯誤。
      rpc RandomError(EmptyMessage) returns (EmptyMessage) {}
      // 該方法調用會返回header。
      rpc HeadersUnary(EmptyMessage) returns (HeadersMessage) {}
      // 該方法調用不會返回響應。
      rpc NoResponseUnary(EmptyMessage) returns (EmptyMessage) {}
    }
    
    message HeadersMessage {
      message Values {
        repeated string values = 1;
      }
      map<string, Values> Metadata = 1;
    }
    
    message SpecificErrorRequest {
      uint32 code = 1;
      string reason = 2;
    }
    
    message EmptyMessage {}
    
    message DummyMessage {
      message Sub {
        string f_string = 1;
      }
      enum Enum {
        ENUM_0 = 0;
        ENUM_1 = 1;
        ENUM_2 = 2;
      }
      string f_string = 1;
      repeated string f_strings = 2;
      int32 f_int32 = 3;
      repeated int32 f_int32s = 4;
      Enum f_enum = 5;
      repeated Enum f_enums = 6;
      Sub f_sub = 7;
      repeated Sub f_subs = 8;
      bool f_bool = 9;
      repeated bool f_bools = 10;
      int64 f_int64 = 11;
      repeated int64 f_int64s= 12;
      bytes f_bytes = 13;
      repeated bytes f_bytess = 14;
      float f_float = 15;
      repeated float f_floats = 16;
    }
    
    message IndexReply {
      message Endpoint {
        string path = 1;
        string description = 2;
      }
      string description = 1;
      repeated Endpoint endpoints = 2;
    }

    gRPC服務底層基于HTTP2協議,其路徑格式為{包名}.{服務名}/{方法名},基于此,Knative網關可以在Path字段中實現對gRPC協議的路由。例如,如果使用gRPC訪問grpcbin的Index方法,在HTTP2協議中,該Path字段值為grpcbin.GRPCBin/Index

  3. 使用BloomRPC測試gRPC服務的可用性,若服務端正常返回響應,則表示gRPC服務可用。

    1. gRPC.proto文件導入BloomRPC。

    2. 在左側導航欄,單擊DummyUnary調用方法,并在頁面頂部設置調用域名:端口。例如helloworld-grpc.default.example.com:80

    3. 單擊綠色執行按鈕,查看服務端返回的響應是否正常。

相關文檔

您可以為自定義域名配置相應的HTTPS證書,請參見配置HTTPS證書訪問