SpringBoot4.0集成Kafka4快速入门

windows下安装kafka4

下载安装

bat 复制代码
# 下载
https://kafka.apache.org/community/downloads/
# 进入windows下的bin目录
cd D:\kafka_2.13-4.1.1\bin\windows
# 创建集群id,报错不用管,我的是TkS3qte5T8Soj2saiRg87w 
kafka-storage random-uuid
# 修改日志文件存放目录,编辑config\server.properties
log.dirs=D:/kafka_2.13-4.1.1/data
# 初始化数据目录,报错不用管,-t指定集群id,-c指定配置文件
kafka-storage format --standalone -t TkS3qte5T8Soj2saiRg87w  -c D:\kafka_2.13-4.1.1\config\server.properties
# 启动服务端
kafka-server-start D:\kafka_2.13-4.1.1\config\server.properties

新版的kafka不再依赖zookeeper。

命令行收发消息

sh 复制代码
# 手动创建topic
kafka-topics --create --topic quickstart-events --bootstrap-server localhost:9092
# 查看topic
kafka-topics --describe --topic quickstart-events --bootstrap-server localhost:9092
# 手动发消息
kafka-console-producer --topic quickstart-events --bootstrap-server localhost:9092
# 手动消费消息
kafka-console-consumer --topic quickstart-events --from-beginning --bootstrap-server localhost:9092

集成SpringBoot4.0

  • 添加依赖
xml 复制代码
<dependency>
	<groupId>org.springframework.boot</groupId>
	<artifactId>spring-boot-starter-kafka</artifactId>
</dependency>
  • 添加配置
yml 复制代码
spring:
  kafka:
    # 设置kafka服务器地址
    bootstrap-servers: localhost:9092
    # 设置消费者组
    consumer:
      group-id: quick-group
  • 添加生产者
java 复制代码
@Autowired
private KafkaTemplate<String, String> stringTemplate;
@GetMapping("/send/{msg}")
public void send(@PathVariable("msg")String msg){
    // 如果是key-value都是string类型,可以直接发送和接收
    stringTemplate.send("quickstart-events", msg);
    log.info("send message:{}", msg);
}
  • 添加消费者
java 复制代码
@Service
public class QuickConsumer {
    @KafkaListener(topics = "quickstart-events")
    public void onMessage(String message){
        log.info("on message:{}", message);
    }
}

spring-boot-starter-kafka中已经自动配置了KafkaTemplate的key和value的序列化器StringSerializer和反序列化器StringDeserializer,只需要设置broker的地址和消费者所属的组即可进行消息的收发,显然比之前的老版本更简单了。

安装可视化管理工具

kafka的管理工具有很多,比如:Kafka UI、Kafdrop等,这里我们选择Kafka UI,它是一个SpringBoot的应用,易用且功能全面。

bat 复制代码
#下载地址
https://github.com/provectus/kafka-ui
# 启动
java -Dserver.port=8000 -Ddynamic.config.enabled=true -jar kafka-ui-api-v0.7.2.jar

浏览器访问http://localhost:8000,首先添加cluster:

然后就可以对cluster进行管理:

更多关于SpringBoot4.0的文章:SpringBoot4.0新特性

相关推荐
AI进化营-智能译站2 小时前
ROS2 C++开发系列17-多线程驱动多传感器|chrono高精度计时实现机器人同步控制
java·c++·ai·机器人
qq_589568105 小时前
springbootweb案例,出现访问 http://localhost:8080/list 一直处于浏览器运转阶段
java·网络协议·http·list·springboot
JAVA面经实录9176 小时前
计算机基础(完整版·超详细可背诵)
java·linux·数据结构·算法
晚风_END6 小时前
Linux|操作系统|最新版openzfs编译记录
linux·运维·服务器·数据库·spring·中间件·个人开发
AC赳赳老秦6 小时前
知识产权辅助:用 OpenClaw 批量生成专利交底书 / 软著申请材料,自动校验格式与内容合规性
java·人工智能·python·算法·elasticsearch·deepseek·openclaw
FYKJ_20107 小时前
springboot校园兼职平台--附源码02041
java·javascript·spring boot·python·eclipse·django·php
书源丶8 小时前
三十六、File 类与 IO 流基础——文件操作的「第一步」
java
AI人工智能+电脑小能手8 小时前
【大白话说Java面试题】【Java基础篇】第30题:JDK动态代理和CGLIB动态代理有什么区别
java·开发语言·后端·面试·代理模式
hERS EOUS8 小时前
SpringBoot 使用 spring.profiles.active 来区分不同环境配置
spring boot·后端·spring