kafka java 小记录

本文章 方便日后查看使用。

创建kafka消费者(此处没啥可讲的,看注释吧。 手动版本的,更加灵活)

复制代码
    public KafkaConsumer<String, String> getCustomer() {
        // 1. 配置属性参数
        Properties properties = new Properties();

        // 设置Kafka集群的地址和端口,消费者将连接到这个地址和端口
        properties.put(ConsumerConfig.BOOTSTRAP_SERVERS_CONFIG, "localhost:9092");

        // 设置键(Key)的反序列化器为StringDeserializer,用于将字节数据转换为String类型
        properties.put(ConsumerConfig.KEY_DESERIALIZER_CLASS_CONFIG, StringDeserializer.class.getName());
        // 设置值(Value)的反序列化器为StringDeserializer,用于将字节数据转换为String类型
        properties.put(ConsumerConfig.VALUE_DESERIALIZER_CLASS_CONFIG, StringDeserializer.class.getName());

        // 设置消费者所属的消费者组,消费者组内的消费者将共同消费同一个Topic的消息
        properties.put(ConsumerConfig.GROUP_ID_CONFIG, "test-group");
        // 设置消费者与Kafka集群之间的会话超时时间(单位:毫秒)
        properties.put(ConsumerConfig.SESSION_TIMEOUT_MS_CONFIG, 10000);
        // 设置消费者是否自动提交offset,true表示自动提交
        properties.put(ConsumerConfig.ENABLE_AUTO_COMMIT_CONFIG, true);
        // 设置自动提交offset的时间间隔(单位:毫秒)
        properties.put(ConsumerConfig.AUTO_COMMIT_INTERVAL_MS_CONFIG, 5000);
        // 设置每次poll操作返回的最大记录数
        properties.put(ConsumerConfig.MAX_POLL_RECORDS_CONFIG,5);

        // 根据配置属性创建Kafka消费者实例
        return new KafkaConsumer<>(properties);
    }

使用kafka开始消费

复制代码
    @Test
    void KafkaConsumerTest() {
        KafkaConsumer<String, String> consumer = kafkaNdpiCustomer.getCustomer();

        // 订阅要消费的主题,这里是 "test Topic"
        consumer.subscribe(Collections.singletonList("test-Topic"));


        ConsumerRecords<String, String> records = consumer.poll(Duration.ofMillis(1000));
        for (ConsumerRecord<String, String> record : records) {
                // 处理消息的逻辑
                System.out.printf("消息为:offset = %d, key = %s, value = %s%n", record.offset(), record.key(), record.value());
//                boolean flag = true;
//                if (flag){
//                    consumer.commitAsync();
//                    break;
//                }
        }
        consumer.close();
        System.out.println("结束消费");
    }

其中 consumer.commitAsync(); 为异步提交,不选择则不会像kafka报告已经消费,可以重复使用,

相关推荐
Grey Zeng2 小时前
Java SE 25新增特性
java·jdk·jdk新特性·jdk25
雨白3 小时前
Java 线程通信基础:interrupt、wait 和 notifyAll 详解
android·java
AAA修煤气灶刘哥4 小时前
别让Redis「歪脖子」!一次搞定数据倾斜与请求倾斜的捉妖记
redis·分布式·后端
架构师沉默7 小时前
设计多租户 SaaS 系统,如何做到数据隔离 & 资源配额?
java·后端·架构
Java中文社群9 小时前
重要:Java25正式发布(长期支持版)!
java·后端·面试
阿里云云原生10 小时前
嘉银科技基于阿里云 Kafka Serverless 提升业务弹性能力,节省成本超过 20%
kafka·serverless
每天进步一点_JL10 小时前
JVM 类加载:双亲委派机制
java·后端
用户2986985301410 小时前
Java HTML 转 Word 完整指南
java·后端
渣哥10 小时前
原来公平锁和非公平锁差别这么大
java
渣哥11 小时前
99% 的人没搞懂:Semaphore 到底是干啥的?
java