第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高级特性,包括共享订阅、主题别名、请求响应等。