Spring Boot 如何集成 MQTT,实现基于 MQTT 协议的消息传递?

简介: Spring Boot 如何集成 MQTT,实现基于 MQTT 协议的消息传递?

MQTT(Message Queuing Telemetry Transport)是一种轻量级的通信协议,在物联网和消息传递系统中广泛应用。而 Spring Boot 是一个开源的 Java 框架,简化了基于 Spring 的应用程序的开发流程。本文将详细介绍 Spring Boot 如何集成 MQTT,实现基于 MQTT 协议的消息传递。

什么是 Spring Boot

Spring Boot 是由 Pivotal 团队开发的用于简化 Spring 应用程序开发的框架。它提供了自动配置和约定优于配置的原则,使得开发者可以快速构建独立的、生产级别的 Spring 应用程序。Spring Boot 集成了大量常用的第三方库和组件,提供了良好的开发体验和高度可扩展性。

为什么需要集成 MQTT

MQTT 是一种轻量级的、可靠的消息传递协议,特别适用于物联网和分布式系统中的设备间通信。将 MQTT 集成到 Spring Boot 应用中,可以实现异步、实时的消息传递,使得应用程序更具弹性和灵活性。通过 MQTT,可以实现设备间的数据传输、事件通知以及远程控制等功能。

集成 MQTT 的步骤

下面是将 MQTT 集成到 Spring Boot 的基本步骤:

1. 添加 MQTT 依赖

首先,在项目的 Maven 或 Gradle 配置文件中,添加 MQTT 相关的依赖。可以使用 Eclipse Paho 提供的 MQTT 客户端库,也可以选择其他优质的第三方 MQTT 客户端库。例如,使用 Eclipse Paho 的 Maven 依赖配置如下:

<dependency>
    <groupId>org.eclipse.paho</groupId>
    <artifactId>org.eclipse.paho.client.mqttv3</artifactId>
    <version>1.2.5</version>
</dependency>

2. 创建 MQTT 客户端

在 Spring Boot 应用程序中,创建一个 MQTT 客户端类,用于连接到 MQTT 代理并处理消息。可以使用 Eclipse Paho 提供的 MqttClient 类,根据需要自定义该类的行为。例如:

@Component
public class MyMqttClient {
   
   
    private MqttClient client;

    @PostConstruct
    public void init() {
   
   
        String broker = "tcp://localhost:1883";
        String clientId = "my-client-id";

        try {
   
   
            client = new MqttClient(broker, clientId);
        } catch (MqttException e) {
   
   
            e.printStackTrace();
        }
    }

    // 处理收到的消息
    public void handleMessage(String topic, String message) {
   
   
        // 处理逻辑
    }

    // 发布消息
    public void publishMessage(String topic, String message) {
   
   
        try {
   
   
            client.publish(topic, message.getBytes(), 2, false);
        } catch (MqttException e) {
   
   
            e.printStackTrace();
        }
    }
}

3. 配置 MQTT 连接属性

在 Spring Boot 的配置文件中,添加 MQTT 连接相关的属性。这些属性包括代理地址、客户端 ID、用户名、密码等。例如,在 application.properties 文件中配置:

mqtt.broker=tcp://localhost:1883
mqtt.clientId=my-client-id
mqtt.username=
mqtt.password=

4. 创建 MQTT 消息订阅器

在 Spring Boot 应用程序中,创建一个 MQTT 消息订阅器,用于订阅感兴趣的主题,并将收到的消息交给对应的处理器进行处理。可以使用 Spring Integration 的 MQTT 支持,或者自定义订阅器。例如,使用 Spring Integration 的配置代码如下:

@Configuration
@EnableIntegration
public class MqttSubcriberConfig {
   
   

    @Autowired
    private MyMqttClient mqttClient;

    @Bean
    public MessageChannel mqttInputChannel() {
   
   
        return new DirectChannel();
    }

    @Bean
    public MessageProducer inbound() {
   
   
        MqttPahoMessageDrivenChannelAdapter adapter =
                new MqttPahoMessageDrivenChannelAdapter(
                        "tcp://localhost:1883",
                        "my-client-id",
                        "topic1", "topic2"); // 订阅的主题

        adapter.setCompletionTimeout(5000);
        adapter.setConverter(new DefaultPahoMessageConverter());
        adapter.setQos(2);
        adapter.setOutputChannel(mqttInputChannel());

        return adapter;
    }

    @ServiceActivator(inputChannel = "mqttInputChannel")
    public void handleMessage(Message<String> message) {
   
   
        String topic = (String) message.getHeaders().get("mqtt_receivedTopic");
        String payload = message.getPayload();

        mqttClient.handleMessage(topic, payload);
    }
}

5. 使用 MQTT 客户端

在应用程序的其他组件中,可以使用之前创建的 MQTT 客户端类来发布消息或处理收到的消息。例如:

@RestController
public class MyController {
   
   

    @Autowired
    private MyMqttClient mqttClient;

    @GetMapping("/publish")
    public void publishMessage() {
   
   
        mqttClient.publishMessage("topic1", "Hello, MQTT!");
    }
}

总结

本文详细介绍了如何将 MQTT 集成到 Spring Boot 应用程序中。首先,添加 MQTT 依赖;然后,创建 MQTT 客户端类,并配置 MQTT 连接属性;接着,创建 MQTT 消息订阅器,并将收到的消息交给对应的处理器进行处理;最后,可以在应用程序的其他组件中使用 MQTT 客户端来发布消息或处理收到的消息。

相关实践学习
快速体验阿里云云消息队列RocketMQ版
本实验将带您快速体验使用云消息队列RocketMQ版Serverless系列实例进行获取接入点、创建Topic、创建订阅组、收发消息、查看消息轨迹和仪表盘。
消息队列 MNS 入门课程
1、消息队列MNS简介 本节课介绍消息队列的MNS的基础概念 2、消息队列MNS特性 本节课介绍消息队列的MNS的主要特性 3、MNS的最佳实践及场景应用 本节课介绍消息队列的MNS的最佳实践及场景应用案例 4、手把手系列:消息队列MNS实操讲 本节课介绍消息队列的MNS的实际操作演示 5、动手实验:基于MNS,0基础轻松构建 Web Client 本节课带您一起基于MNS,0基础轻松构建 Web Client
目录
相关文章
|
8月前
|
消息中间件 Ubuntu Java
SpringBoot整合MQTT实战:基于EMQX实现双向设备通信
本教程指导在Ubuntu上部署EMQX 5.9.0并集成Spring Boot实现MQTT双向通信,涵盖服务器搭建、客户端配置及生产实践,助您快速构建企业级物联网消息系统。
2697 1
|
8月前
|
消息中间件 Java Kafka
消息队列比较:Spring 微服务中的 Kafka 与 RabbitMQ
本文深入解析了 Kafka 和 RabbitMQ 两大主流消息队列在 Spring 微服务中的应用与对比。内容涵盖消息队列的基本原理、Kafka 与 RabbitMQ 的核心概念、各自优势及典型用例,并结合 Spring 生态的集成方式,帮助开发者根据实际需求选择合适的消息中间件,提升系统解耦、可扩展性与可靠性。
546 1
消息队列比较:Spring 微服务中的 Kafka 与 RabbitMQ
|
8月前
|
消息中间件 存储 Java
RabbitMQ 和 Spring Cloud Stream 实现异步通信
本文介绍了在微服务架构中,如何利用 RabbitMQ 作为消息代理,并结合 Spring Cloud Stream 实现高效的异步通信。内容涵盖异步通信的优势、RabbitMQ 的核心概念与特性、Spring Cloud Stream 的功能及其与 RabbitMQ 的集成方式。通过这种组合,开发者可以构建出具备高可用性、可扩展性和弹性的分布式系统,满足现代应用对快速响应和可靠消息传递的需求。
431 2
RabbitMQ 和 Spring Cloud Stream 实现异步通信
|
10月前
|
物联网 Linux 开发者
快速部署自己私有MQTT-Broker-下载安装到运行不到一分钟,快速简单且易于集成到自己项目中
本文给物联网开发的朋友推荐的是GMQT,让物联网开发者快速拥有合适自己的MQTT-Broker,本文从下载程序到安装部署手把手教大家安装用上私有化MQTT服务器。
2135 5
|
12月前
|
消息中间件 缓存 NoSQL
基于Spring Data Redis与RabbitMQ实现字符串缓存和计数功能(数据同步)
总的来说,借助Spring Data Redis和RabbitMQ,我们可以轻松实现字符串缓存和计数的功能。而关键的部分不过是一些"厨房的套路",一旦你掌握了这些套路,那么你就像厨师一样可以准备出一道道饕餮美食了。通过这种方式促进数据处理效率无疑将大大提高我们的生产力。
359 32
|
11月前
|
监控 安全 Java
Java 开发中基于 Spring Boot 3.2 框架集成 MQTT 5.0 协议实现消息推送与订阅功能的技术方案解析
本文介绍基于Spring Boot 3.2集成MQTT 5.0的消息推送与订阅技术方案,涵盖核心技术栈选型(Spring Boot、Eclipse Paho、HiveMQ)、项目搭建与配置、消息发布与订阅服务实现,以及在智能家居控制系统中的应用实例。同时,详细探讨了安全增强(TLS/SSL)、性能优化(异步处理与背压控制)、测试监控及生产环境部署方案,为构建高可用、高性能的消息通信系统提供全面指导。附资源下载链接:[https://pan.quark.cn/s/14fcf913bae6](https://pan.quark.cn/s/14fcf913bae6)。
2263 0
|
NoSQL Java API
微服务——SpringBoot使用归纳——Spring Boot 中集成Redis——Spring Boot 集成 Redis
本文介绍了在Spring Boot中集成Redis的方法,包括依赖导入、Redis配置及常用API的使用。通过导入`spring-boot-starter-data-redis`依赖和配置`application.yml`文件,可轻松实现Redis集成。文中详细讲解了StringRedisTemplate的使用,适用于字符串操作,并结合FastJSON将实体类转换为JSON存储。还展示了Redis的string、hash和list类型的操作示例。最后总结了Redis在缓存和高并发场景中的应用价值,并提供课程源代码下载链接。
2722 0