# Mosquitto 搭建及配置
[](https://www.jianshu.com/u/24eb890d1bd1)
> Eclipse Mosquitto是一个开源消息代理,实现了MQTT协议版本3.1和3.1.1。Mosquitto轻量,适用于低功耗单板计算机到完整服务器的所有设备。Mosquitto项目还提供了用于实现MQTT客户端的C库以及非常受欢迎的mosquitto\_pub和mosquitto\_sub命令行MQTT客户端。
其他服务器代理实现:[https://github.com/mqtt/mqtt.github.io/wiki/servers](https://github.com/mqtt/mqtt.github.io/wiki/servers)各操作系统安装指引:[https://mosquitto.org/download/](https://mosquitto.org/download/)
#### 1\. 下载安装
以Ubuntu16为例
* 添加到存储库列表
~~~csharp
sudo apt-add-repository ppa:mosquitto-dev/mosquitto-ppa
~~~
* 更新软件包
~~~csharp
sudo apt-get update
~~~
* 安装
~~~csharp
sudo apt-get install mosquitto
~~~
* 安装命令行客户端
~~~csharp
sudo apt-get install mosquitto-clients
~~~
#### 2\. 配置
##### 2.1 主配置文件mosquitto.conf
~~~csharp
port 1883
listener 8003
protocol websockets
pid_file /var/run/mosquitto.pid
# 消息持久存储
persistence true
persistence_location /var/lib/mosquitto/
# 日志文件
log_dest file /var/log/mosquitto/mosquitto.log
# 其他配置
include_dir /etc/mosquitto/conf.d
# 禁止匿名访问
allow_anonymous false
# 认证配置
password_file /etc/mosquitto/pwfile
# 权限配置
acl_file /etc/mosquitto/aclfile
~~~
##### 2.2 认证配置pwfile
* 没有则创建文件
~~~undefined
mosquitto_passwd -c pwfile 用户名
~~~
##### 2.3 权限配置aclfile
* 打开文件
~~~undefined
vim /etc/mosquitto/aclfile
~~~
* 编辑内容
~~~bash
# 李雷只能发布以test为前缀的主题,订阅以$SYS开头的主题即系统主题
user lilei
topic write test/#
topic read $SYS/#
# 韩梅梅只能订阅以test为前缀的主题
user hanmeimei
topic read test/#
~~~
#### 3\. 启动
\-c:指定特定配置文件启动-d:后台运行
~~~swift
mosquitto -c /etc/mosquitto/mosquitto.conf -d
~~~
#### 4\. 测试
发布使用mosquitto\_pub命令,订阅使用mosquitto\_sub命令。常用参数介绍:
| 参数 | 描述 |
| --- | --- |
| \-h | 服务器主机,默认localhost |
| \-t | 指定主题 |
| \-u | 用户名 |
| \-P | 密码 |
| \-i | 客户端id,唯一 |
| \-m | 发布的消息内容 |
订阅
~~~bash
mosquitto_sub -h localhost -t "test/#" -u hanmeimei -P 123456 -i "client1"
~~~
订阅系统主题
~~~bash
# 订阅客户端存活连接数
mosquitto_sub -h localhost –t '$SYS/broker/clients/active' -u lilei -P 123456 -i "client2"
~~~
发布
~~~bash
mosquitto_pub -h localhost -t "test/abc" -u lilei -P 123456 -i "client3" -m "How are you?"
~~~
## 调整内核参数
```
在/etc/security/limits.conf最后增加如下两行记录
* soft nofile 65535
* hard nofile 65535
ulimit -n 65535
//
sysctl -w
```