深度解析PFC和ECN

hdd
hdd
1月1日发布 /正在检测是否收录...

深入理解 PFC & ECN(含优先级概念详解)

🔶PFC(Priority Flow Control)本质与优先级说明

PFC = IEEE 802.1Qbb,是对传统 802.3x Pause 的增强版。
区别:802.3x暂停是全局停,PFC可以按优先级分类停。

📌PFC优先级(CoS / PCP)

网络帧头的 VLAN Tag 中 PCP字段,共3bit,可表示 8 个优先级:

PCP值优先级名 (CoS)常见用途
0Best Effort普通业务流量(Web/办公)
1Background后台/低优先级同步
2Spare预留或低价值流量
3Excellent Effort更高优先级业务
4Controlled Load视频/语音
5VoiceVoIP实时流
6Internetwork Control控制面协议(OSPF/BGP)
7Network Control / RDMARoCEv2/存储RDMA/算力流量(最敏感)

👉PFC通常只在少数优先级上启用,例如PCP=3或PCP=7,用于Lossless流量。
即:

PFC ≠ 全局启用
PFC = 针对关键队列做Lossless保证

📌为什么不能全启?

❌全局启用 → 非关键流量也暂停
❌拥塞传播快 → 形成“暂停风暴”
❌更容易死锁

🚦PFC工作流程(展开)

① 交换机检测某优先级队列逼近门限(Buffer Threshold)
② 判断 → 达到触发条件
③ 发送PFC Pause帧给上游设备
④ 上游暂停该优先级对应流量发送
⑤ 拥塞缓解后继续传输

📌重点理解:

PFC只控制 → 入口队列(Ingress Queue)
PFC暂停的是 → “发送端的发送”
不是把现有包退回/吞掉

🧊PFC常见的三大问题(展开讲)

1)Head-of-Line Blocking(HOL阻塞)

同一个端口上,单个队列被暂停 → 后面队列想走也走不了
(车道被封,同路段车辆都被阻塞)

2)Deadlock 死锁

A暂停B → B等待C → C又暂停A
(环形互相等待 → 谁也走不了 → 网络冻结)

3)Pause Storm 暂停风暴

拓扑中大量Pause扩散 → 整网吞吐崩溃

🩹解决方向(不是配置命令,而是策略):

✔ 只给必要优先级开PFC(RDMA)
✔ Buffer与门限要分级(Low/High Threshold)
✔ ECN/WRED搭配使用避免过早触发PFC
✔ 设计避免环路形成“暂停闭环”

🔶ECN(Explicit Congestion Notification)深入讲解

ECN是什么?

在不丢包的情况下通知拥塞
靠“标记+反馈”让发送端主动减速

📌ECN字段位于IP头中的ECN位(2bit):

名字含义
00Not-ECT未启用ECN
01ECT(1)启用ECN,可标记
10ECT(0)启用ECN,可标记
11CECongestion Experienced(已拥塞)

ECN工作机制(展开版)

① 流量传输阶段 → 交换机队列填高
② 队列未溢出 → 不丢包
③ 交换机在包头打 CE 标记
④ 接收方收到后 → 发回反馈给源端(TCP Echo/CNP等)
⑤ 源端降低发送速度(拥塞窗口/发送速率下降)
⑥ 拥塞缓解后再逐步加速

🔁形成一个动态闭环,类似:

拥塞 → 降速
恢复 → 加速

📌ECN不是万能的(限制解释)

❗端到端必须全部支持(主机/网卡/交换机/协议栈)
❗如果路径中有设备不支持 → ECN=无效
❗只调速,不消除拥塞源头(例如糟糕拓扑/链路不均衡)

🔷总结:PFC vs ECN 核心对照(深度版)

对比项PFCECN
作用层次L2L3/传输层
针对流量某优先级队列所有流路径
控制方式Pause帧硬停CE标记 + 降速
瞬时效果立即停止流量降速之后逐渐见效
默认触发条件Queue接近满Queue增长但未满
风险点死锁/HOL阻塞端到端兼容性问题
理想状态下作用消除丢包防止拥塞扩大
简化理解刹车智能油门调节

📌组合意义:

PFC 保证 Lossless
ECN 保证低延迟 & 不爆队列

🎯结合实际架构的推荐

适用于算力/AI训练/RDMA/RoCEv2环境:

RDMA优先级(PCP=3/7):启用PFC & ECN
普通业务:启用ECN,禁用PFC
跨域/互联网:仅启ECN
存储流量(NVMe-oF):需Lossless → 允许PFC

🧠总结

PFC按优先级暂停流量,提供无丢包环境,但可能导致HOL阻塞与死锁;
ECN通过显式拥塞通知进行端到端调速,避免队列爆满但不保证无丢包。
在RoCEv2等高一致性Lossless网络中,两者常结合使用:PFC兜底,ECN控速。
© 版权声明
THE END
喜欢就支持一下吧
点赞 0 分享 收藏
评论 抢沙发
OωO
取消