kafka监听topic消费_spring集成kafka,实现一个topic可以被多个group消费

往topic发一个消息,如果需要处理n个业务,就可以写到n个消费者组,如果是单独的业务模块不需要关心也不影响老业务,这种方式对于都写到一个消费者里,有利于代码解耦和模块扩展。

1、pom依赖

org.springframework

spring-webmvc

4.2.3.RELEASE

org.springframework.kafka

spring-kafka

1.3.1.RELEASE

2、生产者

/**

* kafka produce 单例模式只初始化一个生产者

*/

public class KafkaProducer {

private static KafkaTemplate kafkaTemplate = new KafkaTemplate<>(producerFactory());;

public static void send(String topic, String key, String data){

ListenableFuture> future = kafkaTemplate.send(topic, key, data);

future.addCallback(new CallBackSuccess(),new FailCallBack(topic, key, data));

}

public static void send(String topic, String data){

ListenableFuture> future = kafkaTemplate.send(topic, data);

future.addCallback(new CallBackSuccess(),new FailCallBack(topic,"",data));

}

private static void send(String topic, Integer parti, Long time, Object key, String value){

kafkaTemplate.send(topic,parti,time,key,value);

}

/**

*

* Description:获取配置

* Date: 2017年7月11日

* @author shaqf

*/

private static Map producerConfigs() {

Map props = Maps.newHashMap();

String list = Properties.appProps.getValue("kafka.broker");

props.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG, list);

props.put(ProducerConfig.RETRIES_CONFIG, 0);

props.put(ProducerConfig.BATCH_SIZE_CONFIG, 4096);

props.put(ProducerConfig.LINGER_MS_CONFIG, 1);

props.put(ProducerConfig.BUFFER_MEMORY_CONFIG, 40960);

props.put(ProducerConfig.KEY_SERIALIZER

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值