Spring Boot基于Spring Integration 实现MQTT客户端简单订阅功能

本文介绍了如何在Spring Boot应用中利用Spring Integration的入站和出站通道适配器实现MQTT消息订阅。内容包括配置MqttPahoMessageDrivenChannelAdapter进行消息驱动的订阅,动态添加和删除主题,以及使用Java配置和Java DSL的方式进行配置。同时讨论了适配器的错误处理、恢复间隔和连接策略。
摘要由CSDN通过智能技术生成

1 简介

Spring Integration 提供入站(inbound)和出站(outbound)通道适配器,以支持MQTT消息协议。使用这两适配器,需要加入依赖:

<!-- Maven --> <dependency> <groupId>org.springframework.integration</groupId> <artifactId>spring-integration-mqtt</artifactId> <version>5.2.1.RELEASE</version> </dependency>

 

// Gradle compile "org.springframework.integration:spring-integration-mqtt:5.2.1.RELEASE"

当前的MQTT Integration实现使用的是Eclipse Paho MQTT客户端库。两个适配器的配置都是使用DefaultMqttPahoClientFactory实现的。有关配置选项的更多信息,请参阅Eclipse Paho MQTT文档定义。

建议配置MqttConnectOptions对象并将其注入工厂(factory),而不是在工厂本身里设置(不推荐使用)MQTT连接选项。

2 Inbound(消息驱动)通道适配器

入站通道适配器由MqttPahoMessageDrivenChannelAdapter实现。常用的配置项有:

  • 客户端ID
  • MQTT Broker URL
  • 待订阅的主题列表
  • 带订阅的主题QoS值列表
  • MqttMessageConverter(可选)。默认情况下,默认的DefaultPaHomeMessageConverter生成一条带有字符串有效负载的消息,其头部内容如下: mqtt_topic: 接收消息的主题 mqtt_duplicate: 如果消息是重复的,则为true mqtt_qos: 服务质量,你可以将DefaultPahoMessageConverter声明为并将payloadAsBytes属性设置为true,从而将DefaultPahoMessageConverter返回有效负载中的原始byte[]
  • 客户端工厂
  • 发送超时。仅当通道可能阻塞(例如当前已满的有界队列通道)时才适用。
  • 错误通道。下游异常将以错误消息的形式发送到此通道(如果提供)。有效负载是包含失败消息和原因的MessagingException。
  • 恢复间隔。它控制适配器在发生故障后尝试重新连接的时间间隔。默认为10000毫秒(10秒)。

从Spring 4.1版开始,可以省略URL。相反,你可以在DefaultMqttPahoClientFactory的server URIs属性中提供服务器uri。例如,这样做允许连接到高可用(HA)集群。

从Spring 4.2.2开始,当适配器成功订阅到主题了,MqttSubscribedEvent事件就会被触发。当连接失败或者订阅失败,MqttConnectionFailedEvent事件会被触发。这两个事件都能够被一个Bean通过实现ApplicationListener而接收到。另外,名为recoveryInterval的新属性控制适配器在失败后尝试重新连接的时间间隔。默认为100

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot 应用程序中集成 Spring Integration MQTT 的步骤与在普通的 Spring 应用程序中类似。下面是一个示例代码,演示了如何在 Spring Boot 应用程序中使用 MQTT 子协议实现多个主题的订阅。 首先,需要在 `application.properties` 文件中配置 MQTT 连接信息和要订阅的主题列表: ``` mqtt.url=tcp://localhost:1883 mqtt.username=user mqtt.password=pass mqtt.topics=topic1,topic2,topic3 mqtt.qos=2 ``` 接下来,可以在 Spring Boot 应用程序中定义一个 MQTT 输入通道和一个消息处理器: ```java @Configuration @EnableIntegration public class MqttIntegrationConfig { @Value("${mqtt.url}") private String mqttUrl; @Value("${mqtt.username}") private String mqttUsername; @Value("${mqtt.password}") private String mqttPassword; @Value("${mqtt.topics}") private String mqttTopics; @Value("${mqtt.qos}") private int mqttQos; @Bean public MqttPahoClientFactory mqttClientFactory() { DefaultMqttPahoClientFactory factory = new DefaultMqttPahoClientFactory(); factory.setServerURIs(mqttUrl); factory.setUserName(mqttUsername); factory.setPassword(mqttPassword); return factory; } @Bean public MessageChannel mqttInputChannel() { return new DirectChannel(); } @Bean public MessageProducer inbound() { MqttPahoMessageDrivenChannelAdapter adapter = new MqttPahoMessageDrivenChannelAdapter("mqttInbound", mqttClientFactory(), mqttTopics.split(",")); adapter.setCompletionTimeout(5000); adapter.setConverter(new DefaultPahoMessageConverter()); adapter.setQos(mqttQos); return adapter; } @Bean public MessageHandler mqttMessageHandler() { return new MqttMessageHandler(); } public class MqttMessageHandler implements MessageHandler { @Override public void handleMessage(Message<?> message) throws MessagingException { // 处理接收到的消息 } } } ``` 在这个示例中,我们定义了一个 MQTT 客户端工厂 `mqttClientFactory()`,用于创建 MQTT 连接,根据配置文件中的 `mqtt.url`、`mqtt.username` 和 `mqtt.password` 属性来设置 MQTT 服务器的 URL、用户名和密码。`mqttInputChannel()` 是一个直接通道,用于接收 MQTT 消息。`inbound()` 是一个消息驱动的通道适配器,用于从 MQTT 代理服务器接收消息。`mqttTopics` 属性设置了要订阅的主题列表,`mqttQos` 属性设置了消息的服务质量。`mqttMessageHandler()` 是一个消息处理器,用于处理接收到的 MQTT 消息。 最后,在 `MqttMessageHandler` 类中实现 `handleMessage()` 方法,用于处理接收到的消息。 总之,以上是一个简单的示例,演示了如何在 Spring Boot 应用程序中使用 MQTT 子协议实现多个主题的订阅。需要注意的是,要在 `@Configuration` 类上使用 `@EnableIntegration` 注解,以启用 Spring Integration
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值