spring boot 2 kafka

本文介绍如何使用Spring Boot 2与Kafka进行集成,包括通过Docker部署Kafka集群,配置Spring Boot项目引入Kafka依赖,并实现消息发送与监听的功能。

  spring boot 2 跟kafka的配置


采用docker 安装kafka

docker run --name zookeeper -p 2181:2181 -t wurstmeister/zookeeper
docker run --name kafka -e KAFKA_ADVERTISED_HOST_NAME=localhost -e HOST_IP=localhost -e KAFKA_ADVERTISED_PORT=9092 -e KAFKA_ZOOKEEPER_CONNECT=zk:2181 -e KAFKA_BROKER_ID=1 -e ZK=zk -p 9092:9092 --link zookeeper:zk -t wurstmeister/kafka

其中pom依赖包为:

<dependency>
    <groupId>org.springframework.kafka</groupId>
    <artifactId>spring-kafka</artifactId>
</dependency>

其次parent依赖于

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.0.0.RELEASE</version>
</parent>

如果采用io来管理那么需要依赖

其中必须应用到最新版本的管理。

<platform-bom.version>Cairo-SR1</platform-bom.version
<dependency>
    <groupId>io.spring.platform</groupId>
    <artifactId>platform-bom</artifactId>
    <version>${platform-bom.version}</version>
    <type>pom</type>
    <scope>import</scope>
</dependency>

其中代码

package com.wj.product.common;

        import org.apache.kafka.clients.consumer.ConsumerRecord;
        import org.slf4j.Logger;
        import org.slf4j.LoggerFactory;
        import org.springframework.beans.factory.annotation.Autowired;
        import org.springframework.boot.CommandLineRunner;
        import org.springframework.boot.SpringApplication;
        import org.springframework.boot.autoconfigure.SpringBootApplication;
        import org.springframework.kafka.annotation.KafkaListener;
        import org.springframework.kafka.core.KafkaTemplate;

        import java.util.concurrent.CountDownLatch;
        import java.util.concurrent.TimeUnit;



@SpringBootApplication
public class KafkaTest implements CommandLineRunner {


    public static Logger logger = LoggerFactory.getLogger(KafkaTest.class);
    public static void main(String[] args) {
        SpringApplication.run(KafkaTest.class, args).close();
    }


    @Autowired
    private KafkaTemplate<String, String> kafkaTemplate;



    private final CountDownLatch latch = new CountDownLatch(3);


    @Override
    public void run(String... args) throws Exception {
        kafkaTemplate.send("myTopic", "foo1");
        kafkaTemplate.send("myTopic", "foo2");
        kafkaTemplate.send("myTopic", "foo3");
        latch.await(60, TimeUnit.SECONDS);
    }
    @KafkaListener(topics = "myTopic")
    public void listen(ConsumerRecord<?, ?> cr) throws Exception {
        logger.info(cr.toString());
        latch.countDown();
    }
}
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值