KafkaConsumer 流程解析

2018-05-06  本文已影响0人  桥头桥尾

前言

对于中间件的使用都必须按照他们自己的规范和流程来使用, KafkaConsumer也对消息的负载消费定义了流程,新版本的流程跟老版本的流程有一些改变,这里只对新版本的流程来介绍,同时也会介绍这样去设计组件与流程的好处

KafkaConsumer 对于多线程访问是不安全的,通过使用acquire()release()方法来操作AtomicLong currentThread字段(保存当前访问线程ID), 有多个线程同时访问抛出ConcurrentModificationException, 来防止对个线程同时访问。

核心组件

工作流程

kafka是以拉模式去消费数据,可由用户自由控制消费速度,对用户的消费位置可以选择自动异步commit,或者由用户主动同步commit, 实例代码如下:

KafkaConsumer consumer = ...
consumer.subscribe(Arrays.asList("topic"));
while (!closed.get()) {
    ConsumerRecords records = consumer.poll(long timeout);
    // Handle new records 用户处理消息
    // consumer.commitSync 可由用户自主提交消费位置
}

时序图:


消费流程
上一篇 下一篇

猜你喜欢

热点阅读