Mosquitto是一个实现了MQTT3.1协议的代理服务器,由MQTT协议创始人之一的Andy Stanford-Clark开发,它为我们提供了非常棒的轻量级数据交换的解决方案。本文的主旨在于记录Mosquitto服务的安装和使用,以备日后查阅。

获取&安装

在Linux系统上安装Mosquitto,本人建议大家使用源码安装模式,最新的源码可从 http://mosquitto.org/files/source/ 地址中获取。解压之后,我们可以在源码目录里面找到主要的配置文件config.mk,其中包含了所有Mosquitto的安装选项,详细的参数说明如下:

  1. # 是否支持tcpd/libwrap功能.
  2. #WITH_WRAP:=yes
  3.  
  4. # 是否开启SSL/TLS支持
  5. #WITH_TLS:=yes
  6.  
  7. # 是否开启TLS/PSK支持
  8. #WITH_TLS_PSK:=yes
  9.  
  10. # Comment out to disable client client threading support.
  11. #WITH_THREADING:=yes
  12.  
  13. # 是否使用严格的协议版本(老版本兼容会有点问题)
  14. #WITH_STRICT_PROTOCOL:=yes
  15.  
  16. # 是否开启桥接模式
  17. #WITH_BRIDGE:=yes
  18.  
  19. # 是否开启持久化功能
  20. #WITH_PERSISTENCE:=yes
  21.  
  22. # 是否监控运行状态
  23. #WITH_MEMORY_TRACKING:=yes

这里需要注意的是,默认情况下Mosquitto的安装需要OpenSSL的支持;如果不需要SSL,则需要关闭config.mk里面的某些与SSL功能有关的选项(WITH_TLS、WITH_TLS_PSK)。接着,就是运行make install进行安装,完成之后会在系统命令行里发现mosquitto、mosquitto_passwd、mosquitto_pub和mosquitto_sub四个工具(截图如下),分别用于启动代理、管理密码、发布消息和订阅消息。

安装其他依赖包:

  1. yum install gcc gcc-c++ libstdc++-devel
  2.  
  3. yum install openssl-devel -y
  4.  
  5. yum install c-ares-devel -y
  6.  
  7. yum install uuid-devel -y
  8.  
  9. yum install libuuid-devel -y

安装mosquitto:

1、切换到/home/tool/sourceDir/mosquitto-1.4.14目录下

2、make && make install

3、安装完以后切换到 /etc 目录下查看:

4、切换到 /etc/mosquitto目录下,执行

  1. cp mosquitto.conf.example mosquitto.conf

5、mosquitto参数详细说明:

  1. # =================================================================
  2. # General configuration
  3. # =================================================================
  4.  
  5. # 客户端心跳的间隔时间
  6. #retry_interval 20
  7.  
  8. # 系统状态的刷新时间
  9. #sys_interval 10
  10.  
  11. # 系统资源的回收时间,0表示尽快处理
  12. #store_clean_interval 10
  13.  
  14. # 服务进程的PID
  15. #pid_file /var/run/mosquitto.pid
  16.  
  17. # 服务进程的系统用户
  18. #user mosquitto
  19.  
  20. # 客户端心跳消息的最大并发数
  21. #max_inflight_messages 10
  22.  
  23. # 客户端心跳消息缓存队列
  24. #max_queued_messages 100
  25.  
  26. # 用于设置客户端长连接的过期时间,默认永不过期
  27. #persistent_client_expiration
  28.  
  29. # =================================================================
  30. # Default listener
  31. # =================================================================
  32.  
  33. # 服务绑定的IP地址
  34. #bind_address
  35.  
  36. # 服务绑定的端口号
  37. #port 1883
  38.  
  39. # 允许的最大连接数,-1表示没有限制
  40. #max_connections -1
  41.  
  42. # cafile:CA证书文件
  43. # capath:CA证书目录
  44. # certfile:PEM证书文件
  45. # keyfile:PEM密钥文件
  46. #cafile
  47. #capath
  48. #certfile
  49. #keyfile
  50.  
  51. # 必须提供证书以保证数据安全性
  52. #require_certificate false
  53.  
  54. # 若require_certificate值为true,use_identity_as_username也必须为true
  55. #use_identity_as_username false
  56.  
  57. # 启用PSK(Pre-shared-key)支持
  58. #psk_hint
  59.  
  60. # SSL/TSL加密算法,可以使用“openssl ciphers”命令获取
  61. # as the output of that command.
  62. #ciphers
  63.  
  64. # =================================================================
  65. # Persistence
  66. # =================================================================
  67.  
  68. # 消息自动保存的间隔时间
  69. #autosave_interval 1800
  70.  
  71. # 消息自动保存功能的开关
  72. #autosave_on_changes false
  73.  
  74. # 持久化功能的开关
  75. persistence true
  76.  
  77. # 持久化DB文件
  78. #persistence_file mosquitto.db
  79.  
  80. # 持久化DB文件目录
  81. #persistence_location /var/lib/mosquitto/
  82.  
  83. # =================================================================
  84. # Logging
  85. # =================================================================
  86.  
  87. # 4种日志模式:stdout、stderr、syslog、topic
  88. # none 则表示不记日志,此配置可以提升些许性能
  89. log_dest none
  90.  
  91. # 选择日志的级别(可设置多项)
  92. #log_type error
  93. #log_type warning
  94. #log_type notice
  95. #log_type information
  96.  
  97. # 是否记录客户端连接信息
  98. #connection_messages true
  99.  
  100. # 是否记录日志时间
  101. #log_timestamp true
  102.  
  103. # =================================================================
  104. # Security
  105. # =================================================================
  106.  
  107. # 客户端ID的前缀限制,可用于保证安全性
  108. #clientid_prefixes
  109.  
  110. # 允许匿名用户
  111. #allow_anonymous true
  112.  
  113. # 用户/密码文件,默认格式:username:password
  114. #password_file
  115.  
  116. # PSK格式密码文件,默认格式:identity:key
  117. #psk_file
  118.  
  119. # pattern write sensor/%u/data
  120. # ACL权限配置,常用语法如下:
  121. # 用户限制:user <username>
  122. # 话题限制:topic [read|write] <topic>
  123. # 正则限制:pattern write sensor/%u/data
  124. #acl_file
  125.  
  126. # =================================================================
  127. # Bridges
  128. # =================================================================
  129.  
  130. # 允许服务之间使用“桥接”模式(可用于分布式部署)
  131. #connection <name>
  132. #address <host>[:<port>]
  133. #topic <topic> [[[out | in | both] qos-level] local-prefix remote-prefix]
  134.  
  135. # 设置桥接的客户端ID
  136. #clientid
  137.  
  138. # 桥接断开时,是否清除远程服务器中的消息
  139. #cleansession false
  140.  
  141. # 是否发布桥接的状态信息
  142. #notifications true
  143.  
  144. # 设置桥接模式下,消息将会发布到的话题地址
  145. # $SYS/broker/connection/<clientid>/state
  146. #notification_topic
  147.  
  148. # 设置桥接的keepalive数值
  149. #keepalive_interval 60
  150.  
  151. # 桥接模式,目前有三种:automatic、lazy、once
  152. #start_type automatic
  153.  
  154. # 桥接模式automatic的超时时间
  155. #restart_timeout 30
  156.  
  157. # 桥接模式lazy的超时时间
  158. #idle_timeout 60
  159.  
  160. # 桥接客户端的用户名
  161. #username
  162.  
  163. # 桥接客户端的密码
  164. #password
  165.  
  166. # bridge_cafile:桥接客户端的CA证书文件
  167. # bridge_capath:桥接客户端的CA证书目录
  168. # bridge_certfile:桥接客户端的PEM证书文件
  169. # bridge_keyfile:桥接客户端的PEM密钥文件
  170. #bridge_cafile
  171. #bridge_capath
  172. #bridge_certfile
  173. #bridge_keyfile

5、启动mosquitto服务:

  1. mosquitto -c /etc/mosquitto/mosquitto.conf

  2. mosquitto -c /etc/mosquitto/mosquitto.conf -v -d
  1.  6、查看端口:

  1.  

7、至此,mosquitto安装,启动完毕!

补充问题:

1、在启动过程中报错:

  1. Error: Invalid user 'mosquitto'.

解决方法:

2、重启Mosquitto

笔者在网上找了很多资料都没有提起怎样重启服务器,并且在官网上也没有相应命令提示。

所以我们使用Liunx终止进程命令,强行退出。

先kill掉,再重启:
  1. [root@localhost ~]# ps -A | grep mosquitto
  2. 21674 ? 00:02:38 mosquitto
  3. [root@localhost ~]# kill -9 21674

编译过程中问题:

1. ssh.h找不到。我之前安装了openssl,为什么还会报这个错误呢,因为我安装好了以后并没有配置环境变量      下面的命令是安装开发环境,执行此命令,上面的openssl就可以不安装了

yum install openssl-devel

2.ares.h找不到

yum install c-ares-devel

3.#include <uuid/uuid.h> 找不到文件解决方法:

yum install e2fsprogs-devel
yum install uuid-devel
yum install libuuid-devel

 调测问题:

1、报错./mosquitto_sub: error while loading shared libraries: libmosquitto.so.1: cannot open shared object file: No such file or directory

解决:执行以下命令:

sudo ln -s /usr/local/lib/libmosquitto.so.1 /usr/lib/libmosquitto.so.1

ldconfig

 调测步骤:

1、先开启一个客户端,模拟broker

2、再开启一个客户端,模拟订阅

3、最后开启一个客户端,模拟发布

4、订阅界面可以实时收到发布消息

MQTT的学习之Mosquitto安装和使用的更多相关文章

  1. MQTT的学习之Mosquitto安装&使用(1)

    Mosquitto是一个实现了MQTT3.1协议的代理服务器,由MQTT协议创始人之一的Andy Stanford-Clark开发,它为我们提供了非常棒的轻量级数据交换的解决方案.本文的主旨在于记录M ...

  2. MQTT的学习之Mosquitto发布-订阅(2)

    在<MQTT的学习之Mosquitto安装&使用(1)>一文末尾,我已经模拟了发布-订阅模式,只是那时在服务器直接模拟的,并不是java代码模拟的.下面贴出Java代码 1.首先引 ...

  3. MQTT协议学习研究 & Mosquitto简要教程(安装和使用)

    若初次接触MQTT协议,可先理解以下概念: [MQTT协议特点]——相比于RESTful架构的物联网系统,MQTT协议借助消息推送功能,可以更好地实现远程控制. [MQTT协议角色]——在RESTfu ...

  4. 【转载】MQTT的学习之Mosquitto集群搭建

    本文出自:http://www.cnblogs.com/yinyi521/p/6087215.html 文章钢要: 1.进行双服务器搭建 2.进行多服务器搭建 一.Mosquitto的分布式集群部署 ...

  5. Centos7.2 MQTT的学习之Mosquitto搭建&集群搭建&使用

    下载安装包http://mosquitto.org/files/source/ 安装依赖yum install -y gcc gcc-c++ libstdc++-develyum install -y ...

  6. MQTT入门1 -- mosquitto 安装

    原文链接:https://www.cnblogs.com/NickQ/p/9247638.html MQTT入门1 -- mosquitto 安装 简介: MQTT(Message Queuing T ...

  7. Mac 下 Mosquitto 安装和配置 (Mosquitto为开源的mqtt服务器)

    官网:http://mosquitto.org/download/ 官网的介绍简单明了 Mac 下一个命令“brew install mosquitto” 安装成功了,还学会了brew 安装目录:/u ...

  8. Mosquitto安装_Ubuntu/Debian上安装消息队列Mosquitto

    Mosquitto安装_Ubuntu/Debian上安装消息队列Mosquitto MQTT是IBM开发的一个即时通讯协议.MQTT是面向M2M和物联网的连接协议,采用轻量级发布和订阅消息传输机制.M ...

  9. MQTT再学习 -- 搭建MQTT服务器及测试

    最近在搞 PM2.5 采集,需要用到 MQTT 传输协议.协议部分看了几天的,讲的七七八八.本身在 intel 上有 写好的MQTT 的源码,现在的工作其实也就是移植到单片机上或者DM368板卡上.不 ...

随机推荐

  1. Fedora dnf配置

    1.在配置文件/etc/dnf/dnf.conf中加入: fastestmirror=true keepcache=true 这样下载安装软件就快多了. 2.dnf常用命令 检查并升级可用软件包: $ ...

  2. apache添加https证书

    今天折腾了一下,总结apache添加https证书的方法. 证书类型分为两种, A)自签名证书 利用oepnssl命令生成.csr和key文件,没有授信,没有有效期,但是可以强制使用https协议,可 ...

  3. docker实战(一)之Tomcat的安装

           docker号称分分钟就可以将环境构建完成,这话一点也不假,因为docker在使用软件时只需要从官方 仓库中拉取对应的镜像就行了.docker的使用前需要了解两个名词--镜像和容器.这两 ...

  4. 线程锁,threadinglocal,线程池,生产者消费者模型

    1.线程锁 1.锁Lock(只能锁一次) import threading import time v = [] lock = threading.Lock() def func(arg): lock ...

  5. .NET 欢乐编程术之类型超级转换之术👍👍

    准备工作:先确保 VS 版本大于 2017,且支持C# 7.0 语言版本.然后新建 .Net Core 项目,在 Nuget 包管理上引入微软霸霸官方包 System.Runtime.Compiler ...

  6. Java EE.Servlet.生成响应

    Servlet的核心职责就是根据客户端的请求生成动态响应. 1.编码类型 2.流操作(下载文件) servlet支持两种格式的输入/输出流.一种是字符输入输出流.另一种是字节输入输出流. 3.重定向

  7. 我对微服务、SpringCloud、k8s、Istio的一些杂想

    一.微服务与SOA “微服务”是一个名词,没有这个名词之前也有“微服务”,一个朗朗上口的名词能让大家产生一个认知共识,这对推动一个事务的发展挺重要的,不然你叫微服务他叫小服务的大家很难集中到一个点上. ...

  8. [学习笔记] MySQL入门

    一.MySQL的安装与简单使用 ubuntu16.04下安装MySQL: sudo apt-get update sudo apt-get install mysql-server mysql-cli ...

  9. JVM指令

    本篇指令码表,参考自ASM文档手册,如果你对asm感兴趣,可到ASM官网下载手册学习. 一.本地变量操作指令(I,L,F,D,A这些前缀表示对int,long,float,double,引用进行操作) ...

  10. BFS vs DFS

    1 Clone Graph   1  copy ervery nodes by bfs  2  add neighbors public UndirectedGraphNode cloneGraph( ...