springboot自动化配置mqtt,整合spring-integration-mqtt,连接多个mqtt,动态订阅主题

本文介绍了如何使用Spring Boot结合Spring-Integration-MQTT实现自动化配置,连接多个非集群MQTT服务,并动态订阅主题。通过添加特定依赖、配置,以及实现MessageHandler接口,可以轻松完成消息的订阅和发送。详细源码可在GitHub找到。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

springboot自动化配置mqtt,整合spring-integration-mqtt,连接多个mqtt

mqtt整合

最近有一个业务,要求连接多个非集群不同的mqtt服务,于是乎写了一个可根据配置动态配置的工具。starter-integration-mqtt整合了spring-integration-mqtt,只需添加配置,并实现消息订阅接口即可。可以实现订阅多个mqtt。
github源码:https://github.com/aLiang-xyl/integration-mqtt

添加依赖

<dependency>
    <groupId>cn.xyliang</groupId>
	<artifactId>integration-mqtt-starter</artifactId>
	<version>0.0.2</version>
</dependency>

添加配置

mqtt:
  config: 
    channel1:                                          #通道名称,可自定义,订阅消息时需要该名称
      url: [tcp://host1:1883, tcp://host1:1883]        #mqtt的url
      topics: [topic1, topic2]                         #监听的主题,和qos一一对应
      qos: [1, 0]                                      #监听主题的qos,和主题一一对应
      username: admin                                  #用户名
      password: public                                 #密码
      timeout: 60                                      #连接超时时间,单位:秒
      kep-alive-interval: 60                           #心跳时间,单位:秒
      async: true                                      #发送消息时是否异步发送
      client-id-append-ip: true                        #是否在clientId后面追加本机ip,因为clientid是唯一值,集群环境下不能使用相同的clientid,追加ip可解决该问题
      consumer-client-id: consumer_client_test1        #consumer client id配置
      producer-client-id: producer_client_test1        #producer client id配置
      consumer-will:                                   #consumer遗嘱消息配置
        qos: 1                                         #遗嘱qos
        topic: will_topic                              #遗嘱主题
        payload: '{
   "id": "consumer_client_test1"}'     #遗嘱内容
        retained: false                                #是否发送保留消息
      producer-will:                                   #producer遗嘱消息配置
        qos: 1                                         #遗嘱qos
        topic: will_topic                              #遗嘱主题
        payload: '{
   "id": "producer_client_test1"}'     #遗嘱内容
        retained: 
### Spring Integration MQTT 和 Mica-MQTT-Client-Spring-Boot-Starter 的对比 #### 一、功能特性比较 Spring Integration MQTT 是基于 Spring Integration 提供的一个模块,专注于通过通道(Channel)和适配器(Adapter)的方式集成 MQTT 协议。它提供了发布者和订阅者的抽象层,并支持复杂的事件驱动架构[^1]。 Mica-MQTT-Client-Spring-Boot-Starter 则是一个轻量级的 Starter 库,旨在简化 Spring Boot 项目中对 MQTT 客户端的支持。它的设计目标是提供更简单的配置方式以及更高的灵活性来满足不同的业务需求[^4]。 | 特性 | **Spring Integration MQTT** | **Mica-MQTT-Client-Spring-Boot-Starter** | |-------------------------|-------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------| | 配置复杂度 | 较高,需要定义输入/输出 Channel 并绑定到具体的 Handler 上[^3] | 更低,通常只需要在 `application.yml` 中完成基本配置即可启动客户端[^4] | | 动态订阅能力 | 支持动态订阅主题,但需手动实现逻辑并关联至特定 Channel | 原生支持动态订阅,可通过 API 调用轻松切换或新增订阅主题[^4] | | 消息处理机制 | 使用 MessageHandler 接口及其子类进行消息接收与分发 | 提供回调函数形式的消息处理器,允许开发者直接编写响应代码[^4] | | 连接管理 | 自动化程度较高,可自定义连接参数并通过 XML 或 Java Config 方式声明[^2] | 同样具备自动重连等功能,默认行为可以通过属性调整[^4] | #### 二、使用场景分析 对于希望构建高度解耦系统的团队来说,Spring Integration MQTT 可能更加适合因为其强调的是企业服务总线(ESB)模式下的组件间通信模型;而如果只是单纯为了快速接入MQTT协议,则可以选择后者以减少开发工作量[^5]。 以下是两种技术栈下典型的编码实例: ##### Spring Integration MQTT 示例 ```java // 订阅消息处理器 @Component public class CustomMessageHandler implements MessageHandler { private static final Logger logger = LoggerFactory.getLogger(CustomMessageHandler.class); @ServiceActivator(inputChannel = "mqttInputChannel") @Override public void handleMessage(Message<?> message) throws MessagingException { String payload = new String((byte[])message.getPayload()); logger.info("Received message: {}", payload); } } ``` ##### Mica-MQTT-Client-Spring-Boot-Starter 示例 ```java @Configuration @EnableMqttClient public class MqttConfig { @Bean public IMqttMessageListener<String> mqttMessageListener() { return (topic, message) -> System.out.println("Topic:" + topic + ", Message:" + message); } } ``` #### 三、总结 两者各有千秋,在选型时应考虑实际应用场景和技术背景等因素综合判断。如果当前系统已经广泛采用了Spring Integration框架或者未来有可能扩展更多类型的集成需求的话,那么继续沿用前者会更为合理一些;反之则可以尝试采用后者获得更快捷简便的操作体验[^6]。
评论 21
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值