# wget https://mosquitto.org/files/source/mosquitto-1.6.7.tar.gz
# tar zxvf mosquitto-1.6.7.tar.gz
# mv mosquitto-1.6.7 /usr/local/mosquitto-1.6.7
以下三个必须安装,不然make时无法通过。 另外安装MQTT之前,我们也可以# cat compiling.txt文件阅读一下官方的说明。
# yum -y install openssl-devel
# yum -y install gcc-c++
# yum -y install cmake
其他扩展
# yum install -y c-ares-devel
# yum install -y uuid-devel
# yum install -y libuuid-devel
# yum install -y libwebsockets //yum安装会出错,请使用编译安装
# cd /usr/local/mosquitto-1.6.7
# vim config.mk
修改以下为yes,如果前面有#就去掉,保存退出。
WITH_SRV:=yes
WITH_WEBSOCKETS:=yes
WITH_ADNS:=yes
# make
# make install
以上执行# make时,如果不报错的话,就跳过以下说明。如果报错: mosquitto.c:49:29: fatal error: libwebsockets.h: No such file or directory
那么说明libwebsockets 没有安装好,执行卸载# yum remove libwebsockets,下载新的源包的进行安装,步骤如下。
源包链接:https://github.com/warmcat/libwebsockets 我们选择一个版本复制zip下载链接,这里我选择的是1.5版本。
# wget https://github.com/warmcat/libwebsockets/archive/v1.5-stable.zip
# yum -y install unzip
# unzip v1.5-stable.zip
# mkdir -p /usr/local/websocket
# mv libwebsockets-1.5-stable /usr/local/websocket
# cd /usr/local/websocke/libwebsockets-1.5-stable
# cmake .
# make
# make install
执行以上安装ibwebsockets后,重新编译安装MQTT # cd /usr/local/mosquitto-1.6.7 # make # make install 这3个命令前面已经列出过了。
创建用户:
groupadd mosquitto
useradd -g mosquitto mosquitto
程序配置:
mv /etc/mosquitto/mosquitto.conf.example /etc/mosquitto/mosquitto.conf
启动程序:
mosquitto -c /etc/mosquitto/mosquitto.conf -d
默认端口为1883
最后我们再打开一个服务器窗口,在一个(订阅)窗口输入:
mosquitto_sub -t hello
另一个(发布)窗口输入:
mosquitto_pub -t hello -h localhost -m "hello world"
解决方法:使用whereis可以查找 libwebsockets.so.5的所在路径,建立一个软链接到/usr/lib 下即可。
# ln -s /usr/local/lib/libwebsockets.so.5 /usr/lib/libwebsockets.so.5
# ldconfig
ln -s /usr/local/lib/libmosquitto.so.1 /usr/lib/libmosquitto.so.1
ldconfig
1、查看mosquitto的进程
ps -aux | grep mosquitto
2、杀掉进程
kill -9 18248
3.启动mosquitto
mosquitto -c /etc/mosquitto/mosquitto.conf -d
打开mosquitto.conf文件,找到allow_anonymous节点,这个节点作用是,是否开启匿名用户登录,默认是true。打开此项配置(将前面的 # 号去掉)之后将其值改为true
修改前:#allow_anonymous
修改后:allow_anonymous false
找到password_file节点,这个节点是告诉服务器你要配置的用户将存放在哪里。打开此配置并指定pwfile.example文件路径
修改前:#password_file
修改后:password_file /etc/mosquitto/pwfile
创建用户名和密码、打开命令窗口 键入如下命令:
mosquitto_passwd -c /etc/mosquitto/pwfile admin
提示连续两次输入密码、创建成功。命令解释: -c 创建一个用户 /etc/mosquitto/pwfile 是将用户创建到 pwfile文件中、admin 是用户名
打开mosquitto.conf文件,找到password_file节点
修改前:#acl_file
修改后:acl_file /etc/mosquitto/aclfile
认证配置pwfile,没有则创建文件
# This affects access control for clients with no username.
topic read $SYS/#
# This only affects clients with username "roger".
user roger
topic foo/bar
# This affects all clients.
#pattern write $SYS/broker/connection/%c/state
#admin 可读写hello topic
user admin
topic hello/#
#bing 只能读
user bing
topic read hello/#
mosquitto_sub -t hello -h 127.0.0.1 -u admin -P admin@123
mosquitto_pub -t hello -h localhost -m "hello world" -u admin -P admin@123
yum install https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm
yum repolist all | grep enabled
查找 mosquitto 软件包:yum list all | grep mosquitto
查看 mosquitto 信息: yum info mosquitto
安装 mosquitto 软件包: yum install mosquitto
查看安装结果:yum list installed | grep mosquitto
启动 mosquitto 主程序:mosquitto
新建一个ssh窗口;订阅》执行命令:mosquitto_sub -t test
新建一个ssh窗口;发布》执行命令:mosquitto_pub -t test -h localhost -m "hello, world"
可以看到订阅窗口收到:hello, world
查找 mosquitto 服务:find / -iname mosquitto* | grep service
设置 mosquitto 服务:systemctl enable mosquitto.service
启动 mosquitto 服务:systemctl start mosquitto.service
查看 mosquitto 状态:systemctl status mosquitto.service
查看进程:ps -aux | grep mosquitto
重启 CentOS:reboot,查看 mosquitto 服务是否自动启动:systemctl list-units | grep mosquitto
mosquitto_pub 命令参数说明
mosquitto_sub 命令参数说明