springboot整合kafka实现 consume启动不起来_SpringBoot整合kafka,以及多播机制的应用...

最近做一个需求需要用SpringBoot整合Kafka的多播机制,所以就顺便写篇文章介绍一下自己的对Kafka多播机制的应用吧。

先说明一下我的需求,一个分布式系统内每个节点需要处理存在该节点本地的文件,但是处理的任务必须放到队列中排队避免高并发引起的系统崩溃。当时由于需要处理的文件都是在发出消息的节点上的,所以考虑之后决定使用Kafka的多播机制来实现。

首先简单讲解一下Kafka的多播机制。Kafka的消息是由消费组Group来消费的,Kafka会把消息复制多份发给每个注册的消费组一份。每个消费组内只消费该消息一次,也就是说只要这个消费组中有人消费了这个消息,这个消息就认为被消费了,但是不影响其他消费组内的这个消息。

所以我的流程是这样的:每个节点都用自己的IP作为GroupId来注册一个消费组,当消费消息的时候判断消息中包含的ip地址是否与该节点的IP地址匹配,如果匹配就处理文件,如果不匹配就直接消费消息不做任何操作。

1.SpringBoot整合Kafka

SpringBoot整合Kafka是非常简单的,引入kafka的依赖再在application.properties文件上配置Kafka的配置参数就可以直接使用了。如下图所示:

3f7e9465e678b967837ddda0b14e151a.png
9cc83c3bf2d0315f496331800d8c7dea.gif

8ae8e0eae0dd0b4bb2eee804a57a1a1b.png
9cc83c3bf2d0315f496331800d8c7dea.gif

2. kafka生产者发送消息

fe9007b824a2517fc3f35078c10857e7.png
9cc83c3bf2d0315f496331800d8c7dea.gif

如上图所示,只需要调用kafkaTemplate对象就可以直接发送消息了。

3.kafka注册动态消费组

一般kafka的消费组groupId是在SpringBoot中的配置文件中配置的,如下:

bddf50f247bd6f4a6962e64b7c142531.png
9cc83c3bf2d0315f496331800d8c7dea.gif

但是这是静态的groupId,不满足我们的需求,所以我们要创建动态的groupId来覆盖这个静态的配置。

创建一个config类,使用System.setProperty()方法将动态的groupId添加到系统配置中覆盖原来的配置。如下:

4e6a5e08fd6369ceb6079328d069a3dd.png
9cc83c3bf2d0315f496331800d8c7dea.gif

这样每个节点就都会注册一个groupId了,也就实现的kafka的多播机制。

4. 创建kafka的监听类

2791faaf9d1f095c0e241e7f2eaa65fb.png
9cc83c3bf2d0315f496331800d8c7dea.gif

SpringBoot创建监听方法也非常简单,只要使用@KafkaListener注解就可以创建一个监听方法了,不过要注意这里的topic参数必须静态的。

文章就到这里,更多精彩文章敬请期待。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值