TCP是可靠的传输层协议,但这并不意味着一端发送的数据一定可以到达另一端,因为传输过程中遇到的情况是不可控的,很有可能就有某些数据发生丢失,所以”可靠”其实并不可靠。
不过毕竟现如今的网络设备还算完善,传输过程中由于硬件错误导致数据丢失的情况基本可以忽略,那么,数据丢失的原因就只能是:传输路径过于拥堵,导致某些路由器或链路缓冲区无法再容纳多余数据,那么对于新来的数据包就只能丢掉。
为了解决这一问题,保证就算传输过程中遇到再多麻烦,也尽量使数据可以顺利到达对端,TCP引入拥塞控制用于缓解网络中的拥堵情况,同时采用超时重传机制解决数据的丢失问题
超时重传机制
超时重传机制主要是为了解决数据包在传输过程中丢失的问题,在上一篇关于TCP流量控制的介绍中已经简单接触过超时重传的概念。TCP每发送一个报文段,就会为这个报文段开启一个定时器,如果定时器溢出时仍然没有收到接收端的应答报文,那么TCP就认为这个报文段在传输过程中丢失,然后重新发送这个报文段。这便是超时重传机制
以<TCP/IP详解>中的例子为例,通过tcpdump抓包分析观察TCP的重传
首先和远方的某个服务器进行连接,发送一些数据以确认连接正常,随后拔掉本机以太网电缆,发送另一条数据
tcpdump的输出结果为
可以看到,前三行表示TCP的三次握手,四五行分别表示发送的”hello world”报文段以及应答报文段,随后的若干行表示TCP多次尝试重新发送”and hi”报文段,最后一行发送复位报文段,终止连接
本质上就是当第一次发送”and hi”报文段时启动了定时器,然而在规定的时间内没有收到对端的回复,所以重新发送”and hi”报文段,并重启定时器(重启的定时器时间会增大)
拥塞控制
超时重传是为了