第8章 Mosquitto消息高级特性

第8章 消息高级特性

8.1 消息队列机制



QoS 0
QoS 1/2
消息到达
是否有订阅者?
立即投递
QoS等级?
丢弃
入队等待
新订阅者连接
发送队列消息

8.2 $SYS系统主题

bash 复制代码
# 监控所有系统主题
mosquitto_sub -v -t "$SYS/#"

# 常用系统主题
$SYS/broker/version           # 版本
$SYS/broker/uptime            # 运行时间
$SYS/broker/timestamp         # 时间戳
$SYS/broker/clients/connected # 在线客户端
$SYS/broker/bytes/received    # 接收字节
$SYS/broker/messages/stored   # 存储消息

$SYS主题树

$SYS
broker
clients
version
uptime
load
bytes
messages
connected
disconnected
maximum
received
sent
stored

8.3 共享订阅

订阅者3 订阅者2 订阅者1 Broker 发布者 订阅者3 订阅者2 订阅者1 Broker 发布者 共享订阅组: g1 负载均衡选择一个订阅者 轮询到下一个订阅者 SUBSCRIBE share/g1/sensor/ SUBSCRIBE share/g1/sensor/ SUBSCRIBE $share/g1/sensor/ PUBLISH sensor/temp "25" PUBLISH sensor/temp "25" PUBLISH sensor/hum "60" PUBLISH sensor/hum "60"

共享订阅语法

bash 复制代码
# 共享订阅格式: $share/{GroupName}/{Topic}

# 订阅者1
mosquitto_sub -t "$share/group1/sensor/#"

# 订阅者2
mosquitto_sub -t "$share/group1/sensor/#"

# 订阅者3
mosquitto_sub -t "$share/group1/sensor/#"

# 发布消息
mosquitto_pub -t "sensor/temp" -m "25"
# 只有其中一个订阅者收到

应用场景

共享订阅
负载均衡
多消费者
避免重复处理
提高吞吐量
队列处理
任务分发
并行处理
水平扩展
场景
数据采集集群
消息处理队列
微服务集成

8.4 主题别名

Broker 客户端 Broker 客户端 首次发送完整主题 后续使用别名 节省带宽 PUBLISH sensor/device001/temp Topic Alias: 1 缓存: 1 ->> sensor/device001/temp PUBLISH Topic Alias: 1 展开: sensor/device001/temp

主题别名配置

bash 复制代码
# Mosquitto 2.x 自动支持主题别名
# MQTT 5.0特性

# 客户端使用
mosquitto_pub -t "very/long/topic/name" -m "data" -q 1
# 自动使用别名缩短后续消息

8.5 请求/响应模式

服务端 Broker 请求者 服务端 Broker 请求者 生成相关ID 处理请求 匹配相关ID 关联请求响应 PUBLISH cmd/request Correlation Data: xyz123 Response Topic: response/cmd PUBLISH cmd/request PUBLISH response/cmd Correlation Data: xyz123 Payload: "result" PUBLISH response/cmd

请求/响应示例

python 复制代码
# 请求者
import paho.mqtt.client as mqtt
import uuid

def on_message(client, userdata, msg):
    if msg.topic == "response/cmd":
        print(f"响应: {msg.payload}")

client = mqtt.Client()
client.on_message = on_message
client.connect("localhost", 1883)
client.subscribe("response/#")

correlation_id = str(uuid.uuid4())
client.publish(
    "cmd/request",
    "get_status",
    properties=[
        mqtt.Properties.PacketTypes.PUBLISH.CorrelationData(
            correlation_id.encode()
        ),
        mqtt.Properties.PacketTypes.PUBLISH.ResponseTopic(
            "response/cmd"
        )
    ]
)

8.6 消息过期

bash 复制代码
# MQTT 5.0 消息过期
# 单位: 秒

mosquitto_pub -t "sensor/data" -m "temp:25" \
  -D publish message-expiry-interval 60 \
  -q 1

8.7 用户属性

消息
Payload
User Properties
key1: value1
key2: value2
key3: value3
元数据传递

用户属性示例

bash 复制代码
# 使用mosquitto_pub
mosquitto_pub -t "sensor/data" -m "25.5" \
  -D publish user-property "location,livingroom" \
  -D publish user-property "type,temperature" \
  -D publish user-property "unit,celsius"

8.8 本章小结

掌握了MQTT高级特性,包括共享订阅、主题别名、请求响应等。

相关推荐
H Journey2 小时前
OpenCV之Canny边缘检测
人工智能·opencv·计算机视觉
观远数据2 小时前
未来3年企业数据分析的核心:基于自然语言的AI优先决策体系如何搭建
数据库·人工智能·数据分析
zhengyquan2 小时前
微软砸1.6万亿日元布局日本AI!
人工智能·microsoft
Dev7z2 小时前
基于MATLAB与SVM实现河道水面漂浮物的自动检测与识别
人工智能·支持向量机·matlab
prog_61032 小时前
【笔记】用cursor手搓cursor(五)再见claude
人工智能·笔记·大语言模型·agent
爱睡懒觉的焦糖玛奇朵2 小时前
【工业级落地算法之打架斗殴检测算法详解】
人工智能·python·深度学习·学习·算法·yolo·计算机视觉
programhelp_2 小时前
IBM OA 高频真题分享|2026最新-Programhelp 独家整理
人工智能·机器学习·面试·职场和发展·数据分析
rOuN STAT2 小时前
PLC(电力载波通信)网络机制介绍
开发语言·网络·php
nFBD29OFC2 小时前
pillow - 图像处理的瑞士军刀
图像处理·人工智能·pillow