Vorwärtskompatibilität in gRPC mit mustEmbedUnimplemented*
Die gRPC-go-Bibliothek hat die Methode mustEmbedUnimplemented*** eingeführt, um die Vorwärtskompatibilität im Server zu verbessern Implementierungen.
In der Vergangenheit schlugen gRPC-Server bei der Kompilierung fehl, wenn erforderliche Methoden vorhanden waren nicht umgesetzt. Um dies abzumildern, mussten Entwickler nicht implementierte Methoden manuell implementieren, auch wenn sie nicht für die Verwendung vorgesehen waren.
mustEmbedUnimplemented* löst dieses Problem, indem die Vorwärtskompatibilität deaktiviert wird. Das bedeutet:
Zum Beispiel, wenn Sie eine haben GreetService-Schnittstelle:
type GreetService interface { Greet(ctx context.Context, req *pb.GreetRequest, opts ...gax.CallOption) (*pb.GreetResponse, error) }
Sie würden es zuvor wie folgt implementieren:
type server struct {...} func (s *server) Greet(ctx context.Context, req *pb.GreetRequest, opts ...gax.CallOption) (*pb.GreetResponse, error) {...} func (s *server) MustEmbeddUnimplementedGreetServiceServer() {...}
Jetzt können Sie mit mustEmbedUnimplemented*** die Vorwärtskompatibilität deaktivieren, indem Sie unsichere***-Schnittstellen einbetten stattdessen:
type server struct { grpc.UnsafeGreetServiceServer ... }
Diese Änderung bietet mehr Flexibilität und verhindert unnötigen Code in Ihren Serverimplementierungen.
Das obige ist der detaillierte Inhalt vonWie verbessert „mustEmbedUnimplemented' von gRPC die Server-Vorwärtskompatibilität?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!