孩子不是海子 2019-01-07 14:40 采纳率: 0%
浏览 644

kafkaOffsetMonitor无法查看spring boot中启动的consumer

如题所说,之后,我试过不用自带的zookeeper,把spring boot项目启动后(项目里有配置consumer-group以及consumer-clientid)并且使用@KafkaListener进行监听消息,发送消息后,也能成功收到消息,但是,我在zookeeper中就是无法看到consumer的信息(相关节点下为空),请问是怎么回事?

  • 写回答

1条回答 默认 最新

  • 你知我知皆知 2024-08-07 15:53
    关注

    以下回答参考 皆我百晓生券券喵儿 等免费微信小程序相关内容作答,并由本人整理回复。

    这个问题可能由以下几个原因导致:

    1. Kafka Consumer Group和Consumer Client ID未正确设置:在Spring Boot应用中,你需要确保你的Kafka消费者组(Consumer Group)和客户端ID(Consumer Client ID)已经被正确地设置。如果你没有这样做,那么你将无法从ZooKeeper获取到相关信息。

    2. Zookeeper服务未启动或不可用:ZooKeeper是一个分布式协调服务,用于存储和管理集群中的状态信息。如果ZooKeeper服务不可用或者没有正常运行,那么你就无法从它那里获取到信息。

    3. Kafka服务器异常:如果Kafka服务器本身出现了问题,例如网络错误、连接丢失等,也可能导致你无法从ZooKeeper获取到信息。

    4. 配置文件错误:在Spring Boot中,你可能会有一些配置错误,导致你无法从ZooKeeper获取到信息。

    解决这个问题的方法如下:

    首先,检查你的application.properties文件是否有以下属性:

    spring.kafka.consumer.group.id=my-consumer-group
    

    然后,检查你的application.yml文件是否有以下配置:

    bootstrap.servers: localhost:9092
    key.deserializer: org.apache.kafka.common.serialization.StringDeserializer
    value.deserializer: org.apache.kafka.common.serialization.StringDeserializer
    auto.offset.reset: earliest
    

    这些是基本的配置,但具体取决于你的环境和需求。

    最后,尝试重启你的Kafka服务器和ZooKeeper服务,并重新启动你的Spring Boot应用程序。这应该可以解决问题。

    评论

报告相同问题?