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);
}
复制代码
相关推荐
古城小栈16 分钟前
Spring Boot + 代理 AI:解锁供应链自动化决策新范式
人工智能·spring boot·自动化
跟‘码’死磕29 分钟前
springboot集成钉钉群内发送消息
java·spring boot·钉钉
0和1的舞者30 分钟前
SpringBoot配置文件
java·spring boot·后端·web·配置·spirng
CadeCode40 分钟前
SpringBoot 封装 starter
spring boot·后端·架构
lang201509281 小时前
Kafka副本管理核心机制解析
分布式·kafka
雨雨雨雨雨别下啦1 小时前
SSM+Spring Boot+Vue.js3期末复习
vue.js·spring boot·后端
Query*1 小时前
分布式消息队列kafka【一】—— 环境搭建及基本配置参数讲解
分布式·kafka
lang201509281 小时前
深入解析Kafka核心写入逻辑
分布式·kafka·linq
lang201509281 小时前
Kafka核心揭秘:ReplicaManager如何保障高可用
分布式·kafka
honder试试1 小时前
Springboot实现Clickhouse连接池的配置和接口查询
spring boot·后端·clickhouse