>백엔드 개발 >Golang >gRPC-go의 `mustEmbedUnimplemented*`는 서버 구현에 대한 향후 호환성을 어떻게 보장합니까?

gRPC-go의 `mustEmbedUnimplemented*`는 서버 구현에 대한 향후 호환성을 어떻게 보장합니까?

DDD
DDD원래의
2024-11-29 12:40:111076검색

How Does `mustEmbedUnimplemented*` in gRPC-go Ensure Forward Compatibility for Server Implementations?

MustEmbedUnimplemented* 향후 호환성을 위한 gRPC의 메서드

grpc-go는 최근에 mustEmbedUnimplemented* 메서드를 도입했습니다. 서버 구현의 향후 호환성. 이전에는 서버 구현이 proto 정의에 정의된 모든 메서드를 구현하지 않고도 서비스를 등록할 수 있었습니다. 이로 인해 proto에 새 메소드를 추가하면 서버 구현 누락으로 인해 컴파일 시간 오류가 발생하는 경우가 발생했습니다.

mustEmbedUnimplemented* 메소드 사용:

  • 향후 호환성: 서버 구현에는 이제 다음을 포함해야 합니다. 구현되지 않은*ServiceServer, 컴파일 시간 오류 없이 새 메서드를 추가할 수 있습니다. 그러나 구현되지 않은 메서드를 호출하려고 시도하면 code.Unimplemented와 함께 런타임 오류가 발생합니다.
  • 옵트아웃: 개발자는 Unsafe* 대신 ServiceServer를 사용하세요. 이렇게 하면 런타임 오류는 방지되지만 메서드가 구현되지 않은 경우 컴파일 시간 오류는 유지됩니다.
예:

// Implements gRPC FooBarServiceServer
type FooBarService struct {
    grpc.UnsafeFooBarServiceServer // Opt out of forward compatibility
    // other fields
}
코드 생성에서 상위 호환성을 비활성화하려면:

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

* 메소드는 서버가 구현은 항상 최신 proto 정의로 업데이트되어 잠재적인 불일치를 방지합니다. 이전 버전과의 호환성을 유지하면서 기존 코드를 손상시키지 않고 새로운 메소드를 추가하는 우아한 방법을 제공합니다.

위 내용은 gRPC-go의 `mustEmbedUnimplemented*`는 서버 구현에 대한 향후 호환성을 어떻게 보장합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.