• Kafka3.0.0版本——消费者(手动提交offset)


    一、消费者(手动提交 offset)的概述

    1.1、手动提交offset的两种方式

    • commitSync(同步提交):必须等待offset提交完毕,再去消费下一批数据。
    • commitAsync(异步提交) :发送完提交offset请求后,就开始消费下一批数据了。

    1.2、手动提交offset两种方式的区别

    • 相同点:都会将本次提交的一批数据最高的偏移量提交。
    • 不同点是:同步提交阻塞当前线程,一直到提交成功,并且会自动失败重试(由不可控因素导致,也会出现提交失败);而异步提交则没有失败重试机制,故有可能提交失败。

    1.3、手动提交offset的图解

    在这里插入图片描述

    二、消费者(手动提交 offset)的代码示例

    2.1、手动提交 offset(采用同步提交的方式)代码

    • 同步提交代码
      由于同步提交 offset 有失败重试机制,故更加可靠,但是由于一直等待提交结果,提交的效率比较低。

       // 是否自动提交 offset
      properties.put(ConsumerConfig.ENABLE_AUTO_COMMIT_CONFIG,false);
      // 手动提交offset(同步提交)
      kafkaConsumer.commitSync();
      
      • 1
      • 2
      • 3
      • 4
    • 同步提交完整代码

      package com.xz.kafka.consumer;
      
      import org.apache.kafka.clients.consumer.ConsumerConfig;
      import org.apache.kafka.clients.consumer.ConsumerRecord;
      import org.apache.kafka.clients.consumer.ConsumerRecords;
      import org.apache.kafka.clients.consumer.KafkaConsumer;
      import org.apache.kafka.common.serialization.StringDeserializer;
      
      import java.time.Duration;
      import java.util.ArrayList;
      import java.util.Properties;
      
      public class CustomConsumerByHandSync {
      
          public static void main(String[] args) {
      
              // 配置
              Properties properties = new Properties();
      
              // 连接 bootstrap.servers
              properties.put(ConsumerConfig.BOOTSTRAP_SERVERS_CONFIG,"192.168.136.27:9092,192.168.136.28:9092,192.168.136.29:9092");
      
              // 反序列化
              properties.put(ConsumerConfig.KEY_DESERIALIZER_CLASS_CONFIG, StringDeserializer.class.getName());
              properties.put(ConsumerConfig.VALUE_DESERIALIZER_CLASS_CONFIG, StringDeserializer.class.getName());
      
              // 配置消费者组id
              properties.put(ConsumerConfig.GROUP_ID_CONFIG,"test3");
      
              // 手动提交
              properties.put(ConsumerConfig.ENABLE_AUTO_COMMIT_CONFIG,false);
      
              // 1 创建一个消费者  "", "hello"
              KafkaConsumer<String, String> kafkaConsumer = new KafkaConsumer<>(properties);
      
              // 2 订阅主题 sevenTopic
              ArrayList<String> topics = new ArrayList<>();
              topics.add("sevenTopic");
              kafkaConsumer.subscribe(topics);
      
              // 3 消费数据
              while (true){
      
                  ConsumerRecords<String, String> consumerRecords = kafkaConsumer.poll(Duration.ofSeconds(1));
      
                  for (ConsumerRecord<String, String> consumerRecord : consumerRecords) {
                      System.out.println(consumerRecord);
                  }
      
                  // 手动提交offset(同步提交)
                  kafkaConsumer.commitSync();
              }
          }
      }
      
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
      • 7
      • 8
      • 9
      • 10
      • 11
      • 12
      • 13
      • 14
      • 15
      • 16
      • 17
      • 18
      • 19
      • 20
      • 21
      • 22
      • 23
      • 24
      • 25
      • 26
      • 27
      • 28
      • 29
      • 30
      • 31
      • 32
      • 33
      • 34
      • 35
      • 36
      • 37
      • 38
      • 39
      • 40
      • 41
      • 42
      • 43
      • 44
      • 45
      • 46
      • 47
      • 48
      • 49
      • 50
      • 51
      • 52
      • 53
      • 54

    2.1、手动提交 offset(采用异步提交的方式)代码

    • 异步提交代码
      虽然同步提交 offset 更可靠一些,但是由于其会阻塞当前线程,直到提交成功。因此吞吐量会受到很大的影响。因此更多的情况下,会选用异步提交 offset的方式。

       // 是否自动提交 offset
      properties.put(ConsumerConfig.ENABLE_AUTO_COMMIT_CONFIG,false);
      // 手动提交offset(异步提交)
      kafkaConsumer.commitAsync();
      
      • 1
      • 2
      • 3
      • 4
    • 异步提交完整代码

      package com.xz.kafka.consumer;
      
      import org.apache.kafka.clients.consumer.ConsumerConfig;
      import org.apache.kafka.clients.consumer.ConsumerRecord;
      import org.apache.kafka.clients.consumer.ConsumerRecords;
      import org.apache.kafka.clients.consumer.KafkaConsumer;
      import org.apache.kafka.common.serialization.StringDeserializer;
      
      import java.time.Duration;
      import java.util.ArrayList;
      import java.util.Properties;
      
      public class CustomConsumerByHandSync {
      
          public static void main(String[] args) {
      
              // 0 配置
              Properties properties = new Properties();
      
              // 连接 bootstrap.servers
              properties.put(ConsumerConfig.BOOTSTRAP_SERVERS_CONFIG,"192.168.136.27:9092,192.168.136.28:9092,192.168.136.29:9092");
      
              // 反序列化
              properties.put(ConsumerConfig.KEY_DESERIALIZER_CLASS_CONFIG, StringDeserializer.class.getName());
              properties.put(ConsumerConfig.VALUE_DESERIALIZER_CLASS_CONFIG, StringDeserializer.class.getName());
      
              // 配置消费者组id
              properties.put(ConsumerConfig.GROUP_ID_CONFIG,"test3");
      
              // 手动提交
              properties.put(ConsumerConfig.ENABLE_AUTO_COMMIT_CONFIG,false);
      
              // 1 创建一个消费者  "", "hello"
              KafkaConsumer<String, String> kafkaConsumer = new KafkaConsumer<>(properties);
      
              // 2 订阅主题 sevenTopic
              ArrayList<String> topics = new ArrayList<>();
              topics.add("sevenTopic");
              kafkaConsumer.subscribe(topics);
      
              // 3 消费数据
              while (true){
      
                  ConsumerRecords<String, String> consumerRecords = kafkaConsumer.poll(Duration.ofSeconds(1));
      
                  for (ConsumerRecord<String, String> consumerRecord : consumerRecords) {
                      System.out.println(consumerRecord);
                  }
                  // 手动提交offset(异步提交)
                  kafkaConsumer.commitAsync();
              }
          }
      }
      
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
      • 7
      • 8
      • 9
      • 10
      • 11
      • 12
      • 13
      • 14
      • 15
      • 16
      • 17
      • 18
      • 19
      • 20
      • 21
      • 22
      • 23
      • 24
      • 25
      • 26
      • 27
      • 28
      • 29
      • 30
      • 31
      • 32
      • 33
      • 34
      • 35
      • 36
      • 37
      • 38
      • 39
      • 40
      • 41
      • 42
      • 43
      • 44
      • 45
      • 46
      • 47
      • 48
      • 49
      • 50
      • 51
      • 52
      • 53
  • 相关阅读:
    【仿牛客网笔记】 Spring Boot进阶,开发社区核心功能-统一记录日志
    CSS学习250~272(精灵图+字体图标+CSS三角+CSS用户界面样式+vertical-align+溢出文本省略号显示+布局技巧+CSS初始化)
    python学习——numpy库的使用[超详细的学习笔记]
    Opengl ES之踩坑记
    大厂外包干了一个月,技术明显进步。。。。。
    IDEA操作Sharding-JDBC实战2
    功率放大器和电压放大器的区别是什么意思
    【python】文件操作
    string·模拟实现
    模式识别与图像处理课程实验二:基于UNet的目标检测网络
  • 原文地址:https://blog.csdn.net/li1325169021/article/details/132795237