kafka java 多线程_实现一个简单的Kafka多线程消费模型

本文介绍了如何使用Kafka API实现一个简单的多线程消费模型。通过创建KafkaConsumerClient,设置线程池处理数据,以及配置消费者参数如bootstrap.servers、group.id等。在消费线程中循环拉取数据并提交偏移,数据处理线程负责具体的消息处理。建议根据实际需求调整线程池参数以保证告警数据不丢失。

最近项目上用到了Kafka(作为数据源接入),这里将自己的实践分享出来,供大家参考或针砭。

从网上查阅资料发现,基本上有2中与Kafka对接的方式:

1.Spring-Kafka2.调用Kafka API自己实现ConsumerClient

Spring-Kafka的基本原理就是Spring自动轮询Poll数据,通过监听器MessageListener.onMessage()向用户自定义的消费入口(@KafkaListener)推送数据。因此对于用户来说,仅需要关注自己的业务实现即可,Kafka数据对于业务来说就是一个方法的入参而已。这种设计很有意思,因为Kafka是不支持主动Push的,但是Spring-Kafka自己实现了这种角色反转。Spring-Kafka本身就是一个很好的实现,而且上手相对简单,推荐大家使用这种方式。

温馨提示:Spring-Kafka和kafka-clients之间有版本的兼容性问题需特别注意,另外如果你使用SpringBoot开发的话也需要匹配特定的版本。

5b8079051fb73351877c414dc011df7b.png

6a5bc46a660541ec615ec7faca8835dc.png

#Spring-Kafka KafkaConsumer消费模型(来源于网络)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值