一.URG和PSH版本控制位
Tcp协议为了能保证正确有效的数据传输过程,诞生了六个版本控制位;
SYN : 表示连接请求
ACK : 表示确认
FIN : 表示关闭连接的请求
RST : 表示断开连接的有效时长
而今天我们主要来了解URG 和 PSH
1.URG推送位
URG(紧急位):设置为1时,首部中的紧急指针有效;为0时,紧急指针没有意义。
紧急数据的起始点=序号;
紧急数据的终止点=序号+紧急指针;
1)在紧急数据后面的数据为普通数据,需要按序缓存
2)窗口为0也可以发送紧急数据
3)紧急数据都处理完成后,tcp就告诉进程恢复到正常操作
2.PSH推送位
PSH(推位):当设置为1时,要求把数据尽快的交给应用层,不做处理。
1)PSH的数据=本报文数据+缓存区数据
2)PSH的方向->单方向(接收PSH报文的一端)
PSH强调的是尽快将数据交付给上层(协议),而不需要经过强迫数据交互(默认tcp/ip是将数据缓存到一定的上限,再将数据递交给上层,以提高网络性能).可见,该部分数据是需要复制到缓存中的
3.联系与区别
URG交付给进程的数据:只有紧急数据
PSH交付给进程的数据:缓冲区排好序的数据及当前报文中的数据
共同点:都是一种对数据的处理方式.只不过URG是处理在前端(收到数据后立马对真正意义上”数据”进行操作,所以说”紧急.而PSH是在处理的后端,告诉内核,不用等待”满了”再递交数据递交到上层。
二.TCP定时器
TCP 是提供可靠的传输层,它需要确保数据从另一端到另一端。但是数据和确认都可能会丢失,所以TCP 通过在发送时设置一个定时器来解决这个问题。如果当定时器溢出时还没收到确认,它就会默认这个数据丢失,则重传该数据。
常见的几种定时器:
1.重传计时器(Retransmission Timer)
当TCP发送报文段时,就创建这个特定报文段的重传计时器,若在计时器超时之前收到对报文段的确认,则撤销计时器;而若是在收到对特定报文段的确认之前计时器超时,则重传该报文,并把计时器复位。
重传时间=2*RTT(动态计算)
RTT=previous RTT*i + (1-i)*current RTT。
i的值通常取90%,即新的RTT是以前的RTT值的90%加上当前RTT值的10%.
2.坚持计时器(Persistent Timer)
坚持定时器是专门为0窗口通知而设立的。当TCP服务器收到了客户端的0滑动窗口报文的时候,就启动一个定时器来计时,并在定时器溢出的时候向客户端查询窗口是否已经增大,如果得到非零的窗口就重新开始发送数据,如果得到0窗口就再开一个新的定时器准备下一次查询。
3.保活计时器(Keeplive Timer)
每当服务器收到客户的信息,就将保活计时器复位,超时通常设置2小时,若服务器超过2小时还没有收到来自客户的信息,就发送探测报文段,若发送了10个探测报文段(每75秒发送一个)还没收到响应,则终止连接。
4.时间等待计时器(Time_Wait Timer)
在连接终止期使用,当TCP关闭连接时,并不认为这个连接就真正关闭了,在时间等待期间,连接还处于一种中间过渡状态。这样就可以使重复的fin报文段在到达终点后被丢弃,这个计时器的值通常设置为一格报文段寿命期望值的两倍。