最近项目上用到了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开发的话也需要匹配特定的版本。


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

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

被折叠的 条评论
为什么被折叠?



