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

相关推荐
武子康8 分钟前
调查研究-200 llama.cpp b9754:一次很小但很关键的 Agent 工具调用修复
人工智能·agent·llama
Ralph_Salar20 分钟前
从0到1搭建AI智能支付风控助手Stage1-RAG知识库升级 — 元数据让检索更精准
人工智能
武子康29 分钟前
调查研究-199 MCP Zero-Touch OAuth:为什么它是 MCP 进入企业生产的关键门槛?
人工智能·agent·mcp
冬奇Lab35 分钟前
每日一个开源项目(第144篇):ai-website-cloner-template - 一条命令、多 Agent 并行,把任意网站逆向成 Next.js 代码
前端·人工智能·开源
冬奇Lab36 分钟前
AI 原生组织不是买工具,而是让等待消失
人工智能·工作流引擎
半个落月1 小时前
从数据集划分理解大模型的数据工程
人工智能
用户8299792943931 小时前
一文带你彻底搞懂claude code中的上下文压缩
人工智能
IT_陈寒1 小时前
Vue的这个响应式陷阱让我熬到凌晨三点
前端·人工智能·后端
冬奇Lab11 小时前
Workflow 系列(01):基础理论——三种执行模型与 Anthropic 5 种模式
人工智能·agent·工作流引擎
冬奇Lab11 小时前
每日一个开源项目(第143篇):page-agent - 纯 JS 的网页 GUI Agent,无需截图、无需插件、无需后端
前端·人工智能·agent