簡(jiǎn)述: TCP是面向連接的安全的傳輸, 不會(huì)丟失數(shù)據(jù)(只是丟失之后會(huì)重新發(fā)送), TCP連接需要三次握手.
TCP通信數(shù)據(jù)段如圖:
TCP數(shù)據(jù)段.png
三次握手, 通信, 四次握手如圖:
TCP通信.png
- 三次握手: 1 - 3
(1) 首先client 給server發(fā)送連接請(qǐng)求, 對(duì)應(yīng)標(biāo)識(shí)位SYN, 隨機(jī)生成一個(gè)32位序號(hào):1000, 那么server應(yīng)答的時(shí)候ACK對(duì)應(yīng)的應(yīng)為1001 并帶有一個(gè)mss, mss表示最大段尺寸夏哭,如果一個(gè)段太大楷力,封裝成幀后超過(guò)了鏈路層的最大幀長(zhǎng)度通惫,就必須在IP層分片狐粱,為了避免這種情況蘸吓,客戶端聲明自己的最大段尺寸,建議服務(wù)器端發(fā)來(lái)的段不要超過(guò)這個(gè)長(zhǎng)度雄驹。
(2) 當(dāng)server收到client的連接請(qǐng)求時(shí), 先判斷SYN標(biāo)志位是否為1, 然后做出應(yīng)答, 對(duì)應(yīng)的應(yīng)答標(biāo)志位是ACK, 并以client端發(fā)送的SYN請(qǐng)求生成的32位序號(hào)+1作為應(yīng)答(ACK)的確認(rèn)序號(hào); 并且也向client發(fā)送連接請(qǐng)求(SYN), 也生成一個(gè)隨機(jī)32位序號(hào)8000, 表示server端向client發(fā)送的連接請(qǐng)求的序號(hào), 那么client應(yīng)答的時(shí)候ACK對(duì)應(yīng)的應(yīng)為8001.
(3) client收到server的應(yīng)答(ACK-1001), 和server的連接請(qǐng)求(SYN-8000)之后, 判斷ack是否為1, 序號(hào)是否是發(fā)過(guò)去的1000+1, 然后判斷syn是否為1, 然后需要對(duì)服務(wù)器的連接請(qǐng)求做應(yīng)答ACK, 對(duì)應(yīng)攜帶的確認(rèn)序號(hào)為8001.
此時(shí)建立連接 - 通信
(4) client向server發(fā)送數(shù)據(jù), 1001(20)表示發(fā)送數(shù)據(jù)是20字節(jié), 并且再確認(rèn)上次的回復(fù)8001(對(duì)應(yīng)的是server SYN生成的序號(hào)+1)
(5) server收到數(shù)據(jù)后做應(yīng)答, ACK 對(duì)應(yīng)的序號(hào)應(yīng)為1001+20, 表示server收到了20字節(jié), 并且向client發(fā)送數(shù)據(jù), 8001(10)表示發(fā)送數(shù)據(jù)是10字節(jié),
(6) client收到數(shù)據(jù)之后應(yīng)答ACK為8001+10, 表示收到了10字節(jié), 這時(shí)沒(méi)有再發(fā)數(shù)據(jù) - 四次握手 - 斷開(kāi)連接, 由于TCP連接是全雙工的愈诚,因此每個(gè)方向都必須單獨(dú)進(jìn)行關(guān)閉。這原則是當(dāng)一方完成它的數(shù)據(jù)發(fā)送任務(wù)后就能發(fā)送一個(gè)FIN來(lái)終止這個(gè)方向的連接阔挠。收到一個(gè) FIN只意味著這一方向上沒(méi)有數(shù)據(jù)流動(dòng)飘庄,一個(gè)TCP連接在收到一個(gè)FIN后仍能發(fā)送數(shù)據(jù)。首先進(jìn)行關(guān)閉的一方將執(zhí)行主動(dòng)關(guān)閉谒亦,而另一方執(zhí)行被動(dòng)關(guān)閉竭宰。
(7) client發(fā)出段7, 對(duì)應(yīng)標(biāo)識(shí)位:FIN, 表示關(guān)閉連接的請(qǐng)求, 對(duì)應(yīng)32位序號(hào)是server應(yīng)答client的ACK(1021), 發(fā)送0字節(jié)數(shù)據(jù), 并確認(rèn)上次收到10字節(jié)數(shù)據(jù), 對(duì)server的應(yīng)答ACK對(duì)應(yīng)確認(rèn)序號(hào)為8011.(此時(shí)為半關(guān)閉狀態(tài))
(8) 服務(wù)器發(fā)出段8,應(yīng)答客戶端的關(guān)閉連接請(qǐng)求份招。
(9) 緊接著服務(wù)器發(fā)出段9切揭,其中也包含F(xiàn)IN位,向客戶端發(fā)送關(guān)閉連接請(qǐng)求锁摔。
(10) 客戶端發(fā)出段10廓旬,應(yīng)答服務(wù)器的關(guān)閉連接請(qǐng)求。
建立連接的過(guò)程是三方握手,而關(guān)閉連接通常需要4個(gè)段孕豹,服務(wù)器的應(yīng)答和關(guān)閉連接請(qǐng)求通常不合并在一個(gè)段中涩盾,因?yàn)橛羞B接半關(guān)閉的情況,這種情況下客戶端關(guān)閉連接之后就不能再發(fā)送數(shù)據(jù)給服務(wù)器了励背,但是服務(wù)器還可以發(fā)送數(shù)據(jù)給客戶端春霍,直到服務(wù)器也關(guān)閉連接為止。