7.kafka3.x集成springboot

kafka集成springboot

  1. 引入依赖

            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-web</artifactId>
            </dependency>
    
            <dependency>
                <groupId>org.springframework.kafka</groupId>
                <artifactId>spring-kafka</artifactId>
            </dependency>
    
            <dependency>
                <groupId>org.springframework.kafka</groupId>
                <artifactId>spring-kafka-test</artifactId>
                <scope>test</scope>
            </dependency>
    
  2. 添加yaml配置

    spring:
      application:
        name: kafka_spring_boot
      kafka:
        bootstrap-servers: node1:9092,node2:9092
        # 生产者相关
        producer:
          # k v 序列化器
          key-serializer: org.apache.kafka.common.serialization.StringSerializer
          value-serializer: org.apache.kafka.common.serialization.StringSerializer
          # ack
          acks: 1
          # 压缩类型
          compression-type: snappy
          # 重试次数
          retries: 3
        # 消费者相关
        consumer:
          group-id: kafka_spring_boot
          key-deserializer: org.apache.kafka.common.serialization.StringDeserializer
          value-deserializer: org.apache.kafka.common.serialization.StringDeserializer
    
  3. 生产者代码 核心 org.springframework.kafka.core.KafkaTemplate#send

    @RestController
    public class SpringKafkaController {
    
        @Autowired
        private KafkaTemplate<String, String> kafkaTemplate;
    
        @GetMapping("sendMsg")
        public void sendMsg(String msg) {
            final String topic = "test_topic";
            kafkaTemplate.send(topic, msg);
        }
        
    }
    
    
  4. 消费者代码 @KafkaListener注解

    @Configuration
    @Slf4j
    public class KafkaSpringBootListener {
    
        @KafkaListener(topics = "test_topic")
        public void consume(String msg) {
            log.info("接受消息:{}", msg);
        }
    }
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值