TCP拥塞控制机制之慢启动

2023-11-22 13:10

本文主要是介绍TCP拥塞控制机制之慢启动,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

什么是慢启动

最初的TCP的实现方式是,在连接建立成功后便会向网络中发送大尺寸的数据包,假如网络出现问题,很多这样的大包会积攒在路由器上,很容易导致网络中路由器缓存空间耗尽,从而发生拥塞。因此现在的TCP协议规定了,新建立的连接不能够一开始就发送大尺寸的数据包,而只能从一个小尺寸的包开始发送,在发送和数据被对方确认的过程中去计算对方的接收速度,来逐步增加每次发送的数据量(最后到达一个稳定的值,进入高速传输阶段。相应的,慢启动过程中,TCP通道处在低速传输阶段),以避免上述现象的发生。这个策略就是慢启动。
æ¥å¡çªå£å¤§å°å¢é¿ç¤ºæå¾

慢启动导致客户端与服务器之间经过几百毫秒才能达到接近最大速度的问题,对于大型流式下载服务的影响倒不显著,因为慢启动的时间可以分摊到整个传输周期内消化掉。可是,对于很多HTTP连接,特别是一些短暂、突发的连接而言,常常会出现还没有达到最大窗口请求就被终止的情况。换句话说,很多Web应用的性能经常受到服务器与客户端之间往返时间的制约。因为慢启动限制了可用的吞吐量,而这对于小文件传输非常不利。慢启动重启除了调节新连接的传输速度,TCP还实现了SSR(Slow-StartRestart,慢启动重启)机制。

这种机制会在连接空闲一定时间后重置连接的拥塞窗口。道理很简单,在连接空闲的同时,网络状况也可能发生了变化,为了避免拥塞,理应将拥塞窗口重置回“安全的”默认值。毫无疑问,SSR对于那些会出现突发空闲的长周期TCP连接(比如HTTP的keep-alive连接)有很大的影响。因此,我们建议在服务器上禁用SSR。在Linux平台,可以通过如下命令来检查和禁用SSR:

$>sysctlnet.ipv4.tcp_slow_start_after_idle
$>sysctl-wnet.ipv4.tcp_slow_start_after_idle=0

为演示三次握手和慢启动对简单HTTP传输的影响,我们假设纽约的客户端需要通过TCP连接向伦敦的服务器请求一个20KB的文件,下面列出了连接的参数。

通过新TCP连接取得文件

•往返时间:56ms。

•客户端到服务器的带宽:5Mbit/s。

•客户端和服务器接收窗口:65535字节。

•初始的拥塞窗口:4段(4×1460字节≈5.7KB)。

•服务器生成响应的处理时间:40ms。

•没有分组丢失、每个分组都要确认、GET请求只占1段。

•0ms:客户端发送SYN分组开始TCP握手。

•28ms:服务器响应SYN-ACK并指定其rwnd大小。

•56ms:客户端确认SYN-ACK,指定其rwnd大小,并立即发送HTTPGET请求。

•84ms:服务器收到HTTP请求。

•124ms:服务器生成20KB的响应,并发送4个TCP段(初始cwnd大小为4),然后等待ACK。

•152ms:客户端收到4个段,并分别发送ACK确认。

•180ms:服务器针对每个ACK递增cwnd,然后发送8个TCP段。

•208ms:客户端接收8个段,并分别发送ACK确认。

•236ms:服务器针对每个ACK递增cwnd,然后发送剩余的TCP段。

•264ms:客户端收到剩余的TCP段,并分别发送ACK确认。

大家可以练习一下,如果将cwnd值设置为10个TCP段,那么图2-5所示的过程将减少一次往返,性能可以提升22%!通过新TCP连接在往返时间为56ms的客户端与服务器间传输一个20KB的文件需要264ms!作为对比,现在假设客户端可以重用同一个TCP连接(图2-6),再发送一次相同的请求。

•0ms:客户端发送HTTP请求。

•28ms:服务器收到HTTP请求。

•68ms:服务器生成20KB响应,但cwnd已经大于发送文件所需的15段了,因此一次性发送所有数据段。

•96ms:客户端收到所有15个段,分别发送ACK确认。

同一个连接、同样的请求,但没有三次握手和慢启动,只花了96ms,性能提升幅度达275%!

以上两种情况下,服务器和客户端之间的5Mbit/s带宽并不影响TCP连接的启动阶段。此时,延迟和拥塞窗口大小才是限制因素。事实上,如果增大往返时间,第一次和第二次请求的性能差距只会加大。大家可以练习一下,试试不同的往返时间会有什么结果。理解了TCP拥塞控制机制后,针对keep-alive、流水线和多路复用的优化就简单得多了。

增大TCP的初始拥塞窗口。把服务器的初始cwnd值增大到RFC6928新规定的10段(IW10),是提升用户体验以及所有TCP应用性能的最简单方式。好消息是,很多操作系统已经更新了内核,采用了增大后的值。可以留意相应的文档和发布说明。在Linux上,IW10是2.6.39以上版本内核的新默认值。但不要就此满足,升级到3.2以上版本还有其他重要更新。

典型案例:

问题描述:

hbase主备集群之间增量同步,主集群在上海,备集群在张北,服务器均为万兆网卡,且带宽没有达到上限;长途带宽为专线,带宽足够,不会成为瓶颈。跨长途带宽复制数据,由于数据量较大,总是有延迟。

解决方法:

将内核参数从1调整到0,禁用慢启动:

sysctl-w net.ipv4.tcp_slow_start_after_idle=0

 

这篇关于TCP拥塞控制机制之慢启动的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/410376

相关文章

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

基于Redis自动过期的流处理暂停机制

《基于Redis自动过期的流处理暂停机制》基于Redis自动过期的流处理暂停机制是一种高效、可靠且易于实现的解决方案,防止延时过大的数据影响实时处理自动恢复处理,以避免积压的数据影响实时性,下面就来详... 目录核心思路代码实现1. 初始化Redis连接和键前缀2. 接收数据时检查暂停状态3. 检测到延时过

SpringBoot通过main方法启动web项目实践

《SpringBoot通过main方法启动web项目实践》SpringBoot通过SpringApplication.run()启动Web项目,自动推断应用类型,加载初始化器与监听器,配置Spring... 目录1. 启动入口:SpringApplication.run()2. SpringApplicat

Redis中哨兵机制和集群的区别及说明

《Redis中哨兵机制和集群的区别及说明》Redis哨兵通过主从复制实现高可用,适用于中小规模数据;集群采用分布式分片,支持动态扩展,适合大规模数据,哨兵管理简单但扩展性弱,集群性能更强但架构复杂,根... 目录一、架构设计与节点角色1. 哨兵机制(Sentinel)2. 集群(Cluster)二、数据分片

解决Nginx启动报错Job for nginx.service failed because the control process exited with error code问题

《解决Nginx启动报错Jobfornginx.servicefailedbecausethecontrolprocessexitedwitherrorcode问题》Nginx启... 目录一、报错如下二、解决原因三、解决方式总结一、报错如下Job for nginx.service failed bec

Spring Boot项目如何使用外部application.yml配置文件启动JAR包

《SpringBoot项目如何使用外部application.yml配置文件启动JAR包》文章介绍了SpringBoot项目通过指定外部application.yml配置文件启动JAR包的方法,包括... 目录Spring Boot项目中使用外部application.yml配置文件启动JAR包一、基本原理

解决若依微服务框架启动报错的问题

《解决若依微服务框架启动报错的问题》Invalidboundstatement错误通常由MyBatis映射文件未正确加载或Nacos配置未读取导致,需检查XML的namespace与方法ID是否匹配,... 目录ruoyi-system模块报错报错详情nacos文件目录总结ruoyi-systnGLNYpe

深入理解go中interface机制

《深入理解go中interface机制》本文主要介绍了深入理解go中interface机制,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录前言interface使用类型判断总结前言go的interface是一组method的集合,不

Linux之UDP和TCP报头管理方式

《Linux之UDP和TCP报头管理方式》文章系统讲解了传输层协议UDP与TCP的核心区别:UDP无连接、不可靠,适合实时传输(如视频),通过端口号标识应用;TCP有连接、可靠,通过确认应答、序号、窗... 目录一、关于端口号1.1 端口号的理解1.2 端口号范围的划分1.3 认识知名端口号1.4 一个进程

解决hive启动时java.net.ConnectException:拒绝连接的问题

《解决hive启动时java.net.ConnectException:拒绝连接的问题》Hadoop集群连接被拒,需检查集群是否启动、关闭防火墙/SELinux、确认安全模式退出,若问题仍存,查看日志... 目录错误发生原因解决方式1.关闭防火墙2.关闭selinux3.启动集群4.检查集群是否正常启动5.