前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >计算机网络--重传时间计算

计算机网络--重传时间计算

作者头像
kif
发布2023-02-27 17:53:08
5850
发布2023-02-27 17:53:08
举报
文章被收录于专栏:kifroom

我们都知道,TCP发送方在规定时间内没有收到确认就要重传已发送的报文段(里面有一个超时计数器),这个逻辑很简单,但是这个超时计数器的值每次都是不一样的,也就是说:重传时间的选择是不一样的,它是如何确定的呢???

TCP下层是互联网环境,发送的报文段可能只经过一个高速率的局域网,也可能经过多个低速率的网络,并且每个IP数据报所选择的路由还可能不同。如果把超时重传时间设置太短,就会引起很多报文段的不必要的重传,使网络负荷增大。但若把超时重传时间设置的太长,那么网络空闲时间会增大,极大的降低了网络的效率

到底应该设置为多大呢????

TCP采用了一种自适应算法,它记录一个报文段发出的时间,以及收到相应的确认的时间。这两个时间之差就是报文段的往返时间RTT。TCP保留了RTT的一个加权平均往返时间RTTs(这又成为平滑的往返时间,S表示Smoothed。因为进行的是加权平均,因此获得的结果更加平滑,也就是让我们计算出的结果更加合理)。每回的第一次测量到RTT样本时,RTTs值就取为所测量到的RTT样本值,但以后每次测量到一个新的RTT样本,就按下面的公式重新计算一次RTTs:

image-20210622135042562
image-20210622135042562

在上式中:(阿尔法 的值介于0到1,若很接近0,则表示旧的RTTs值和新的RTTs值相比变化不大,也就是说,新的RTT样本不太影响RTTs; 若很接近1,则表明新的RTTs值,受当前采集的RTT样本影响较大,跟上次的RTTs差距大)

RFC 2988:推荐的阿尔法值为1/8,也就是0.125 (这种方式得出的值更为平滑)

显然:超时计数器设置的超时重传时间RTO(Retransmission Time-Out)应略大于上面计算的结果。同样的:

RFC  2988:建议使用下面的公式计算RTO:

image-20210622135115160
image-20210622135115160

RTTd是RTT的偏差的加权平均值,与RTTs和新的RTT样本之差有关。RFC 2988建议这样计算RTTd。当第一次测量时,RTTd值取为RTT样本值的一半。在以后的测量中,则使用下式计算加权平均RTTd:

image-20210622135139430
image-20210622135139430

这里的(贝塔)是一个小于1的系数,它的推荐值是1/4,即就是0。125

好了,通过上面这些东西:我们就可以求出超时计数器所要设置的时间问题了,但是,但是,但是,新的问题也来了????

发送一个报文段,设定的重传时间到了,还没有收到确认。于是重传报文段,经过一段时间后:收到了确认报文段。

现在的问题是:如何判定此报文段是对先发送的报文段的确认,还是对后来重传的报文段的确认???由于重传的报文段和原来的报文段完全一样,所以源主机在接受到确认后,无法做出正确的判断,而正确的判断对确定加权平均RTTs的值关系很大。

1,若收到的是对重传报文段的确认,但却被源主机当作是对原来报文段的确认,则计算出的RTTs和超时重传时间RTO就会偏大。若后面再发送的报文段又是经过重传后才收到的确认报文段,则RTO这个时间会越来越长。直接影响效率

2,若收到的是对原来的报文段的确认,但被当作是对重传报文段的确认,则由此计算出的RTTs和RTO都会偏小,这样就会导致过多的重传,使的RTO越来越小

根据以上所说:Karn提出了一个算法:在计算加权平均RTTs时,只要报文段重传了,就不采用其往返时间样本。这样得出的加权平均RTTs和RTO就相对比较准确了。

但是,但是,要是出现这样的情况呢??:报文段的时延突然增大了很多。因此在原来得出的重传时间内,不会收到确认报文段。于是就重传报文段。但根据Karn算法,不考虑重传的报文段的往返时间样本。这样:超时重传时间就无法更新。

因此:要对Karn算法进行修正:方法是:报文段每重传一次,就把超时冲传时间RTO增大一些。典型的做法是:取新的重传时间为2倍的旧的重传时间。当不再发生报文段的重传时,才根据上面给出公式计算超时重传时间。。。。

转自;https://blog.csdn.net/msdnwolaile/article/details/51227491

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021/06/22 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档