亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

是跨 goroutines 的 gRPC 客戶端/存根使用

是跨 goroutines 的 gRPC 客戶端/存根使用

Go
catspeake 2023-01-03 16:03:17
我正在試驗 Protobuf 和 gRPC,并且正在學習 Go 基礎教程:https ://www.grpc.io/docs/languages/go/basics/從我在有關 ClientConn 的文檔中看到的內容來看,同時使用相同的ClientConn似乎是安全的。但是我對創建的存根/客戶端一無所知......假設我通過 HTTP POST 請求接收數據,我想通過 gRPC 作為 protobuf 轉發該數據,然后響應 HTTP 請求。我應該在每次處理 HTTP 請求時都創建一個客戶端/存根,還是可以在設置 HTTP 服務器時創建客戶端/存根并在設置 HTTP 處理程序時傳入客戶端/存根?示例:我認為這沒問題var opts []grpc.DialOptionconn, err := grpc.Dial("127.0.0.1:1234", opts...)if err != nil {    log.Panic(err)}defer conn.Close()grpcService := service.Service{GRPC: conn}http.HandleFunc("/", util.ValidateRequest(grpcService.HandleRoot))// listen to porthttp.ListenAndServe(fmt.Sprintf("%s:%d", viper.GetString("server.address"), viper.GetInt32("server.port")), nil)但是這個呢var opts []grpc.DialOptionconn, err := grpc.Dial("127.0.0.1:1234", opts...)if err != nil {    log.Panic(err)}defer conn.Close()client := pb.NewEventShipperClient(conn)grpcService := service.Service{GRPC: conn, Client: client}http.HandleFunc("/", util.ValidateRequest(grpcService.HandleRoot))// listen to porthttp.ListenAndServe(fmt.Sprintf("%s:%d", viper.GetString("server.address"), viper.GetInt32("server.port")), nil)
查看完整描述

1 回答

?
慕尼黑的夜晚無繁華

TA貢獻1864條經驗 獲得超6個贊

生成代碼參考中涵蓋了線程安全(“同時運行它是否安全”):

線程安全:請注意,客戶端 RPC 調用和服務器端 RPC 處理程序是線程安全的,旨在并發 goroutines 上運行。但還要注意,對于單個流,傳入和傳出數據是雙向的但串行的;因此,例如,單個流不支持并發讀取或并發寫入(但讀取與寫入是安全并發的)。

所以,是的,可以同時調用struct返回的方法。pb.NewEventShipperClient(conn)

您也可以通過查看pb.NewEventShipperClient. 目前(我想這可能會改變)唯一的成員變量將是一個接口(cc grpc.ClientConnInterface- 實現*ClientConn),每個方法都使用到InvokegRPC 調用的連接。

但是請注意,您在實施時需要小心,service.Service以確保它也是線程安全的,并注意有關流的警告。


查看完整回答
反對 回復 2023-01-03
  • 1 回答
  • 0 關注
  • 109 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號