Chinaunix首页 | 论坛 | 博客
  • 博客访问: 227488
  • 博文数量: 17
  • 博客积分: 1545
  • 博客等级: 上尉
  • 技术积分: 302
  • 用 户 组: 普通用户
  • 注册时间: 2009-02-12 21:59
文章分类
文章存档

2011年(8)

2010年(5)

2009年(4)

分类: LINUX

2010-08-15 10:40:08

首先,我申明一下俺不是这个据说有韩国背景的CDN公司的(好吧,我现在可以公开,就是同兴万点),所以分析他们的技术应该不存在法律问题。

本来是没有兴趣关心他们的,只是同事说他们服务效果很好,甚至比我们还好(后面证实这是个乌龙)。好吧,那就让我们看看他都做了啥。

note: 一下结果使用tcpdump抓的,ip我已经隐去了,只剩下端口
建立连接:

23:52:36.524988 IP 37043 > 80: S 3057031392:3057031392(0) win 5840
23:52:36.835004 IP 80 > 37043: S 4181496636:4181496636(0) ack 3057031393 win 64436 wscale 8>
23:52:36.835017 IP 37043 > 80: . ack 1 win 682
23:52:36.835050 IP 37043 > 80: P 1:156(155) ack 1 win 682
23:52:36.888571 IP 80 > 37043: S 4181496636:4181496636(0) ack 3057031393 win 64436
看上面带红色字体的这一行,算一算和第二行之间差了多少时间? 没错,肯定不是3s还有那个wscale 8,这也不是标准配置了。
继续往下看
23:52:37.143002 IP 80 > 37043: P 1:314(313) ack 156 win 5115
23:52:37.143006 IP 37043 > 80: . ack 314 win 680
23:52:37.143047 IP 80 >37043: . 314:1774(1460) ack 156 win 5115
23:52:37.143052 IP 37043 > 80: . ack 1774 win 668
23:52:37.143054 IP 80 > 37043: . 1774:3234(1460) ack 156 win 5115
23:52:37.143057 IP 37043 > 80: . ack 3234 win 657
23:52:37.143066 IP 80 > 37043: . 3234:4694(1460) ack 156 win 5115
23:52:37.143070 IP 37043 > 80: . ack 4694 win 645
23:52:37.442440 IP 80 > 37043: . 3234:4694(1460) ack 156 win 5115
23:52:37.442446 IP 37043 > 80: . ack 4694 win 645
注意一下那一行红色的,3234:4694 这个包是个重复包,是故意发的, 和上次收到的时间间隔差了300ms.
win 5115 *2的7次方,这个初始的接收窗口,也不是linux内核的标准了。
初始窗口是4,不是2

继续往下看,这一段抓包的记录好长,看官们要有点耐心。
23:52:37.449906 IP 80 > 37043: . 4694:6154(1460) ack 156 win 5115
23:52:37.449909 IP .37043 > .80: . ack 6154 win 634
23:52:37.450012 IP .80 > .37043: . 6154:7614(1460) ack 156 win 5115
23:52:37.450016 IP .37043 > .80: . ack 7614 win 623
23:52:37.450020 IP .80 > .37043: . 7614:9074(1460) ack 156 win 5115
23:52:37.450022 IP .37043 > .80: . ack 9074 win 611
23:52:37.450024 IP .80 > .37043: . 9074:10534(1460) ack 156 win 5115
23:52:37.450027 IP .80 > .37043: . 10534:11994(1460) ack 156 win 5115
23:52:37.450036 IP .37043 > .80: . ack 10534 win 600
23:52:37.450044 IP .37043 > .80: . ack 11994 win 588       

