Spring Boot中@KafkaListener使用${}动态指定topic

项目场景:

在Spring Kafka中,我们可以使用${}来引用Spring的属性配置。这样我们就可以在不同的环境中重新配置topic名称,而不需要修改代码。


解决方案:

在application.properties或application.yml中定义topic名称:

java 复制代码
# application.properties
kafka.topic=myTopic

然后在你的代码中使用${}来引用这个属性:

java 复制代码
@KafkaListener(topics = "${kafka.topic}")
public void listen(String message) {
    System.out.println("Received message in topic : " + message);
}

如果你使用的是多个topic,你可以使用;来分割多个topic名称:

java 复制代码
# application.properties
kafka.topics=topic1;topic2;topic3

然后在你的代码中使用${}来引用这个属性:

java 复制代码
@KafkaListener(topics = "${kafka.topics}")
public void listen(String message) {
    System.out.println("Received message in topic : " + message);
}
复制代码
相关推荐
bitt TRES6 小时前
springboot与springcloud对应版本
java·spring boot·spring cloud
2301_7717172111 小时前
Spring Boot 自动配置核心注解
java·spring boot·mybatis
❀͜͡傀儡师11 小时前
Claude Code 命令大全:从入门到精通的完整指南
spring boot·claude code
kybs199113 小时前
springboot租车系统--附源码68701
java·hadoop·spring boot·python·django·asp.net·php
过期动态13 小时前
MySQL中的约束
android·java·数据库·spring boot·mysql
wxin_VXbishe13 小时前
springboot新能源车充电站管理系统小程序-计算机毕业设计源码29213
java·c++·spring boot·python·spring·django·php
代码漫谈14 小时前
一文学习 SpringBoot 的 application.yml 配置,基于 Spring Boot 3.2.x
java·spring boot·spring·配置文件
_Evan_Yao15 小时前
内存映射文件与零拷贝:Kafka、RocketMQ 飞升的秘密通道
分布式·kafka·rocketmq
Java面试题总结16 小时前
Spring Boot:别再重复造轮子,这些内置功能香麻了
java·spring boot·后端
海兰16 小时前
【第32篇】场景示例项目
人工智能·spring boot·状态模式·spring ai