Home >Backend Development >Golang >What is gRPC's `mustEmbedUnimplemented` Method and How Does it Ensure Forward Compatibility?

What is gRPC's `mustEmbedUnimplemented` Method and How Does it Ensure Forward Compatibility?

Susan Sarandon
Susan SarandonOriginal
2024-11-30 17:59:091078browse

What is gRPC's `mustEmbedUnimplemented` Method and How Does it Ensure Forward Compatibility?

Understanding gRPC's mustEmbedUnimplemented Method*

In its most recent update, gRPC-go has introduced the mustEmbedUnimplemented* method to ensure forward compatibility in its servers. But what exactly does it do?

Prior to mustEmbedUnimplemented*

Previously, registering a server implementation involved registering it directly, as shown:

        pb.RegisterFooBarServiceServer(
            server,
            &FooBarServer{}, // or whatever you use to construct the server impl
        )

If the server lacked certain method implementations, it would result in errors during compilation.

Introducing mustEmbedUnimplemented*

With the updated protoc-gen-grpc-go compiler, forward-compatibility becomes the default. This means:

  1. Mandating mustEmbedUnimplementedFooBarServiceServer: Including this statement in server implementations prevents compile-time errors when new methods are not explicitly implemented. However, if unimplemented methods are called, it triggers a run-time error (code.Unimplemented).
  2. Opting Out with Unsafe FooBarServiceServer: Developers can opt out of forward compatibility by embedding UnsafeFooBarServiceServer instead. This interface incorporates the mustEmbedUnimplementedFooBarServiceServer() method, eliminating the compile-time error while still allowing explicit implementation of new handlers.

Configuring Forward Compatibility

Additionally, forward compatibility can be disabled by setting the following option when using protoc-gen-grpc-go:

protoc --go-grpc_out=require_unimplemented_servers=false:.

Benefits

mustEmbedUnimplemented* ensures that servers are always forward compatible, preventing unexpected errors caused by unimplemented methods. By opting out with Unsafe FooBarServiceServer, developers can maintain backward compatibility while still adhering to the principles of forward compatibility.

The above is the detailed content of What is gRPC's `mustEmbedUnimplemented` Method and How Does it Ensure Forward Compatibility?. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn