MQTT服务器集群架构:高效、稳定、可扩展 (mqtt 服务器集群 架构)
随着物联网的快速发展,越来越多的设备需要进行数据传输和通信。MQTT作为一种轻量级的物联网协议,在物联网领域中被广泛使用。然而,随着MQTT传输的数据量不断增加,单点的MQTT服务器已经无法满足设备间通信的需求,因此需要构建一个MQTT服务器集群架构。
MQTT服务器集群架构的基本原则是高效、稳定、可扩展。在基于此原则的基础上,以下是MQTT服务器集群架构的设计要素:
1. 负载均衡
负载均衡是构建MQTT服务器集群架构的首要要素。通过负载均衡的方式,可以将MQTT连接、消息发布、订阅请求等均匀地分布到多个MQTT服务器上,从而达到负载均衡的效果,提高服务器的性能和可靠性。负载均衡可以使用硬件负载均衡器或基于软件的负载均衡器来实现。
2. 分布式存储
在MQTT服务器集群架构中,一个设备可能会产生大量的数据,如果使用集中式存储,可能会导致存储瓶颈、性能问题和单点故障等问题。因此,分布式存储是非常必要的。可以使用不同的技术来实现分布式存储,如NoSQL、Hadoop等。
3. 高可用性
在MQTT服务器集群架构中,某一台MQTT服务器失效可能会导致设备之间的通信中断,影响整个设备网络的正常运行。因此,必须通过备份、冗余等方式来确保单个MQTT服务器的失效不会影响整个系统的运行。可以采用主从同步、分布式数据库等技术来实现。
4. 自动扩展
当设备数量增加时,MQTT服务器集群架构应该可以自动扩展来满足设备通信的需求。这就需要MQTT服务器集群中的服务器具有自适应性来满足设备数量的变化,可以使用自动扩展技术实现。
MQTT服务器集群架构的设计要素包括负载均衡、分布式存储、高可用性和自动扩展。这些要素的选择和实现应该根据具体的需求和系统情况来进行,有效地满足设备之间的通信需求。
相关问题拓展阅读:
- springboot整合RabbitMQ Mqtt
- Android 中使用MQTT(之一篇)
springboot整合RabbitMQ Mqtt
之一,pom配置,我们需要引入相关jar:
第二,配置MQTT服务器基本信息,在springBoot配置文件application.properties中配置,添加如下:
第三,配置MQTT消息推送配置类,
第四,配置MqttGateway消息推送接口类,在sendToMqtt(String data,@Header(MqttHeaders.TOPIC)String topic)接口中,data为发送的消息内容,topic为主题。指定topic,则我们的接口可以根据需要,向不同的主题发送消息,方便灵活应用。如果不指定,则使用默认配置的主题。
第五,接口类测试下功能,用Postman调用sendMqtt.do接口,往hello主题发送消息,用MQTTLens订阅hello主题,从下面截图,可以看出可以正常往MQTT服务发送消息了,而且可以订阅到。
Android 中使用MQTT(之一篇)
MQTT(Message Queuing Telemetry Transport,消息队列遥测传输)是IBM开发的一个即时通讯协议。它是一种发布/订阅,极其简单和轻量级的消息传递协议,专为受限设备和低带宽,高延迟或不可靠的网络而设计。它的设计思想是轻巧、开放、简单、规范,易于实现。这些特点使得它对很多场景来说都是很好的选择,特别是对于受限的环境如机器与机器的通信(M2M)以及物联网环境。相对于XMPP,MQTT更加轻量级,并且占用的宽带低。
MQTT协议有以下特点:
那么问题来了?重连连接成功后重复接收到最后一条消息
MQTT推送消息订阅端重复接收问题。
(背景)订阅端断开的时候,发布端多次推送消息。
(现象)订阅端启动时,接收到最后一条推送消歼启息有两次;即使Qos设置为2;依然是两次。
经排查是因为
MqttMessage的Retained设置为了true;
该值很多文章上只说了是 消息保留机制,若设置为true,厅改档mqtt服务器会保留每次发布的消息;较少提到 若订阅某主题的客户端重启,则会把此主题之前发布的消息重新推送到客户端。该值默认为false;去掉修改该值即可
那么问题来了?重连连接后手动那么多遗漏的消息,怎么选择只接收最新的一条消息呢?
MQTT推送消息订阅端重复接收问题。
(背景)订阅端断开的时候,扮乱发布端多次推送消息。
(现象)订阅端启动时,接收到msg1,msg2,msg3 (这三个消息都是同一个类型消息,只需要处理最新的msg3就好,不然界面会刷新三次)这个谁有什么好办法没呢?
GitHub地址:
mqtt的官方文档:
Github上有中文翻译:
在module的build.gradle文件中添加依赖
在 AndroidManifest.xml 添加限权
在 AndroidManifest.xml 注册Service (MyMqttService为自己写的服务,下文会讲到)
mqtt 服务器集群 架构的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于mqtt 服务器集群 架构,MQTT服务器集群架构:高效、稳定、可扩展,springboot整合RabbitMQ Mqtt,Android 中使用MQTT(之一篇)的信息别忘了在本站进行查找喔。
编辑:一起学习网
标签:服务器,消息,集群,架构,设备