paho mqtt
遇到诸如“此应用程序只需要向另一个服务器发送值”之类的问题时,总会有一种诱惑,将其简化为打开套接字并发送值之类的事情。 但是,这个简单的主张很快就在生产中瓦解了。 除了必须编写系统的服务器端之外,开发人员还必须应对以下事实:网络不是100%可靠的,而围绕我们的无线和移动网络在设计上并不可靠,因此很可能需要访问控制和加密。
编写代码来解决这个问题,最终会遇到更加复杂,难以测试的例程,这些例程很难证明它们将遇到的极端情况。 更糟糕的是,复杂性的增加并没有增加功能或互操作性。 面对所有这些,从一个可互操作的,功能强大的协议开始就更好了,该协议已经解决了所有这些问题? 这就是MQTT(MQ遥测传输)的出现。
为什么选择MQTT?
MQTT来自M2M (机器对机器)和物联网的世界。 在那里,设备的大小可以与通过无线系统连接的传感器和控制器一样小。 这种环境促使在代码占用量和系统负载方面,任何协议的实现都必须轻量级,同时还要解决该可变可靠性连接问题。
MQTT最初是由IBM的Andy Stanford-Clark和Arcom的Arlen Nipper(后来由Eurotech收购)创建的,作为企业消息传递系统的补充,以便可以安全,轻松地将企业外部的大量数据带入企业内部。 MQTT是一种发布/订阅消息传递系统,它使客户端可以发布消息而无需担心自己的最终目的地。 消息被发送到MQTT代理,在其中可以保留它们。 消息的有效负载只是一个字节序列,最大为256MB,对这些有效负载的格式没有任何要求,并且MQTT协议通常向大多数消息添加两个字节的固定标头。
其他客户端可以订阅这些消息,并在新消息到达时由代理进行更新。 为了考虑使用MQTT的各种可能情况,它允许客户和经纪人根据消息的内容设置从“开火即忘”到“确认交付”的“服务质量”。 MQTT还具有非常轻便的API,具有所有五种协议方法,使其易于学习和调用,但是还支持SSL加密的连接以及客户端到代理的用户名/密码身份验证。
自首次亮相以来,MQTT已在生产场景中证明了自己。 与独立的MQTT代理一样,它也已集成到其他消息队列代理中,例如ActiveMQ和RabbitMQ,提供了到企业网络的桥梁。 MQTT 3.1规范的最新版本被用作OASIS消息遥测标准的基础,为了保持兼容性,该基础与MQTT规范相差甚远。
为什么选择帕霍?
MQTT是一种协议,协议需要客户端实现。 Eclipse Paho项目是Eclipse Foundation M2M任务的一部分,该任务旨在提供M2M库和工具的高质量实现。 在Paho旗帜下,正在策划和开发MQTT的开源客户端库。 在不同的开发阶段,已经有带有Lua,Python,C ++和JavaScript的MQTT C和Java库。 在本文中,我们将展示如何使用Paho Java MQTT库进行发布和订阅。
深入研究MQTT
要开始考虑代码中的MQTT,这是MQTT API的最简单用法:
client = new MqttClient("tcp://localhost:1883", "pahomqttpublish1"); client.connect(); MqttMessage message = new MqttMessage(); message.setPayload("A single message".getBytes()); client.publish("pahodemo/test", message); client.disconnect();
在此代码段中,我们通过TCP到端口1883(MQTT的默认端口)的连接,创建了到本地主机上运行的MQTT代理的客户端连接。 客户需要具有一个标识符,该标识符对于连接到代理的所有客户都是唯一的–在这种情况下,我们为客户提供一个pahomqttpublish1的ID。 然后,我们告诉客户端进行连接。 现在我们可以创建一个MqttMessage并将其有效载荷设置为一个简单的字符串。 注意,我们将字符串转换为字节,因为setPayload仅采用字节数组。 我们依靠MqttMessage的默认设置来设置其他各种参数。 接下来,我们发布消息,并且在这里我们需要介绍主题。
为了避免每个客户端都收到由其他客户端发布的每条消息这一明显问题,MQTT消息将与主题一起发布 。 主题是一个结构化的字符串,它使用“ /”定义了命名空间中的位置,用于分隔该