当 Kafka 消费者无法连接时快速失败

Fail Fast When Kafka Consumer Can't Connect

为了我自己的目的,如果 Kafka 消费者无法连接到代理,我需要 Spring 引导应用程序停止。 我的意思是,当 Kafka Consumer 尝试合并消息时,我们可以看到以下日志:

[Consumer clientId=consumer-ddddd-1, groupId=ddddd] Bootstrap broker localhost:9094 (id: -1 rack: null) disconnected
[Consumer clientId=consumer-ddddd-1, groupId=ddddd] Connection to node -1 (localhost/127.0.0.1:9094) could not be established. Broker may not be available.

这是主题或代理不可用时的标准行为。结果 - 应用程序不会停止。但是我需要。

我正在尝试添加以下属性,但它不起作用:

spring.kafka.consumer.fetch-max-wait=1000
spring.kafka.admin.fail-fast=true
spring.kafka.session.timeout.ms=1000

通常我希望获得如下行为:IF CONSUMER CAN'T CONNECT - SHUTDOWN APPLICATION

Kafka 轮询示例:

consumer.poll(Duration.ofMinutes(5));

作为其中一种方法 - 我们可以使用上面的评论。或者我刚刚根据以下代码创建了验证并且它有效

    public void validate() {
        try {
            consumer.listTopics(Duration.ofSeconds(10));
        } catch (TimeoutException e) {
            logger.error("Topics doesn't exist OR unavailable broker");
            System.exit(1);
        }
    }