繁体   English   中英

如果kafka中不存在属性中的kafka主题名称,如何中断启动spring-boot应用程序?

[英]How can I interrupt startup spring-boot application if kafka topic name from properties does not exist in kafka?

我尝试在启动spring-boot应用程序上检查Kafka主题。 我想抛出异常并中断启动。 这是我的配置:

@Slf4j
@Configuration
public class KafkaTopicConfig implements ApplicationRunner {

    private final KafkaAdmin kafkaAdmin;
    private final TopicProperties topicProperties;

    public KafkaTopicConfig(KafkaAdmin kafkaAdmin, TopicProperties topicProperties) {
        this.kafkaAdmin = kafkaAdmin;
        this.topicProperties = topicProperties;
    }

    @Override
    public void run(ApplicationArguments args) throws Exception {
        AdminClient admin = AdminClient.create(kafkaAdmin.getConfig());

        ListTopicsResult listTopicsResult = admin.listTopics();
        listTopicsResult.names().whenComplete((existTopics, throwable) -> {
            log.info("TOPICS LOAD: {}", existTopics.size());
            topicProperties.getTopics().forEach((s, topic) -> {
                if (!existTopics.contains(topic))
                    throw new IllegalStateException("Topic with name: " + topic + " not found in kafka.");
            });
        });
    }
}

但抛出后抛出throw new IllegalStateException("Topic with name: " + topic + " not found in kafka."); 此异常被忽略,应用程序继续工作。

而不是ApplicationRunner ,使用SmartLifecycle autoStartup=true实现SmartLifecycle并将您的逻辑放在start()

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM