MQTT的学习之Mosquitto安装和使用
Mosquitto是一个实现了MQTT3.1协议的代理服务器,由MQTT协议创始人之一的Andy Stanford-Clark开发,它为我们提供了非常棒的轻量级数据交换的解决方案。本文的主旨在于记录Mosquitto服务的安装和使用,以备日后查阅。
获取&安装
在Linux系统上安装Mosquitto,本人建议大家使用源码安装模式,最新的源码可从 http://mosquitto.org/files/source/ 地址中获取。解压之后,我们可以在源码目录里面找到主要的配置文件config.mk,其中包含了所有Mosquitto的安装选项,详细的参数说明如下:
- # 是否支持tcpd/libwrap功能.
- #WITH_WRAP:=yes
- # 是否开启SSL/TLS支持
- #WITH_TLS:=yes
- # 是否开启TLS/PSK支持
- #WITH_TLS_PSK:=yes
- # Comment out to disable client client threading support.
- #WITH_THREADING:=yes
- # 是否使用严格的协议版本(老版本兼容会有点问题)
- #WITH_STRICT_PROTOCOL:=yes
- # 是否开启桥接模式
- #WITH_BRIDGE:=yes
- # 是否开启持久化功能
- #WITH_PERSISTENCE:=yes
- # 是否监控运行状态
- #WITH_MEMORY_TRACKING:=yes
这里需要注意的是,默认情况下Mosquitto的安装需要OpenSSL的支持;如果不需要SSL,则需要关闭config.mk里面的某些与SSL功能有关的选项(WITH_TLS、WITH_TLS_PSK)。接着,就是运行make install进行安装,完成之后会在系统命令行里发现mosquitto、mosquitto_passwd、mosquitto_pub和mosquitto_sub四个工具(截图如下),分别用于启动代理、管理密码、发布消息和订阅消息。
安装其他依赖包:
- yum install gcc gcc-c++ libstdc++-devel
- yum install openssl-devel -y
- yum install c-ares-devel -y
- yum install uuid-devel -y
- yum install libuuid-devel -y
安装mosquitto:
1、切换到/home/tool/sourceDir/mosquitto-1.4.14目录下
2、make && make install
3、安装完以后切换到 /etc 目录下查看:
4、切换到 /etc/mosquitto目录下,执行
- cp mosquitto.conf.example mosquitto.conf
5、mosquitto参数详细说明:
- # =================================================================
- # General configuration
- # =================================================================
- # 客户端心跳的间隔时间
- #retry_interval 20
- # 系统状态的刷新时间
- #sys_interval 10
- # 系统资源的回收时间,0表示尽快处理
- #store_clean_interval 10
- # 服务进程的PID
- #pid_file /var/run/mosquitto.pid
- # 服务进程的系统用户
- #user mosquitto
- # 客户端心跳消息的最大并发数
- #max_inflight_messages 10
- # 客户端心跳消息缓存队列
- #max_queued_messages 100
- # 用于设置客户端长连接的过期时间,默认永不过期
- #persistent_client_expiration
- # =================================================================
- # Default listener
- # =================================================================
- # 服务绑定的IP地址
- #bind_address
- # 服务绑定的端口号
- #port 1883
- # 允许的最大连接数,-1表示没有限制
- #max_connections -1
- # cafile:CA证书文件
- # capath:CA证书目录
- # certfile:PEM证书文件
- # keyfile:PEM密钥文件
- #cafile
- #capath
- #certfile
- #keyfile
- # 必须提供证书以保证数据安全性
- #require_certificate false
- # 若require_certificate值为true,use_identity_as_username也必须为true
- #use_identity_as_username false
- # 启用PSK(Pre-shared-key)支持
- #psk_hint
- # SSL/TSL加密算法,可以使用“openssl ciphers”命令获取
- # as the output of that command.
- #ciphers
- # =================================================================
- # Persistence
- # =================================================================
- # 消息自动保存的间隔时间
- #autosave_interval 1800
- # 消息自动保存功能的开关
- #autosave_on_changes false
- # 持久化功能的开关
- persistence true
- # 持久化DB文件
- #persistence_file mosquitto.db
- # 持久化DB文件目录
- #persistence_location /var/lib/mosquitto/
- # =================================================================
- # Logging
- # =================================================================
- # 4种日志模式:stdout、stderr、syslog、topic
- # none 则表示不记日志,此配置可以提升些许性能
- log_dest none
- # 选择日志的级别(可设置多项)
- #log_type error
- #log_type warning
- #log_type notice
- #log_type information
- # 是否记录客户端连接信息
- #connection_messages true
- # 是否记录日志时间
- #log_timestamp true
- # =================================================================
- # Security
- # =================================================================
- # 客户端ID的前缀限制,可用于保证安全性
- #clientid_prefixes
- # 允许匿名用户
- #allow_anonymous true
- # 用户/密码文件,默认格式:username:password
- #password_file
- # PSK格式密码文件,默认格式:identity:key
- #psk_file
- # pattern write sensor/%u/data
- # ACL权限配置,常用语法如下:
- # 用户限制:user <username>
- # 话题限制:topic [read|write] <topic>
- # 正则限制:pattern write sensor/%u/data
- #acl_file
- # =================================================================
- # Bridges
- # =================================================================
- # 允许服务之间使用“桥接”模式(可用于分布式部署)
- #connection <name>
- #address <host>[:<port>]
- #topic <topic> [[[out | in | both] qos-level] local-prefix remote-prefix]
- # 设置桥接的客户端ID
- #clientid
- # 桥接断开时,是否清除远程服务器中的消息
- #cleansession false
- # 是否发布桥接的状态信息
- #notifications true
- # 设置桥接模式下,消息将会发布到的话题地址
- # $SYS/broker/connection/<clientid>/state
- #notification_topic
- # 设置桥接的keepalive数值
- #keepalive_interval 60
- # 桥接模式,目前有三种:automatic、lazy、once
- #start_type automatic
- # 桥接模式automatic的超时时间
- #restart_timeout 30
- # 桥接模式lazy的超时时间
- #idle_timeout 60
- # 桥接客户端的用户名
- #username
- # 桥接客户端的密码
- #password
- # bridge_cafile:桥接客户端的CA证书文件
- # bridge_capath:桥接客户端的CA证书目录
- # bridge_certfile:桥接客户端的PEM证书文件
- # bridge_keyfile:桥接客户端的PEM密钥文件
- #bridge_cafile
- #bridge_capath
- #bridge_certfile
- #bridge_keyfile
5、启动mosquitto服务:
- mosquitto -c /etc/mosquitto/mosquitto.conf
- 或
- mosquitto -c /etc/mosquitto/mosquitto.conf -v -d
- 6、查看端口:
7、至此,mosquitto安装,启动完毕!
补充问题:
1、在启动过程中报错:
- Error: Invalid user 'mosquitto'.
解决方法:
2、重启Mosquitto
笔者在网上找了很多资料都没有提起怎样重启服务器,并且在官网上也没有相应命令提示。
所以我们使用Liunx终止进程命令,强行退出。
- [root@localhost ~]# ps -A | grep mosquitto
- 21674 ? 00:02:38 mosquitto
- [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安装和使用的更多相关文章
- MQTT的学习之Mosquitto安装&使用(1)
Mosquitto是一个实现了MQTT3.1协议的代理服务器,由MQTT协议创始人之一的Andy Stanford-Clark开发,它为我们提供了非常棒的轻量级数据交换的解决方案.本文的主旨在于记录M ...
- MQTT的学习之Mosquitto发布-订阅(2)
在<MQTT的学习之Mosquitto安装&使用(1)>一文末尾,我已经模拟了发布-订阅模式,只是那时在服务器直接模拟的,并不是java代码模拟的.下面贴出Java代码 1.首先引 ...
- MQTT协议学习研究 & Mosquitto简要教程(安装和使用)
若初次接触MQTT协议,可先理解以下概念: [MQTT协议特点]——相比于RESTful架构的物联网系统,MQTT协议借助消息推送功能,可以更好地实现远程控制. [MQTT协议角色]——在RESTfu ...
- 【转载】MQTT的学习之Mosquitto集群搭建
本文出自:http://www.cnblogs.com/yinyi521/p/6087215.html 文章钢要: 1.进行双服务器搭建 2.进行多服务器搭建 一.Mosquitto的分布式集群部署 ...
- Centos7.2 MQTT的学习之Mosquitto搭建&集群搭建&使用
下载安装包http://mosquitto.org/files/source/ 安装依赖yum install -y gcc gcc-c++ libstdc++-develyum install -y ...
- MQTT入门1 -- mosquitto 安装
原文链接:https://www.cnblogs.com/NickQ/p/9247638.html MQTT入门1 -- mosquitto 安装 简介: MQTT(Message Queuing T ...
- Mac 下 Mosquitto 安装和配置 (Mosquitto为开源的mqtt服务器)
官网:http://mosquitto.org/download/ 官网的介绍简单明了 Mac 下一个命令“brew install mosquitto” 安装成功了,还学会了brew 安装目录:/u ...
- Mosquitto安装_Ubuntu/Debian上安装消息队列Mosquitto
Mosquitto安装_Ubuntu/Debian上安装消息队列Mosquitto MQTT是IBM开发的一个即时通讯协议.MQTT是面向M2M和物联网的连接协议,采用轻量级发布和订阅消息传输机制.M ...
- MQTT再学习 -- 搭建MQTT服务器及测试
最近在搞 PM2.5 采集,需要用到 MQTT 传输协议.协议部分看了几天的,讲的七七八八.本身在 intel 上有 写好的MQTT 的源码,现在的工作其实也就是移植到单片机上或者DM368板卡上.不 ...
随机推荐
- Fedora dnf配置
1.在配置文件/etc/dnf/dnf.conf中加入: fastestmirror=true keepcache=true 这样下载安装软件就快多了. 2.dnf常用命令 检查并升级可用软件包: $ ...
- apache添加https证书
今天折腾了一下,总结apache添加https证书的方法. 证书类型分为两种, A)自签名证书 利用oepnssl命令生成.csr和key文件,没有授信,没有有效期,但是可以强制使用https协议,可 ...
- docker实战(一)之Tomcat的安装
docker号称分分钟就可以将环境构建完成,这话一点也不假,因为docker在使用软件时只需要从官方 仓库中拉取对应的镜像就行了.docker的使用前需要了解两个名词--镜像和容器.这两 ...
- 线程锁,threadinglocal,线程池,生产者消费者模型
1.线程锁 1.锁Lock(只能锁一次) import threading import time v = [] lock = threading.Lock() def func(arg): lock ...
- .NET 欢乐编程术之类型超级转换之术👍👍
准备工作:先确保 VS 版本大于 2017,且支持C# 7.0 语言版本.然后新建 .Net Core 项目,在 Nuget 包管理上引入微软霸霸官方包 System.Runtime.Compiler ...
- Java EE.Servlet.生成响应
Servlet的核心职责就是根据客户端的请求生成动态响应. 1.编码类型 2.流操作(下载文件) servlet支持两种格式的输入/输出流.一种是字符输入输出流.另一种是字节输入输出流. 3.重定向
- 我对微服务、SpringCloud、k8s、Istio的一些杂想
一.微服务与SOA “微服务”是一个名词,没有这个名词之前也有“微服务”,一个朗朗上口的名词能让大家产生一个认知共识,这对推动一个事务的发展挺重要的,不然你叫微服务他叫小服务的大家很难集中到一个点上. ...
- [学习笔记] MySQL入门
一.MySQL的安装与简单使用 ubuntu16.04下安装MySQL: sudo apt-get update sudo apt-get install mysql-server mysql-cli ...
- JVM指令
本篇指令码表,参考自ASM文档手册,如果你对asm感兴趣,可到ASM官网下载手册学习. 一.本地变量操作指令(I,L,F,D,A这些前缀表示对int,long,float,double,引用进行操作) ...
- BFS vs DFS
1 Clone Graph 1 copy ervery nodes by bfs 2 add neighbors public UndirectedGraphNode cloneGraph( ...