关于kafka高级API(新)的多线程测试

博客提及测试场景,将相关程序关掉后,Kafka 继续向主题生产数据,之后再启动,能看到 Kafka 从保存的 offset 处继续消费数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

public class MyTestThreads {
    public static void main(String[] args) {
      

        //因为KafkaConsumer不是线程安全的,使用一个对象会报异常
        //ConcurrentModificationException: KafkaConsumer is not safe for multi-threaded access
        new Thread(new MyConsumerThread(),"a").start();

        new Thread(new MyConsumerThread(),"b").start();


    }
}

class MyConsumerThread implements Runnable {
    KafkaConsumer<String, String> consumer;
    public  MyConsumerThread(){
        Properties properties = PropertyUtil.properties;
       consumer = new KafkaConsumer<>(properties);
    }
    @Override
    public void run() {
        consumer.subscribe(Arrays.asList("dai"));
        while(true){
            ConsumerRecords<String,String> records = consumer.poll(1000);
            for (ConsumerRecord<String, String> record : records) {
                System.out.println(Thread.currentThread().getName()+"进行了消费"+record.value()+"分区是"+record.partition()+"偏移量是"+record.offset());
            }

        }

    }
}

测试

  
        a进行了消费ddd分区是0偏移量是15
        b进行了消费eee分区是2偏移量是17
        a进行了消费wade分区是1偏移量是17
        a进行了消费pual分区是0偏移量是16
         

关掉,kafka继续向主题生产,然后再启动,可以看见从保存的offset继续消费

b进行了消费james分区是2偏移量是18
a进行了消费antony分区是1偏移量是18
a进行了消费kobe分区是0偏移量是17

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值