创建TCP须要三次握手才能创建,而断开链接则须要四次握手。整个过程以下图所示:服务器
先来看看如何创建链接的。网络
首先Client端发送链接请求报文,Server段接受链接后回复ACK报文,并为此次链接分配资源。Client端接收到ACK报文后也向Server段发生ACK报文,并分配资源,这样TCP链接就创建了。ide
那如何断开链接呢?简单的过程以下:spa
【注意】中断链接端能够是Client端,也能够是Server端。orm
假设Client端发起中断链接请求,也就是发送FIN报文。Server端接到FIN报文后,意思是说"我Client端没有数据要发给你了",可是若是你还有数据没有发送完成,则没必要急着关闭Socket,能够继续发送数据。因此你先发送ACK,"告诉Client端,你的请求我收到了,可是我还没准备好,请继续你等个人消息"。这个时候Client端就进入FIN_WAIT状态,继续等待Server端的FIN报文。当Server端肯定数据已发送完成,则向Client端发送FIN报文,"告诉Client端,好了,我这边数据发完了,准备好关闭链接了"。Client端收到FIN报文后,"就知道能够关闭链接了,可是他仍是不相信网络,怕Server端不知道要关闭,因此发送ACK后进入TIME_WAIT状态,若是Server端没有收到ACK则能够重传。“,Server端收到ACK后,"就知道能够断开链接了"。Client端等待了2MSL后依然没有收到回复,则证实Server端已正常关闭,那好,我Client端也能够关闭链接了。Ok,TCP链接就这样关闭了!资源
整个过程Client端所经历的状态以下:同步
而Server端所经历的过程以下it
【注意】 在TIME_WAIT状态中,若是TCP client端最后一次发送的ACK丢失了,它将从新发送。TIME_WAIT状态中所须要的时间是依赖于实现方法的。典型的值为30秒、1分钟和2分钟。等待以后链接正式关闭,而且全部的资源(包括端口号)都被释放。io
【问题1】为何链接的时候是三次握手,关闭的时候倒是四次握手?
答:由于当Server端收到Client端的SYN链接请求报文后,能够直接发送SYN+ACK报文。其中ACK报文是用来应答的,SYN报文是用来同步的。可是关闭链接时,当Server端收到FIN报文时,极可能并不会当即关闭SOCKET,因此只能先回复一个ACK报文,告诉Client端,"你发的FIN报文我收到了"。只有等到我Server端全部的报文都发送完了,我才能发送FIN报文,所以不能一块儿发送。故须要四步握手。class
【问题2】为何TIME_WAIT状态须要通过2MSL(最大报文段生存时间)才能返回到CLOSE状态?
答:虽然按道理,四个报文都发送完毕,咱们能够直接进入CLOSE状态了,可是咱们必须假象网络是不可靠的,有能够最后一个ACK丢失。因此TIME_WAIT状态就是用来重发可能丢失的ACK报文。
TCP 的三次握手过程?为何会采用三次握手,若采用二次握手能够吗?
创建链接的过程是利用客户服务器模式,假设主机 A 为客户端,主机 B 为服务器端。
1 ) TCP 的三次握手过程:主机 A 向 B 发送链接请求;主机 B 对收到的主机 A 的报文段进行确认;主机 A 再次对主机 B 的确认进行确认。
2 )采用三次握手是:为了防止失效的链接请求报文段忽然又传送到主机 B ,于是产生错误。
失效的链接请求报文段是指:主机 A 发出的链接请求没有收到主机 B 的确认,因而通过一段时间后,主机 A 又从新向主机 B 发送链接请求,且创建成功,顺序完成数据传输。考虑这样一种特殊状况,主机 A 第一次发送的链接请求并无丢失,而是由于网络节点致使延迟达到主机 B ,主机 B 觉得是主机 A 又发起的新链接,因而主机 B 赞成链接,并向主机 A 发回确认,可是此时主机 A 根本不会理会,主机 B 就一直在等待主机 A 发送数据,致使主机 B 的资源浪费