【spring boot】 重启kafka客户端连接

背景

kafka 服务端重建时,kafka客户端会连不上kafka服务端,此时需要重启客户端重连

代码实现

@Service
public class KafkaConsumerService {
    private KafkaConsumer<String, String> consumer;
    
    @Autowired
    private KafkaProperties kafkaProperties;

   //在应用程序启动时初始化Kafka消费者,并启动一个单独的线程用于消费消息
    @PostConstruct
    public void init() {
        consumer = new KafkaConsumer<>(kafkaProperties.buildConsumerProperties());
        consumer.subscribe(Arrays.asList("myTopic"));
        Executors.newSingleThreadExecutor().submit(this::consume);
    }

    @PreDestroy
    public void destroy() {
        consumer.close();
    }

    private void consume() {
        while (true) {
            ConsumerRecords<String, String> records = consumer.poll(Duration.ofMillis(100));
            for (ConsumerRecord<String, String> record : records) {
                // 处理消息逻辑
            }
        }
    }

   //先关闭现有的Kafka消费者,然后创建一个新的消费者实例,并重新订阅我们的主题。最后,我们使用 ExecutorService 启动一个新的消费者线程
    public void restart() {
        consumer.close();
        consumer = new KafkaConsumer<>(kafkaProperties.buildConsumerProperties());
        consumer.subscribe(Arrays.asList("myTopic"));
        Executors.newSingleThreadExecutor().submit(this::consume);
    }
}

posted @ 2023-04-23 10:25  xiaoyu_jane  阅读(868)  评论(0编辑  收藏  举报