Heim >Backend-Entwicklung >Golang >Was ist die „mustEmbedUnimplemented'-Methode von gRPC und wie stellt sie die Vorwärtskompatibilität sicher?

Was ist die „mustEmbedUnimplemented'-Methode von gRPC und wie stellt sie die Vorwärtskompatibilität sicher?

Susan Sarandon
Susan SarandonOriginal
2024-11-30 17:59:09955Durchsuche

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

Die Methode „mustEmbedUnimplemented“ von gRPC verstehenMethode*

In seinem neuesten Update hat gRPC-go die Methode „mustEmbedUnimplemented“ eingeführt*-Methode, um die Vorwärtskompatibilität auf seinen Servern sicherzustellen. Aber was genau macht es?

Vor mustEmbedUnimplemented*

Früher musste eine Serverimplementierung direkt registriert werden, wie gezeigt:

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

Wenn dem Server bestimmte Methodenimplementierungen fehlten, würde dies zu Fehlern führen Kompilierung.

Wir stellen vor: mustEmbedUnimplemented*

Mit dem aktualisierten protoc-gen-grpc-go-Compiler wird Vorwärtskompatibilität zur Standardeinstellung. Das bedeutet:

  1. MustEmbedUnimplementedFooBarServiceServer vorschreiben: Das Einschließen dieser Anweisung in Serverimplementierungen verhindert Fehler bei der Kompilierung, wenn neue Methoden nicht explizit implementiert werden. Wenn jedoch nicht implementierte Methoden aufgerufen werden, wird ein Laufzeitfehler (code.Unimplemented) ausgelöst.
  2. Deaktivierung mit Unsafe FooBarServiceServer: Entwickler können die Vorwärtskompatibilität deaktivieren, indem sie stattdessen UnsafeFooBarServiceServer einbetten . Diese Schnittstelle enthält die Methode „mustEmbedUnimplementedFooBarServiceServer()“, die den Fehler bei der Kompilierung beseitigt und dennoch die explizite Implementierung neuer Handler ermöglicht.

Konfigurieren der Vorwärtskompatibilität

Zusätzlich Die Vorwärtskompatibilität kann durch Festlegen der folgenden Option bei der Verwendung deaktiviert werden protoc-gen-grpc-go:

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

Vorteile

mustEmbedUnimplemented* stellt sicher, dass Server immer vorwärtskompatibel sind und verhindert, dass unerwartete Fehler verursacht werden durch nicht implementierte Methoden. Durch die Abmeldung von Unsafe FooBarServiceServer können Entwickler die Abwärtskompatibilität aufrechterhalten und gleichzeitig die Grundsätze der Vorwärtskompatibilität einhalten.

Das obige ist der detaillierte Inhalt vonWas ist die „mustEmbedUnimplemented'-Methode von gRPC und wie stellt sie die Vorwärtskompatibilität sicher?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn