Linux 搭建MQTT服务器并使用

环境:ubuntu 18.04

1、安装必备软件

yum install gcc-c++ cmake openssl-devel -y

2、下载mosquitto

我下载的是1.6.8,因为我尝试了最新版1.6.9,它的包里丢了一个头文件,莫名其妙,然后降了一版 官方地址:https://mosquitto.org/,下载地址:https://mosquitto.org/files/source/ 我们使用wget命令下载新包,或者直接下载然后传入服务器。我是直接装在/root下面的,如有需求自行修改路径。

wget http://mosquitto.org/files/source/mosquitto-1.6.8.tar.gz

3、解压 编译 安装

echo "解压"
tar -zxvf mosquitto-1.6.8.tar.gz
echo "进入mosquitto-1.6.8"
cd mosquitto-1.6.8
echo "编译"
Make
echo "安装"
sudo make install

之后会碰到找不到libmosquitto.so.1这个问题,修改链接路径,重新加载动态链接库

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

备注:如果在编译过程中出现没有cJSON相关的文件,则用如下的命令编译和加载

Linux 搭建MQTT服务器并使用_第1张图片

 

4、创建配置文件

原始example去掉,此配置文件内容很多,比如端口默认 1883,密码文件位置,监听端口数,绑定网卡,日志记录等等,内容众多需要自行研究。

mv /etc/mosquitto/mosquitto.conf.example /etc/mosquitto/mosquitto.conf

5、创建用户组和用户

sudo groupadd mosquitto
sudo useradd -g mosquitto mosquitto -s /sbin/nologin

不创建执行程序没反应,猜测因为配置文件中默认使用user mosquitto。 如果不想创建此用户,可以修改配置文件/etc/mosquitto/mosquitto.conf

# When run as root, drop privileges to this user and its primary# group.# Set to root to stay as root, but this is not recommended.# If run as a non-root user, this setting has no effect.# Note that on Windows this has no effect and so mosquitto should# be started by the user you wish it to run as.#user mosquitto
user root

 

6、启动、查看、关闭程序

默认是后台运行,可以ps看下进程,kill关闭

echo "运行程序"
mosquitto -c /etc/mosquitto/mosquitto.conf -d
echo "ps查看"
ps -aux | grep mosquitto
echo "关闭程序"
kill -9 $(pidof mosquitto)

 

7、本地简单测试

mosquitto_pub 命令参数说明
-d 打印debug信息
-f 将指定文件的内容作为发送消息的内容
-h 指定要连接的域名 默认为localhost
-i 指定要给哪个clientId的用户发送消息
-I 指定给哪个clientId前缀的用户发送消息
-m 消息内容
-n 发送一个空(null)消息
-p 连接端口号
-q 指定QoS的值(0,1,2)
-t 指定topic
-u 指定broker访问用户
-P 指定broker访问密码
-V 指定MQTT协议版本
--will-payload 指定一个消息,该消息当客户端与broker意外断开连接时发出。该参数需要与--will-topic一起使用
--will-qos Will的QoS值。该参数需要与--will-topic一起使用
--will-retain 指定Will消息被当做一个retain消息(即消息被广播后,该消息被保留起来)。该参数需要与--will-topic一起使用
--will-topic 用户发送Will消息的topic
 
  
mosquitto_sub 命令参数说明
-c 设定‘clean session’为无效状态,这样一直保持订阅状态,即便是已经失去连接,如果再次连接仍旧能够接收的断开期间发送的消息。
-d 打印debug信息
-h 指定要连接的域名 默认为localhost
-i 指定clientId
-I 指定clientId前缀
-k keepalive 每隔一段时间,发PING消息通知broker,仍处于连接状态。 默认为60秒。
-q 指定希望接收到QoS为什么的消息 默认QoS为0
-R 不显示陈旧的消息
-t 订阅topic
-v 打印消息
--will-payload 指定一个消息,该消息当客户端与broker意外断开连接时发出。该参数需要与--will-topic一起使用
--will-qos Will的QoS值。该参数需要与--will-topic一起使用
--will-retain 指定Will消息被当做一个retain消息(即消息被广播后,该消息被保留起来)。该参数需要与--will-topic一起使用
--will-topic 用户发送Will消息的topic

打开一个订阅者

mosquitto_sub -t topic

打开一个发布者

mosquitto_pub -t topic -m "发布内容"

 

相同topic的双方,发布者pub发送 “发布内容”给订阅者sub

8、修改默认配置

1.关闭匿名用户登录

打开mosquitto.conf文件( /etc/mosquitto/mosquitto.conf ),找到allow_anonymous节点,这个节点作用是,是否开启匿名用户登录。去掉前面的#,改为false。在651行左右

Linux 搭建MQTT服务器并使用_第2张图片

 

2.设置用户密码文件路径

找到password_file节点,这个节点是告诉服务器你要配置的用户将存放在哪里。打开此配置并指定pwfile.example文件路径(注意是绝对路径),在669行左右。 password_file /etc/mosquitto/pwfile.example

 

3.创建自定义用户

终端输入,最后面的是用户名

mosquitto_passwd -c /etc/mosquitto/pwfile.example username

之后自动弹出密码和确认密码,输入即可。(注意第二次创建用户时不用加 -c 如果加 -c 会把第一次创建的用户覆盖。)

 

用户信息存储于 /etc/mosquitto/pwfile.example,对密码进行了加密

 

4、重启mosquitto生效

echo "关闭程序"
kill -9 $(pidof mosquitto)
echo "运行程序"
mosquitto -c /etc/mosquitto/mosquitto.conf -d

你可能感兴趣的:(工具,linux,运维,服务器)