如何通过芝加哥和伦敦之间的100 mbps链路加速我的Windows 7 tcp文件传输?
现在,我在两个sftp会话中传输两个4GB文件。 每个文件传输以500 KB / s(4 Mbits / sec)的速度运行。 (B ==字节,b ==位,自然)。 这很慢,因为iperftesting显示单个TCPstream的速率为16.8 Mbits / sec。 这是2 MB /秒。
开始第二个sftp会话不会影响第一个iota的速度。 这对我来说是有意义的,因为我注意到我的iperftesting在TCP下是有限的,每个连接都是16 Mbps,为了更多的连接而留下空间。 我能够通过运行许多并行连接来使iperf饱和我的线路,并且这是带宽的线性增长。 也就是说,通过5个并行连接,我实现了大约5×16 == 80 Mbps的带宽。
我注意到使用sftp的本地文件传输大约是30 MB / s …相当好。 所以我不认为SSH通道encryption是瓶颈。
我已经回顾了通过高速,高延迟的广域网链路传输单个大文件的最佳方式是什么? 以及其他服务器故障的问题,还有很多有趣的工具,但我正在寻找的是一种方式来调整Windows的TCP堆栈,以确保我至less得到我的全部2 MB …也许更多,因为iPerftesting是跨越未经调整的机器。
我也注意到,当我从芝加哥的文件服务器上把一个文件拖放到伦敦机器上时,它似乎在一个相当好的剪辑中传输(如在传输期间查看细节所示),但几分钟后它从悬崖下降到Kbps的10。 这很奇怪。
我的延迟时间稳定在88毫秒左右,所以我认为networking基础设施是好的。 我们有专线; 这不是互联网上的VPN或类似的东西。
========
我有一个Linux虚拟机,“靠近”我的Windows桌面,networking方面。 也就是说,他们在不同的子网上,但是两台机器都进入了交换机,这两台交换机都进入了另一台到伦敦的交换机。 现在我运行一个从Linux到伦敦的sftp,运行速度为8 MB / s,而我的桌面以500 KB / s的速度运行。
========好吧,我将我的Linux笔记本电脑放在与我的桌面完全相同的交换机上。 在这个时候桌面正以500KB / s的速度执行sftp的时候,Linux笔记本正在以7.6MB / s的速度发送4Gig文件。 当然,在伦敦的同一台服务器上。
========另一个testing:我使用的是VanDyke公司的SecureFX。我的PC上也有Cygwin,我只是去了那里使用了CLI sftp命令。 我只是增加了我的吞吐量的五倍…我现在得到2.5 MB / s而不是500k! : – \这与我的iPerf 16 Mbps的结果相同。 我会满意的…虽然现在我注意到,我的笔记本电脑是三倍的速度。
========另一个testing:在我的伦敦机器上,我从芝加哥的文件服务器启动了Windows资源pipe理器文件复制到本地安装的Downloads文件夹(即在内部硬盘上)。 吞吐量在12分钟左右稳定在5.49 MB / s。 这足够接近我的罚款! 而且,通过SecureCRT进行复制的速度非常慢,稳定在500 KB / s。
我唯一可以得出结论的是,虽然可能会有TCP调整,将有所帮助,你使用的应用程序可以有很大的不同! 此外,我不知道为什么我的文件拷贝前一天performance得如此奇怪。 如果再次发生,我会尝试debugging。
感谢您的build议和答复。
======================
好的,我遵循了托德·威尔科克斯(Todd Wilcox)的链接,想到了一些事情:
netsh
将接收窗口自动调节级别从正常更改为禁用。 我的networking传输速度没有改变,所以我重新启动了我的机器,并再次执行从我的桌面到伦敦服务器的SFTP。 每秒比特带宽*往返延迟时间(秒)= TCP窗口大小(以位为单位)/ 8 = TCP窗口大小(以字节为单位)
在你的情况下: 100 000 000 * .088 = 8 800 000位或1 100 000字节
这可以在TcpWindowSize键的Windowsregistry中在0-0x3FFFFFFF(1 073 741 823 decimal)的有效范围内进行configuration,以便该数字位于有效范围内。
默认值是以下值中的最小值(注意:“ 仅当连接到支持RFC 1323窗口缩放的其他系统时,才能实现大于64 KB的值 ”):
- 为0xFFFF
- GlobalMaxTcpWindowSize(另一个registry参数)
- MSS(最大段大小)的四倍中的较大者
- 16384四舍五入到MSS的偶数倍
该堆栈还根据媒体速度自行调整:
- 低于1 Mbps:8 KB
- 1 Mbps – 100 Mbps:17 KB
- 大于100 Mbps:64 KB
来源 (这个链接现在大部分已经死了 – 稍微活着,但只有一个奇迹才能把它带回来)
另见: http : //bradhedlund.com/2008/12/19/how-to-calculate-tcp-throughput-for-long-distance-links/
和: https : //technet.microsoft.com/en-us/library/cc938219.aspx