Linux TCP 拥塞正反馈 bad case

前置知识,TCP thin stream,参见:

看图说话:
在这里插入图片描述
参见 tcp_retransmit_timer 函数,着重看下面段落:

if (sk->sk_state == TCP_ESTABLISHED &&
    (tp->thin_lto || net->ipv4.sysctl_tcp_thin_linear_timeouts) &&
    tcp_stream_is_thin(tp) &&
    icsk->icsk_retransmits <= TCP_THIN_LINEAR_RETRIES) {
        icsk->icsk_backoff = 0;
        icsk->icsk_rto = min(__tcp_set_rto(tp), TCP_RTO_MAX);
} else {
        /* Use normal (exponential) backoff */
        icsk->icsk_rto = min(icsk->icsk_rto << 1, TCP_RTO_MAX);
}

thin stream 在严重拥塞丢包率高场景会加大 rto 变 0 的可能性从而按照 HZ 频率盲灌重传报文,加重拥塞。

要么关掉 sysctl_tcp_thin_linear_timeouts,要么用 BBR 算法(BBR 不更新 ssthresh,tcp_stream_is_thin 恒为 false,钻了个空子)。

但真要打开 sysctl_tcp_thin_linear_timeouts 呢?so?我觉得这是 Linux kernel TCP 的 BUG!诚然,srtt,rttvar 为 0 无可厚非,采不到就为 0,可 rto 为 0 没有任何现实意义。

很简单的拍脑袋:

- icsk->icsk_rto = min(__tcp_set_rto(tp), TCP_RTO_MAX);
+ icsk->icsk_rto = min(max(__tcp_set_rto(tp), 1), TCP_RTO_MAX);

谁有空给 Linux kernel 社区提个 patch?反正我对社区鄙视且没兴趣(所有内卷的领域都没兴趣,包括全民发烧)。

Linux kernel 社区,这可是大好的秀场,方便后面找工作吹逼。

浙江温州皮鞋湿,下雨进水不会胖。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值