TCP为什么需要三次握手
生活随笔
收集整理的這篇文章主要介紹了
TCP为什么需要三次握手
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
tcp為什么要第三次握手,time_wait是做什么的??
tcp有幾種狀態(tài),畫出所有的狀態(tài)轉(zhuǎn)換圖。?
晚上看到的面試題,TCP三次握手的印象很深,但為什么需要3次握手,還是想不起來了。
簡(jiǎn)單而言:如果不是三次握手的話,那么到底需要幾次握手最佳呢?2次握手,或者4次以上的握手?
先看2次握手的情況:客戶端給服務(wù)器發(fā)送建立連接的請(qǐng)求,服務(wù)器同意連接請(qǐng)求發(fā)回應(yīng)給客戶端,連接就此建立。
有問題的就是網(wǎng)絡(luò)中經(jīng)常會(huì)出現(xiàn)的包的延遲,如果客戶端的某個(gè)包在路由器上延遲了,過了很久才發(fā)給服務(wù)器,服務(wù)器收到這個(gè)包后回應(yīng)給客戶端,服務(wù)器以為連接就此建立成功,分配資源,這樣就會(huì)出現(xiàn)問題。
再看四次握手的情況:
①A發(fā)送SYN,
②B收到SYN后發(fā)送ACK+SYN
③A發(fā)送ACK
④B再發(fā)送ACK
實(shí)際上這樣的過程可以一直循環(huán)下去,其實(shí)3次握手已經(jīng)是能夠使雙方知道對(duì)方設(shè)備都是好用的最少次數(shù)。四次握手會(huì)浪費(fèi)資源。
綜上所述,TCP 3次握手最好。
下面是第二個(gè)問題:time_wait是做什么的?
假設(shè)客戶端發(fā)送的最后一個(gè)ACK丟失了,服務(wù)器會(huì)重發(fā)它發(fā)送的最后一個(gè)FIN,所以客戶端必須維持一個(gè)狀態(tài)信息,以便能夠重發(fā)ACK;如果不維持這種狀態(tài),客戶端在接收到FIN后將會(huì)響應(yīng)一個(gè)RST,服務(wù)器端接收到RST后會(huì)認(rèn)為這是一個(gè)錯(cuò)誤。如果TCP協(xié)議能夠正常完成必要的操作而終止雙方的數(shù)據(jù)流傳輸,就必須完全正確的傳輸四次握手的四個(gè)節(jié),不能有任何的丟失。這就是為什么socket在關(guān)閉后,仍然處于 TIME_WAIT狀態(tài),因?yàn)樗却员阒匕l(fā)ACK。
總結(jié)
以上是生活随笔為你收集整理的TCP为什么需要三次握手的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【Linux学习】epoll详解
- 下一篇: 慢慢聊Linux AIO