23:52:37.450130 IP 80 > .37043: . 13454:14914(1460) ack 156 win 5115                                     乱序丢包
23:52:37.450136 IP .37043 > .80: . ack 11994 win 588                第一个sack  第二个sack包是300ms后的事情
23:52:37.755710 IP .80 > .37043: . 14914:16374(1460) ack 156 win 5115
23:52:37.755715 IP .37043 > .80: . ack 11994 win 588
23:52:37.755744 IP .80 > .37043: . 16374:17834(1460) ack 156 win 5115
23:52:37.755748 IP .37043 > .80: . ack 11994 win 588
23:52:37.755811 IP .80 > .37043: . 17834:19294(1460) ack 156 win 5115
23:52:37.755815 IP .37043 > .80: . ack 11994 win 588
23:52:37.755876 IP .80 > .37043: . 19294:20754(1460) ack 156 win 5115
23:52:37.755880 IP .37043 > .80: . ack 11994 win 588
23:52:37.755939 IP .80 > .37043: . 20754:22214(1460) ack 156 win 5115
23:52:37.755943 IP .37043 > .80: . ack 11994 win 588
23:52:37.755945 IP .80 > .37043: . 22214:23674(1460) ack 156 win 5115
23:52:37.755947 IP .37043 > .80: . ack 11994 win 588
23:52:37.755951 IP .80 > .37043: . 23674:25134(1460) ack 156 win 5115
23:52:37.755953 IP .37043 > .80: . ack 11994 win 588
23:52:37.756000 IP .80 > .37043: . 25134:26594(1460) ack 156 win 5115
23:52:37.756003 IP .37043 > .80: . ack 11994 win 588
23:52:37.756004 IP .80 > .37043: . 26594:28054(1460) ack 156 win 5115
23:52:37.756006 IP .37043 > .80: . ack 11994 win 588
23:52:37.756008 IP .80 > .37043: . 28054:29514(1460) ack 156 win 5115
23:52:37.756010 IP .37043 > .80: . ack 11994 win 588
23:52:37.756093 IP .80 > .37043: . 29514:30974(1460) ack 156 win 5115
23:52:37.756097 IP .37043 > .80: . ack 11994 win 588

23:52:37.792829 IP 1.80 >.37043: . 11994:13454(1460) ack 156 win 5115     这是重传包  和第二个sack相差了只有几十ms,肯定不是被sack包触发的。
23:52:37.792836 IP .37043 > .80: . ack 30974 win 440

看完上面的注解以后,看我的结论, 重传不是被三个相同的ack触发的,而是在收到第一个sack以后的多少ms以后触发的,他们的时间和时延成正比关系。


最后做个总结:

初步来看他们做的改变有几个:
1  连接建立  :第一个syn包重传时间更短,只有50ms 。 后续的是3s  6s  。。。。。。。
 
2更大的读缓存和初始读缓存  ;

3更大的初始拥塞窗口 4
 
4在300ms内收不到任何包的情况下, 用发送的最后一个数据包;
 
5完全颠覆了传统的丢包判断策略:  传统的方法是3个重复的ack包   ,他们的策略是第一个重复的ack包后 RTT/n 时间后就认为包丢包,然后重传;         
 
6拥塞控制算法:  初步来看,  AIMD算法 ,AI  加性增还是加1   ,MD 乘性减大致在0.7-0.8左右;  









阅读(4622) | 评论(5) | 转发(0) |
给主人留下些什么吧!~~

goingstudy2017-11-30 10:11:32

如果他们用sack(或3 个重复的ack)来判断丢失的话,应该在17834:19294(1460)的aCK时就可以重传了吧?

goingstudy2017-11-30 10:06:13

请问怎么看出初始cwnd是4的?
还有13454:14914(1460) 这个包,在端口80端11994-13454 并没有看到,是因为丢包了没有被tcpdump抓到?要不是他们tcp协议栈的bug?

raise_sail2012-09-21 14:21:12

分析的很强大~

luoyan_xy2011-04-20 10:59:32

有几个问题没有搞明白: 1. 在给的例子中,看起来在开始的时候三次握手已经完成了,为什么还有重传的syn包 2. 在300ms收不到数据包就重传最后一个包的目的是什么? 3. 在他们的丢包判断策略中可以看到,重传丢失包的时候已经收到多于3此的重复ack,在这里重传丢失包的时间更靠后,目的是什么呢,是为了减少拥塞窗口的改变吗。。 谢谢。

sakura20012010-08-17 15:51:03

专家啊