Linux 2.6.16 TCP链接速度异常的问题分析

版权声明:本文由余子军原创文章,转载请注明出处: 
文章原文连接:https://www.qcloud.com/community/article/104html

来源:腾云阁 https://www.qcloud.com/communitylinux

 

发现访问公司某些业务时,速度很是不稳定,而且总体慢于竞争对手。分析认为SESU10母盘上内核TCP拥塞控制算法和Windows的Ack频率控制的策略存在不兼容状况。web

目前至少确认 2.6.16内核版本存在此问题;打TCP优化补丁或者更换Tlinux之后能够解决问题。算法

问题现象:

在体验网环境下测试:大文件下载的状况下,百度的下载速度平均在600KBPS,咱们的下载速度平均低于100Kbps;互娱Webgame状况下,TNT业务下载速度大约是DDT的25%。浏览器

这里是一个典型的下载速度曲线:服务器

咱们的服务器的曲线:(纵轴单位:包/s)
网络

百度的服务器下载的曲线:
工具

重现该问题的测试环境:测试

网络: 公司体验网,普通联通4M ADSL大数据

服务器:Linux64位服务器, 深圳机房。

服务器程序: Apache,nws(自研webserver)

客户端: Windows XP, Windows7,任意浏览器或者旋风(单线程下载)

测试工具:wireshark, httpwatch

测试链接:分别是自建CDN、百度下载、深圳DC+Apache

问题分析:

经过客户端抓包分析发现速度很慢的段有两个问题:

  1. 服务器端老是等到前面的数据包确认之后才发送第二个包

  2. Windows老是等到200ms左右才发送ACK确认。

对于Windows端的行为, 为了防止ACK过多致使网络压力,Ms TCP协议栈在每收到一个数据包时,启动一个200ms定时器,直到收到其余数据包或者定时器过时时才发送ACK包。

经过设置注册表选项 TcpAckFrequency 参数为1关闭 Ack delay之后,实验发现下载速度恢复正常,没法重现下载速度慢的问题。

To configure the max outstanding ACKs in Windows XP/2003/Vista/2008:

[HKEYLOCALMACHINE \SYSTEM \CurrentControlSet \Services \Tcpip \Parameters \Interfaces \{Adapter-id}]

TcpAckFrequency = 1 (Default=2, 1=Disables delayed ACK, 2-n = If n outstanding ACKs before timed interval, sent ACK)

由于没法强制用户经过修改注册表避免问题,而且竞争对手也没有看到相似问题,所以只能从linux端解决。

Linux这一端,首先怀疑和nagle算法有关系,在nws服务器上设置TCP_NODELAY之后仍然能够重现,能够排除Nagle算法的影响。 (实际上nws每次发送大数据包或者直接使用sendfile,不太会收到nagle算法影响) 其次Apache,nws均可以重现这个问题,比较怀疑操做系统自己有缺陷。

由于每次linux仅发送一个数据包,所以怀疑拥塞窗口的问题,推测问题以下:

初始状况下,客户端回复一个ACK时,拥塞窗口增大,每次发送多个数据包,所以刚开始能够有较快的传输速度;由于网络延时抖动或丢包致使服务器协议栈断定数据包超时,重置拥塞窗口为1,每次仅发送一个数据包,收到客户端200ms回包,时仍然认为超时,同时调整RTT;直到RTT增大到200ms不算超时为止,拥塞窗口得以扩大,能够发送多个数据包,传输速度增快,如此循环。

经过测试增大初始拥塞窗口为10 (更换内核加载架平新技术组的TCP优化模块实现),下载速度恢复正常。

附旋风测试选项:

参考:
http://smallvoid.com/article/winnt-nagle-algorithm.html
http://support.microsoft.com/kb/214397/en-us

相关文章
相关标签/搜索