首頁 >後端開發 >Golang >如何透過單一連線存取多個gRPC服務?

如何透過單一連線存取多個gRPC服務?

Mary-Kate Olsen
Mary-Kate Olsen原創
2024-11-03 19:28:29930瀏覽

How to Access Multiple gRPC Services Over a Single Connection?

透過單一連線存取多個 gRPC 服務

為什麼為每個 gRPC 服務撥打不同的套接字?

存取在同一個上執行的 gRPC 服務時伺服器,無需為每個服務建立單獨的連線。單一 grpc.ClientConn 可用於存取所有服務。

如何共享連線?

要共享連接,請使用所需端點建立一個 grpc.ClientConn 並將其傳遞給pb.New*Client() 函數用於您想要使用的每個服務。這允許它們利用相同的連接。

<code class="go">cc, err := grpc.Dial("localhost:6000", grpc.WithInsecure())
if err != nil {
    log.Fatal(err)
}
c1 := pb.NewSubscriberServiceClient(cc)
c2 := pb.NewDropperServiceClient(cc)</code>

使用介面來組合客戶端實作?

雖然您可以建立一個介面來組合多個服務的客戶端 gRPC 功能,但pb.go 中產生的程式碼處理所有基本操作。僅特定自訂邏輯需要實現新功能。

對於具有唯一方法名稱的服務,您可以定義一個方便的結構來捆綁其客戶端:

<code class="go">type SubscriberDropper struct {
    pb.SubscriberServiceClient
    pb.DropperServiceClient
}</code>

透過一個存取多個gRPC 服務單連接簡化了客戶端實現並提高了程式碼可維護性。

以上是如何透過單一連線存取多個gRPC服務?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn