Springboot实战:优雅的整合Kafka发送及监听消息示例(附源码下载)

Springboot-cli 开发脚手架系列

Springboot优雅的整合Kafka发送及监听消息示例(附源码下载)



前言

致力于让开发者快速搭建基础环境并让应用跑起来,提供使用示例供使用者参考,让初学者快速上手。

1. 环境

  • pom.xml
       <!--    启动web用于接口测试 -->
      <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
         <!--    kafka -->
     <dependency>
            <groupId>org.springframework.kafka</groupId>
            <artifactId>spring-kafka</artifactId>
        </dependency>
        <!--    json 工具包 -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>1.2.80</version>
        </dependency>

2. 提供者

  • yml配置 bootstrap-servers 改为你kafka的实际地址
server:
  port: 9999

spring:
  kafka:
    bootstrap-servers: 127.0.0.1:9092
    producer:
      # 每次批量发送消息的数量
      batch-size: 16
      # 缓存容量
      buffer-memory: 33554432
      #设置大于0的值,则客户端会将发送失败的记录重新发送
      retries: 0
      # 指定消息key和消息体的编解码方式 UTF-8
      key-serializer: org.apache.kafka.common.serialization.StringSerializer
      value-serializer: org.apache.kafka.common.serialization.StringSerializer
  • 编写发送者KafkaProducer.java
@Component
@RequiredArgsConstructor
@Slf4j
public class KafkaProducer {

    private final KafkaTemplate<String, String> kafkaTemplate;

    /**
     * 发送json消息
     *
     * @param topic 频道
     * @param message  消息
     */
    public void send(String topic, String message) {
        kafkaTemplate.send(topic, message);
        log.info("send success");
    }

}
  • 编写测试接口ProducerController.java
@RestController
@RequiredArgsConstructor
public class ProducerController {

    private final KafkaProducer kafkaProducer;

    /**
     * 发送消息
     */
    @RequestMapping("/send")
    public String send(String topic, String message) {
        kafkaProducer.send(topic, message);
        return "success";
    }

    /**
     * 发送消息
     */
    @PostMapping("/send")
    public String sendJson(@RequestBody JSONObject data) {
        String topic = data.getString("topic");
        JSONObject message = data.getJSONObject("message");
        kafkaProducer.send(topic, message.toJSONString());
        return "success";
    }
}

3. 消费者

  • yml配置bootstrap-servers改为你kafka的实际地址
spring:
  kafka:
    bootstrap-servers: 127.0.0.1:9092
    consumer:
      # 默认的消费组ID
      group-id: javagroup
      # 是否自动提交offset
      enable-auto-commit: true
      # 提交offset延时(接收到消息后多久提交offset)
      auto-commit-interval: 100
      # earliest:当各分区下有已提交的offset时,从提交的offset开始消费;无提交的offset时,从头开始消费
      # latest:当各分区下有已提交的offset时,从提交的offset开始消费;无提交的offset时,消费新产生的该分区下的数据
      # none:topic各分区都存在已提交的offset时,从offset后开始消费;只要有一个分区不存在已提交的offset,则抛出异常
      auto-offset-reset: latest
      key-deserializer: org.apache.kafka.common.serialization.StringDeserializer
      value-deserializer: org.apache.kafka.common.serialization.StringDeserializer

kafka:
  # 订阅的主题
  topic: test
  # 主题消费分组
  group: group-test
  • kafka消费者实现KafkaConsumer.java
@Component
@RequiredArgsConstructor
@Slf4j
public class KafkaConsumer {

    /**
     * 消费者配置,kafka.topic为监听的topic,kafka.group为消费分组,可在yml中修改
     */
    @KafkaListener(topics = "${kafka.topic}", groupId = "${kafka.group}")
    @Async
    public void kafkaListener(ConsumerRecord<String, String> consumerRecord) {
        String value = consumerRecord.value();
        if (log.isInfoEnabled()) {
            log.info("读取到消息:offset {}, value {}", consumerRecord.offset(), value);
        }
        if (null == value) {
            log.error("kafka消费数据为空");
        }
    }

}

4. 效果演示

  • 整体结构
    在这里插入图片描述

  • 启动提供者和消费者

  • 浏览器输入localhost:9999/send?message=hello&topic=test
    在这里插入图片描述

6. 源码分享

本项目已收录

  • Springboot-cli开发脚手架,集合各种常用框架使用案例,完善的文档,致力于让开发者快速搭建基础环境并让应用跑起来,并提供丰富的使用示例供使用者参考,帮助初学者快速上手。
  • 项目源码github地址
  • 项目源码国内gitee地址
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

全栈小定

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值