博客
关于我
MQTT源码交叉编译与移植
阅读量:192 次
发布时间:2019-02-28

本文共 1032 字,大约阅读时间需要 3 分钟。

MQTT协议是ISO标准(ISO/IEC PRF 20922)下基于发布/订阅范式的消息协议,主要用于在低带宽、不可靠的网络环境下,连接硬件性能有限的远程设备和传感器。它以其高效小内存占用和适合资源受限环境的特点,成为物联网和移动应用中的重要通信协议。

MQTT的特点

  • 发布/订阅模式:通过一对多的消息发布,解耦应用程序,提升系统灵活性和可扩展性。
  • 消息质量保证:提供三种消息传输级别:
    • "至多一次":适用于环境传感器数据,因偶次缺失无大碍。
    • "至少一次":确保消息到达,但可能存在重复。
    • "只有一次":确保消息唯一性,避免重复或丢失问题。
  • 小型传输:协议交换最小化,头部固定长度为2字节,降低网络流量。
  • Last Will and Testament:机制通知客户端异常中断。
  • 开放性和可扩展性:支持多种编程语言(如PHP、Python、C#等),广泛应用于物联网和移动推送领域。
  • MQTT的应用

    国内企业广泛采用MQTT作为Android手机客户端与服务器端推送消息的协议。例如,Sohu和Cmstop的手机客户端均使用MQTT进行消息推送。Cmstop的高级研发工程师指出,随着移动互联网的发展,MQTT在移动消息推送和物联网领域将发挥更大作用,成为信息收集和传感器通信的重要方案之一。

    MQTT的安装与测试

    交叉编译OpenSSL

  • 解压并编译OpenSSL源码,创建安装目录。
  • 配置Makefile,编译并安装。
  • 将生成的库文件路径添加至MQTT编译时的选项中。
  • 交叉编译MQTT

  • 解压并获取MQTT源码。
  • 修改Makefile,添加OpenSSL库路径。
  • 编译并生成动态库及测试程序。
  • 搭建MQTT服务器

  • 下载mosquitto源码,编译并安装。
  • 配置mosquitto.conf,创建mosquitto用户。
  • 启动服务并验证运行状态。
  • 测试

  • 在目标板上运行测试程序,确保能够连接到mosquitto服务器。
  • 修改测试程序中的地址参数,确保指向mosquitto服务IP地址。
  • 验证通信是否成功,排查连接问题。
  • 注意事项

    • 若开发板无法访问外网,可直接运行MQTTAsync_publish文件,使用默认mosquitto服务器。
    • 测试过程中,若出现连接错误,需检查mosquitto服务状态及应用程序地址配置是否正确。

    MQTT作为一个灵活且高效的消息协议,已在多个领域展现出其优势。随着物联网和移动应用的快速发展,MQTT将继续在技术领域发挥重要作用。

    转载地址:http://faaj.baihongyu.com/

    你可能感兴趣的文章
    Page Object模式:为什么它是Web自动化测试的必备工具
    查看>>
    SpringBoot中重写addCorsMapping解决跨域以及提示list them explicitly or consider using “allowedOriginPatterns“ in
    查看>>
    PageHelper 解析及实现原理
    查看>>
    pageHelper分页工具的使用
    查看>>
    pageHelper分页技术
    查看>>
    PageHelper分页查询遇到的小问题
    查看>>
    SpringBoot中配置为开发模式,代码修改后不用重新运行
    查看>>
    springboot中pom.xml、application.yml、application.properties
    查看>>
    PageHelper:上手教程(最详细)
    查看>>
    PageOffice如何实现从零开始动态生成图文并茂的Word文档
    查看>>
    PageRank算法
    查看>>
    Paint类(画笔)
    查看>>
    paip.android 手机输入法制造大法
    查看>>
    paip.spring3 mvc servlet的配置以及使用最佳实践
    查看>>
    Palindrome Number leetcode java
    查看>>
    Palo Alto Networks Expedition 未授权SQL注入漏洞复现(CVE-2024-9465)
    查看>>
    Palo Alto Networks Expedition 远程命令执行漏洞(CVE-2024-9463)
    查看>>
    Palo Alto Networks PAN-OS身份认证绕过导致RCE漏洞复现(CVE-2024-0012)
    查看>>
    Panalog 日志审计系统 libres_syn_delete.php 前台RCE漏洞复现
    查看>>
    Springboot中@SuppressWarnings注解详细解析
    查看>>