1.TCP/IP簡介
TCP/IP協(xié)議源于1969年,是針對Internet開發(fā)的一種體系結構和協(xié)議標準,目的在于解決異種計算機網(wǎng)絡的通信問題。使得網(wǎng)絡在互聯(lián)時能為用戶提供一種通用、一致的通信服務。是Internet采用的協(xié)議標準。
TCP/IP是一組通信協(xié)議的代名詞,是由一系列協(xié)議組成的協(xié)議簇。它本身指兩個協(xié)議集:
TCP(傳輸控制協(xié)議)。
IP(互聯(lián)網(wǎng)絡協(xié)議)。
TCP/IP協(xié)議的基本傳輸單位是數(shù)據(jù)包(Datagram)。
TCP/IP傳輸協(xié)議,即傳輸控制/網(wǎng)絡協(xié)議,也叫作網(wǎng)絡通訊協(xié)議。它是在網(wǎng)絡的使用中的最基本的通信協(xié)議。TCP/IP傳輸協(xié)議對互聯(lián)網(wǎng)中各部分進行通信的標準和方法進行了規(guī)定。并且,TCP/IP傳輸協(xié)議是保證網(wǎng)絡數(shù)據(jù)信息及時、完整傳輸?shù)膬蓚€重要的協(xié)議。TCP/IP傳輸協(xié)議是嚴格來說是一個四層的體系結構,應用層、傳輸層、網(wǎng)絡層和數(shù)據(jù)鏈路層都包含其中。
2.TCP/IP協(xié)議分層模型
TCP/IP協(xié)議族是一組不同層次上的多個協(xié)議的組合。TCP/IP通常被認為是一個四層協(xié)議系統(tǒng)。
應用層(Application Layer)
包含各種網(wǎng)絡應用協(xié)議。如HTTP、FTP、telnet、SMTP、DNS、SNMP等。
傳輸層(Transport Layer)
負責在源主機和目的主機的應用程序間建立、管理和拆除可靠而又有效的端到端連接 。主要有TCP和UDP兩個傳輸協(xié)議。
網(wǎng)絡互聯(lián)層(Internet Layer)
負責將分組獨立地從信源傳送到信宿,主要解決路由選擇、擁塞控制和網(wǎng)絡互聯(lián)等問題。如最重要的協(xié)議——IP。
網(wǎng)絡接口層(Network Access Layer)
負責將IP分組封裝成適合在物理網(wǎng)絡上傳輸?shù)膸袷讲鬏?;或將從物理網(wǎng)絡接收到的幀解封,取出IP分組交給網(wǎng)絡互聯(lián)層。當前幾乎所有的物理網(wǎng)絡上都可運行TCP/IP協(xié)議。
3.傳輸控制協(xié)議TCP
TCP協(xié)議, 即傳輸控制協(xié)議,是一個可靠的、面向連接的協(xié)議。所謂連接,就是兩個對等實體為進行數(shù)據(jù)通信而進行的一種結合。面向連接服務是在數(shù)據(jù)交換之前,必須先建立連接。當數(shù)據(jù)交換結束后,則應終止這個連接。面向連接服務具有:連接建立、數(shù)據(jù)傳輸和連接釋放這三個階段。在傳送數(shù)據(jù)時是按序傳送的。
3.1 TCP數(shù)據(jù)格式
3.2 三次握手
第一次握手:
建立連接時,客戶端發(fā)送syn包(syn=j)到服務器,并進入SYN_SEND狀態(tài),等待服務器確認。
第二次握手:
服務器收到syn包,必須確認客戶的SYN(ack=j+1),同時自己也發(fā)送一個SYN包(syn=k),即SYN+ACK包,此時服務器進入SYN_RECV狀態(tài)。
第三次握手:
客戶端收到服務器的SYN+ACK包,向服務器發(fā)送確認包ACK(ack=k+1),此包發(fā)送完畢,客戶端和服務器進入ESTABLISHED狀態(tài),完成三次握手。
為什么握手是三次, 而不是兩次或者四次?
為了保證雙方都具備收發(fā)能力,則雙方都需要發(fā)送SYN和ACK,兩次握手則只能確一方具備收發(fā)能力;三次握手則可剛好可確定雙方都是可以進行收發(fā)的。
第一次握手是客戶端發(fā)送 SYN, 服務端接收, 服務端得出客戶端的發(fā)送能力和服務端的接收能力都正常;
第二次握手是服務端發(fā)送 SYN+ACK, 客戶端接收, 客戶端得出客戶端發(fā)送接收能力正常, 服務端發(fā)送接收能力也都正常, 但是此時服務器并不能確認客戶端的接收能力是否正常;
第三次握手客戶端發(fā)送 ACK, 服務器接收, 服務端才能得出客戶端發(fā)送接收能力正常,服務端自己發(fā)送接收能力也都正常。
3.3 四次揮手
TCP 一個特別的概念叫作半關閉, 這個概念是說, TCP 的連接是全雙工(可以同時發(fā)送和接收) 連接, 因此在關閉連接的時候, 必須關閉發(fā)送和接收兩個方向上的連接。
第一次揮手: 客戶端發(fā)出釋放 FIN=1, 自 己序列號 seq=u, 進入 FIN-WAIT-1 狀態(tài)。
第二次揮手: 服務器收到客戶端的后, 發(fā)出 ACK=1 確認標志和客戶端的確認號 ack=u+1,自己的序列號 seq=v, 進入 CLOSE-WAIT 狀態(tài)。
第三次揮手: 客戶端收到服務器確認結果后, 進入 FIN-WAIT-2 狀態(tài)。 此時服務器發(fā)送釋放 FIN=1 信號, 確認標志 ACK=1, 確認序號 ack=u+1, 自 己序號 seq=w, 服務器進入LAST-ACK(最后確認態(tài))。
第四次揮手: 客戶端收到回復后, 發(fā)送確認 ACK=1, ack=w+1, 自 己的 seq=u+1, 客戶端進入 TIME-WAIT(時間等待) 。 客戶端經(jīng)過 2 個最長報文段壽命后, 客戶端 CLOSE;服務器收到確認后, 立刻進入 CLOSE 狀態(tài)。
為么需要四次揮手
因為為在斷開連接時,服務器收到客戶端斷開請求時可能此時還沒有完成數(shù)據(jù)傳輸,所以需要先回復客戶端我收到你的請求了,等將數(shù)據(jù)傳輸完成后,再通知客戶開端可以斷開連接了,所以服務器需要將應答ack和FIN分兩次發(fā)送,因此需要四次揮手。
審核編輯 黃昊宇
-
Linux
+關注
關注
87文章
11213瀏覽量
208736 -
編程
+關注
關注
88文章
3573瀏覽量
93545 -
TCP
+關注
關注
8文章
1348瀏覽量
78935
發(fā)布評論請先 登錄
相關推薦
評論