我有这个代码:
s := grpc.NewServer()
pb.RegisterMessageServiceServer(s, &messageServer{})
我有这个错误:
无法使用“&messageServer{}”(type *messageServer),因为类型MessageServiceServer Type无法实现“MessageServiceServer”,因为它具有非导出的方法,并且在不同的包中定义
我的messageServer结构体看起来像:
type messageServer struct{}
func (s *messageServer) mustEmbedUnimplementedMessageServiceServer() {
//TODO implement me
panic("implement me")
}
func (s *messageServer) MustEmbedUnimplementedMessageServiceServer() {
//TODO implement me
panic("implement me")
}
func (s *messageServer) SendMessage(ctx context.Context, msg *pb.Message) (*pb.Response, error) {
// Write the message to Kafka
producer, err := sarama.NewSyncProducer([]string{kafkaBroker}, nil)
if err != nil {
log.Fatalf("Error creating Kafka producer: %v", err)
return nil, err
}
defer producer.Close()
kafkaMsg := &sarama.ProducerMessage{
Topic: kafkaTopic,
Value: sarama.StringEncoder(msg.Content),
}
_, _, err = producer.SendMessage(kafkaMsg)
if err != nil {
log.Printf("Failed to send message to Kafka: %v", err)
return nil, err
}
return &pb.Response{Message: "Message sent to Kafka"}, nil
}
错误在这一行:
pb.RegisterMessageServiceServer(s, &messageServer{}) // here
不知道发生了什么事:(
1条答案
按热度按时间thigvfpy1#
你不应该提供
mustEmbedUnimplementedMessageServiceServer()
的实现。你应该让你的服务器结构嵌入UnimplementedMessageServiceServer
。这个成员被命名为告诉你。界面还有一个doc注解,所有实现都必须嵌入UnimplementedMessageServiceServer以实现向前兼容性。
这个想法是,总有一天,gRPC开发人员可能会向服务器接口添加一个新方法。如果这样做了,它们还会向
unimplemented
类型添加一个新方法,该方法返回“method Blah not implemented”错误。由于你被迫将它们的unimplemented
类型嵌入到你的服务器类型中,你将继承那个方法,并得到一个抛出错误的默认实现,而不是让你的代码突然开始失败,因为你的服务器类型缺少新方法。