基于优先级的流量控制(PFC)

一、引言

PFC(Priority-based Flow Control)的含义是基于优先级的流量控制,它是目前应用最广泛的能够有效避免丢包的流量控制技术,是智能无损网络的基础。使能了PFC功能的队列,我们称之为无损队列。当下游设备的无损队列发生拥塞时,下游设备会通知上游设备会停止发送该队列的流量,从而实现零丢包传输。

二、传统流量控制技术

最基本的流量控制技术是IEEE802.3定义的以太Pause机制:当网络中的下游设备发现其流量接收能力小于上游设备的发送能力时,会主动发Pause帧给上游设备,要求上游设备暂停流量发送,等待一段时间后再继续发送。

Pause的局限性会暂停整个链路的流量,可能影响其他类型的业务。

三、PFC的协议802.1Qbb规定

PFC通过将链路划分为多个虚拟通道,每个通道对应一个优先级队列。当某个队列的缓存超过阈值时,接收端发送反压信号(STOP)给发送端,暂停该优先级队列的流量,而其他队列不受影响。PFC帧的格式包括优先级使能向量和反压定时器等字段。

图 PFC帧格式

PFC的优势在于:

  • 实现多种流量的共享链路。

  • 针对特定优先级队列进行流量控制,避免全链路暂停。

  • 支持无丢包传输,适用于高可靠性场景。

四、水线阈值的设置

XOFF-XON = Pause Region暂停深度是设计的关键。暂停深度能容纳在发出XON到上游实际恢复发送的时间内的总流量。

Pause Region = RTT×带宽+安全余量

经验值

|---|---------|---|
| | 队列深度的比例 | |
| | 50% | |
| | 70% | |

参考

什么是PFC? - 华为

相关推荐
米高梅狮子8 小时前
03.网络类服务实践
linux·运维·服务器·网络·kubernetes·centos·openstack
June`8 小时前
网络编程时内核究竟做了什么???
linux·服务器·网络
原来是猿8 小时前
腾讯云服务器端口开放完全指南
服务器·网络·腾讯云
你的保护色9 小时前
【无标题】
java·服务器·网络
楼兰公子9 小时前
RK3588 + Linux7.0.3 网络工程调试错误速查手册
linux·网络·3588
IpdataCloud9 小时前
稳定的企业级IP数据接口怎么选?可用性指标+离线库高可用方案
运维·网络·tcp/ip
HMS工业网络9 小时前
如何解决使用TwinCAT时EtherCAT网络出现“Sync Manager Watchdog”报错
网络·网络协议·网络安全
逸巽散人15 小时前
【无标题】
网络
kaoa00015 小时前
Linux入门攻坚——77、虚拟化技术基础原理-2
linux·服务器·网络
沪漂阿龙16 小时前
面试题详解:大模型设计沙箱全攻略——LLM Sandbox、Agent 工具执行、代码沙箱、安全隔离、权限控制与工程落地
网络·数据库·人工智能·安全