Linux - 网络子系统 - ss的三种tcp速率解析
一. send_bps根据RTT和拥塞窗口计算的发送速率,可能实际速率小于此值。例如,当由于TSQ等机制导致发送延迟,而占不满拥塞窗口。tcp_input.c - net/ipv4/tcp_input.c - Linux source code (v5.17.1) - Bootlins.send_bps = (double) info->tcpi_snd_cwnd * (double)inf
·
一. send_bps
- 根据RTT和拥塞窗口计算的发送速率,可能实际速率小于此值。例如,当由于Pacing check(BBR或者SO_MAX_PACING_RATE),接收窗口限制, TSQ限制 等机制导致发送延迟,而占不满拥塞窗口。
- tcp_input.c - net/ipv4/tcp_input.c - Linux source code (v5.17.1) - Bootlin
- s.send_bps = (double) info->tcpi_snd_cwnd * (double)info->tcpi_snd_mss * 8000000. / rtt;
- ==》info->tcpi_snd_cwnd = tp->snd_cwnd,info->tcpi_snd_mss = tp->mss_cache,info->tcpi_rtt = tp->srtt_us >> 3;
二. pacing_rate
-
表示tcp层的pacing速率,会用于TSQ中,来达到速率控制。
-
tcp_input.c - net/ipv4/tcp_input.c - Linux source code (v5.17.1) - Bootlin
- s.pacing_rate = info->tcpi_pacing_rate * 8.;
- info->tcpi_pacing_rate = READ_ONCE(sk->sk_pacing_rate);
- sk->sk_pacing_rate = (mss * cwnd / srtt) * sysctl_tcp_pacing_ss_ratio or sysctl_tcp_pacing_ca_ratio
- tcp_ack() -> tcp_cong_control() -> tcp_update_pacing_rate()
- s.pacing_rate_max = info->tcpi_max_pacing_rate * 8.;
- info->tcpi_max_pacing_rate = READ_ONCE(sk->sk_max_pacing_rate);
三. delivery_rate
- tcp_rate_gen()中采样来计算实际tcp的发送速率,会计算实际ack的速率。
- tcp_rate.c - net/ipv4/tcp_rate.c - Linux source code (v5.17.1) - Bootlin
- s.delivery_rate = info->tcpi_delivery_rate * 8;
- info->tcpi_delivery_rate = tcp_compute_delivery_rate(tp);
- tcp_ack() -> tcp_rate_gen()
- BBR拥塞算法会用到。
-----------------tcp delivery rate --------------------------------------------------------------
大概的方式就是在发送数据包A的CB控制块中记录最近被接收的数据包的ack时间和发送时间,然后数据包A被ack时计算各个时间。
带宽取值为计算得出的数据传输速率与接收ACK速率两者之间的较小值。通常情况下,传输速率(send_rate-发送并得到确认的数据速率)将大于ACK接收速率(ack_rate),但是,在面对ACK压缩等的情况下,将导致ACK接收速率意外的增大,此时,带宽应选取传输速率(send_rate)。
send_rate = #pkts_delivered/(last_snd_time - first_snd_time)
ack_rate = #pkts_delivered/(last_ack_time - first_ack_time)
bw = min(send_rate, ack_rate)
更多推荐
已为社区贡献6条内容
所有评论(0)