本文共 771 字,大约阅读时间需要 2 分钟。
主动发起断开连接的一方调用close()函数发送FIN并进入FIN WAIT 1状态,当收到对面反馈的ack之后会进入FIN WAIT2状态。之后收到对面发来的FIN并返回ACK之后会进入time wait状态。
进入time wait状态之后,socket pair处于不可用状态。需要等待time out那么长的时间之后,处于time wait状态的一方才会进入close状态。
设置了这一段时间,就不会出现跟下一次连接之间有任何数据的混淆。
主动发起关闭的一方在接受到对方发送的fin之后,会进入time wait的状态。因为每一个tcp都需要选择一个报文的最大生存时间。因为数据包会在网络上一定的存活时间,这个存活时间在ip包头有一个8位生存时间(TTL)。Time wait就是确保我发送的数据包要么就是到达了目的地,要么就是超过了生存时间之后被抛弃。他是做这个保证的。这个时间一般是两分钟,这个时间可以修改,一般我们设置为30s。单次的ttl不足以完成这个time wait时间,因为加入最后在生存时间的最后一刻到达了目的端,则目的端会返回一个确认,这个确认也需要一定的时间,所以tim wait的时间一般是两倍的ttl时间。
虽然客户端和服务器都可以进入time wait状态,但是最好服务器不要进入这样的状态
原因一:资源占用
Socket进入time wait状态时候,操作系统会分配一定的资源去捕捉这个状态,也就是说这个资源还不能被释放,还处于time wait的状态。
原因二:会使得服务器无法使用
假如消息是通过代理服务器获得的,比如vpn,如果这样,很多计算机发出来的消息,是通过一台机器发生中转的。如果服务器发起断开连接,会有大量的端口进入time wait状态,有可能会造成代理服务器无法使用。
转载地址:http://nowux.baihongyu.com/