EMQ X的高级功能使用(六)
学习目标
目标1:飞行窗口
目标2:在何种场景下会产生消息重传
1.飞行窗口和消息队列
1.1 简介
为了提高消息吞吐效率和减少网络波动带来的影响,EMQ X 允许多个未确认的 QoS 1 和 QoS 2 报文同时存在于网路链路上。这些已发送但未确认的报文将被存放在飞行窗口(Inflight Window)中直至完成确认。
当网络链路中同时存在的报文超出限制,即飞行窗口到达长度限制(在emqx.conf配置文件中的max_inflight 相关配置)时,EMQ X 将不再发送后续的报文,而是将这些报文存储在 Message Queue 中。一旦飞行窗口中有报文完成确认,Message Queue 中的报文就会以先入先出的顺序被发送,同时存储到飞行窗口中。
需要注意的是,如果 Message Queue 也到达了长度限制,后续的报文将依然缓存到 Message Queue,但相应的 Message Queue 中最先缓存的消息将被丢弃。因此,根据你的实际情况配置一个合适的 Message Queue 长度限制(在emqx.conf配置文件中的 max_mqueue_len 相关配置)是非常重要的。
1.2 飞行队列与Receive Maximum
MQTT v5.0 协议为 CON