Mosquitto 部署及联调

序言

本文适用于mqtt mosquitto部署的初步入门,旨在提供一个从0到1的基础操作指引,实现从基础部署到测试联调。关于本文中使用的mosquitto命令详细说明,请自行参考官方文档或其他资料。

准备

1、一台云服务器。

2、本地电脑环境,需要python运行环境。

安装

1、安装mosquitto环境。

复制代码
sudo apt install mosquitto mosquitto-clients

2、确认安装是否成功,安装成功之后,会有版本信息打印。

复制代码
mosquitto -v

启用服务

1、启动服务。

复制代码
sudo systemctl start mosquitto

2、设置开机自启。

复制代码
sudo systemctl enable mosquitto

3、查看状态。

复制代码
sudo systemctl status mosquitto

配置用户和密码

1、在 /etc/mosquitto/passwd 路径创建密码文件,并添加一个名为 user_test_01 的用户。

复制代码
mosquitto_passwd -c /etc/mosquitto/passwd user_test_01

2、根据提示输入两次密码。

3、修改 /etc/mosquitto/mosquitto.conf 文件,在文件末尾插入如下代码。参考官网

复制代码
##########    Authentication methods start ##########
per_listener_settings true
​
# password
listener 1883
password_file /etc/mosquitto/passwd
​
# plugins
# todo
​
# anonymous
allow_anonymous false
##########    Authentication methods end ##########

per_listener_settings true:启用授权方法组合策略

listener 1883 和 password_file /etc/mosquitto/passwd:启用网络连接,否则mosquitto会一直保持在 only local 模式下。而且 listener 一定要放在 password_file 前面。

allow_anonymous false:禁用匿名连接。

4、配置完成后重启改服务。

复制代码
sudo systemctl restart mosquitto

测试

本地客户端

一、测试原理:本地用python脚本模拟subscriber和publisher客户端,和broker(mosquitto服务器)通信。

二、测试步骤

1、将如下 publisher.pysubscriber.py、config.json放置在统一文件夹下。

2、根据自己的配置,修改config.json。

3、先运行subscriber.py再运行publisher.py。可以看到publish客户端发送的数据,发给broker后,subscribe客户端能正确收到。

三、测试结果

四、源码

复制代码
# publisher.py.py
import paho.mqtt.client as mqtt
import json
import time
​
with open('config.json', 'r') as f:
    config = json.load(f)
​
broker_address = config['broker']['host']
broker_port = config['broker']['port']
broker_user = config['broker']['user']
broker_password = config['broker']['password']
broker_topic = config['broker']['topic']
​
client = mqtt.Client(client_id="publisher")
​
def on_publish(client, userdata, result):  # 当消息被发送出去后,会调用这个函数
    print("消息发布成功")
​
def init_publisher_client():
    client.on_publish = on_publish
    client.username_pw_set(broker_user,broker_password)
    ret = client.connect(broker_address)
​
    if 0 == ret:
        print("publisher connect success")
        return True
    else:
        print("publisher connect failed " + ret)
        return False
​
def send_message():
    for index in range(0,9):
        message = "Hello MQTT!" + str(index)
        client.publish(broker_topic, message)
        time.sleep(2)
​
def end_publisher_client():
    client.disconnect()
    print("publisher finish, disconnect")
​
if init_publisher_client():
    send_message()
    end_publisher_client()
else:
    print("publisher fail")

复制代码
# subscriber.py
import paho.mqtt.client as mqtt
import json
​
with open('config.json', 'r') as f:
    config = json.load(f)
​
broker_address = config['broker']['host']
broker_port = config['broker']['port']
broker_user = config['broker']['user']
broker_password = config['broker']['password']
broker_topic = config['broker']['topic']
​
def on_connect(client, userdata, flags, rc):
    print(f"Connected with result code {rc}")
    client.subscribe(broker_topic)
​
def on_message(client, userdata, msg):
    print(f"Received message: {msg.payload.decode()} on topic {msg.topic}")
​
client = mqtt.Client(client_id="subscriber")
client.on_connect = on_connect
client.on_message = on_message
client.username_pw_set(broker_user,broker_password)
client.connect(broker_address)
client.loop_start()
​
try:
    while True:
        pass
except KeyboardInterrupt:
        print("Shutting down...")
finally:
    client.disconnect()
    client.loop_stop()

# config.json
{
    "broker": {
        "host": "xx.xx.xx.xx",        # host ip, example: 12.34.56.78
        "port": 1833,                            # 默认 1833
        "user": "user_name",            # mosquitto_passwd 创建的用户名称
        "password": "password",        # mosquitto_passwd 创建的用户对应的密码
        "topic": "test_topic"            # 随便填
    }
}

可以查看服务器的日志,某些情况可能有用。

复制代码
cat /var/log/mosquitto/mosquitto.log
相关推荐
夏玉林的学习之路17 小时前
如何远程连接服务器
运维·服务器
影寂ldy19 小时前
C# try-catch 异常处理全套笔记
服务器·数据库·c#
fei_sun19 小时前
黑洞路由(Null Route/空接口路由)
服务器·前端·javascript
researcher-Jiang21 小时前
高性能计算之MPI:第一次MPI并行程序设计练习
linux·运维·服务器
normanhere1 天前
浪潮云国产化超融合规划和部署案例
服务器·网络
CCPC不拿奖不改名1 天前
Redis 工程化部署深度解析
linux·服务器·数据库·redis·深度学习·缓存·rag
QWEDDRFTG1 天前
运维长期经验总结:从故障倒推服务器电源线选购标准
运维·服务器
Mr.wangh1 天前
聊天模型--流式传输
运维·服务器
有颜有货1 天前
PMC生产排产的4种算法,一次讲清
java·服务器·前端
智恒百亿1 天前
算力基建深度分析:国内服务器产业高强度迭代下的技术壁垒与全球化优势
服务器·人工智能·算力基建