TCP 的那些事儿(下)
这篇讲的是TCP协议核心机制中的“动态调整”与“流控”部分,聚焦于RTT算法演进和滑动窗口原理。作者从一个实际问题切入:重传超时时间(RTO)为何不能固定设置?由此引出RTT(网络往返时长)的测量难题。 文章清晰对比了三代算法。经典算法依赖加权平均,但容易掩盖网络抖动;Karn算法为解决重传采样矛盾选择“忽略重传”,却又用粗暴的“超时翻倍”来应对网络突变;最终,Linux内核采用的Jacobson/Karels算法则更胜一筹,它引入“偏差”因子,能敏锐感知RTT的波动,计算出更精准的RTO。 另一重点是滑动窗口。文章用生动图示拆解了接收端如何通过Advertised-Window告诉发送端“我能收多少”,从而实现流量控制,并详细说明了Zero Window的处理机制及潜在的DDoS风险。整篇内容扎实,用“不适合在厕所中阅读”幽默地暗示了其思维深度,将抽象算法与网络稳定性的现实关联讲得透彻明白。