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
相关推荐
郝学胜-神的一滴7 小时前
超越Spring的Summer(一): PackageScanner 类实现原理详解
java·服务器·开发语言·后端·spring·软件构建
匆匆那年9678 小时前
llamafactory推理消除模型的随机性
linux·服务器·学习·ubuntu
杜子不疼.8 小时前
远程软件大战再升级:2026年2月三大远程控制软件深度横评,安全功能成新焦点
服务器·网络·安全
linux kernel9 小时前
第六部分:数据链路层
服务器·网络
较劲男子汉16 小时前
CANN Runtime零拷贝传输技术源码实战 彻底打通Host与Device的数据传输壁垒
运维·服务器·数据库·cann
wypywyp16 小时前
8. ubuntu 虚拟机 linux 服务器 TCP/IP 概念辨析
linux·服务器·ubuntu
Doro再努力16 小时前
【Linux操作系统10】Makefile深度解析:从依赖推导到有效编译
android·linux·运维·服务器·编辑器·vim
senijusene16 小时前
Linux软件编程:IO编程,标准IO(1)
linux·运维·服务器
不像程序员的程序媛16 小时前
Nginx日志切分
服务器·前端·nginx
忧郁的橙子.16 小时前
02-本地部署Ollama、Python
linux·运维·服务器