首頁 >後端開發 >Golang >gRPC 的「mustEmbedUnimplemented」如何增強伺服器前向相容性?

gRPC 的「mustEmbedUnimplemented」如何增強伺服器前向相容性?

DDD
DDD原創
2024-11-30 11:34:11177瀏覽

How Does gRPC's `mustEmbedUnimplemented` Enhance Server Forward Compatibility?

gRPC 中使用 MustEmbedUnimplemented 的前向相容性*

gRPC-go 庫引入了 MustEmbedUnimplemented***方法來增強伺服器中的前向相容性

過去,如果需要方法,gRPC 伺服器會編譯失敗沒有實作。為了緩解這種情況,開發人員必須手動實現未實現的方法,即使它們並不打算使用。

mustEmbedUnimplemented* 透過選擇退出前向相容性解決了這個問題。這意味著:

  • 伺服器現在必須明確嵌入 Unimplemented*** 介面以選擇退出前向相容性。
  • 透過嵌入 Unimplemented***,伺服器將不會收到編譯時資訊缺少方法實作的錯誤,但如果呼叫未實作的方法,則會在執行時間失敗。

例如,如果您有一個GreetService 介面:

type GreetService interface {
    Greet(ctx context.Context, req *pb.GreetRequest, opts ...gax.CallOption) (*pb.GreetResponse, error)
}

您之前將其實作為:

type server struct {...}
func (s *server) Greet(ctx context.Context, req *pb.GreetRequest, opts ...gax.CallOption) (*pb.GreetResponse, error) {...}
func (s *server) MustEmbeddUnimplementedGreetServiceServer() {...}

現在,使用MustEmbedUnimple🎜>

type server struct {
    grpc.UnsafeGreetServiceServer
    ...
}
現在,使用MustEmbedUnimplemented*** ,您可以透過嵌入Unsafe* 來選擇退出前向相容性**改為介面:

此變更提供了更大的靈活性並防止伺服器中出現不必要的程式碼實作。

以上是gRPC 的「mustEmbedUnimplemented」如何增強伺服器前向相容性?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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