1. 程式人生 > >計網--TCP三揮四握&TCP與UDP的區別

計網--TCP三揮四握&TCP與UDP的區別

TCP協議與UDP協議的區別
    首先咱們弄清楚,TCP協議和UCP協議與TCP/IP協議的聯絡,很多人犯糊塗了,一直都是說TCP/IP協議與UDP協議的區別,我覺得這是沒有從本質上弄清楚網路通訊!
TCP/IP協議是一個協議簇。裡面包括很多協議的。UDP只是其中的一個。之所以命名為TCP/IP協議,因為TCP,IP協議是兩個很重要的協議,就用他兩命名了。
TCP/IP協議集包括應用層,傳輸層,網路層,網路訪問層。
其中應用層包括:
超文字傳輸協議(HTTP):全球資訊網的基本協議.   
檔案傳輸(TFTP簡單檔案傳輸協議):   
遠端登入(Telnet),提供遠端訪問其它主機功能,它允許使用者登入     
internet主機,並在這臺主機上執行命令.    
網路管理(SNMP簡單網路管理協議),該協議提供了監控網路裝置的方法,以及配置管理,統計資訊收集,效能管理及安全管理等.   
域名系統(DNS),該系統用於在internet中將域名及其公共廣播的網路節點轉換成IP地址. 
其次網路層包括:    
Internet協議(IP)     
Internet控制資訊協議(ICMP)    
地址解析協議(ARP)    
反向地址解析協議(RARP)  
最後說網路訪問層:網路訪問層又稱作主機到網路層(host-to-network).網路訪問層的功能包括IP地址與實體地址硬體的對映,以及將IP封裝成幀.基於不同硬體型別的網路介面,網路訪問層定義了和物理介質的連線.
當然我這裡說得不夠完善,TCP/IP協議本來就是一門學問,每一個分支都是一個很複雜的流程,但我相信每位學習軟體開發的同學都有必要去仔細瞭解一番。
下面我著重講解一下TCP協議和UDP協議的區別。
TCP(Transmission Control Protocol,傳輸控制協議)是面向連線的協議,也就是說,在收發資料前,必須和對方建立可靠的連線。一個TCP連線必須要經過三次“對話”才能建立起來,其中的過程非常複雜,只簡單的描述下這三次對話的簡單過程:主機A向主機B發出連線請求資料包:“我想給你發資料,可以嗎?”,這是第一次對話;主機B向主機A傳送同意連線和要求同步(同步就是兩臺主機一個在傳送,一個在接收,協調工作)的資料包:“可以,你什麼時候發?”,這是第二次對話;主機A再發出一個數據包確認主機B的要求同步:“我現在就發,你接著吧!”,這是第三次對話。三次“對話”的目的是使資料包的傳送和接收同步,經過三次“對話”之後,主機A才向主機B正式傳送資料。
詳細點說就是:(文章部分轉載http://zhangjiangxing-gmail-com.iteye.com,主要是這個人講解得很到位,的確很容易使人理解!)
TCP三次握手過程
1 主機A通過向主機B 傳送一個含有同步序列號的標誌位的資料段給主機B ,向主機B 請求建立連線,通過這個資料段,
主機A告訴主機B 兩件事:我想要和你通訊;你可以用哪個序列號作為起始資料段來回應我.
2 主機B 收到主機A的請求後,用一個帶有確認應答(ACK)和同步序列號(SYN)標誌位的資料段響應主機A,也告訴主機A兩件事:
我已經收到你的請求了,你可以傳輸資料了;你要用哪佧序列號作為起始資料段來回應我
3 主機A收到這個資料段後,再發送一個確認應答,確認已收到主機B 的資料段:"我已收到回覆,我現在要開始傳輸實際資料了
這樣3次握手就完成了,主機A和主機B 就可以傳輸資料了.
3次握手的特點
沒有應用層的資料
SYN這個標誌位只有在TCP建產連線時才會被置1
握手完成後SYN標誌位被置0


TCP建立連線要進行3次握手,而斷開連線要進行4次


1 當主機A完成資料傳輸後,將控制位FIN置1,提出停止TCP連線的請求
2  主機B收到FIN後對其作出響應,確認這一方向上的TCP連線將關閉,將ACK置1
3 由B 端再提出反方向的關閉請求,將FIN置1
4 主機A對主機B的請求進行確認,將ACK置1,雙方向的關閉結束.
由TCP的三次握手和四次斷開可以看出,TCP使用面向連線的通訊方式,大大提高了資料通訊的可靠性,使傳送資料端
和接收端在資料正式傳輸前就有了互動,為資料正式傳輸打下了可靠的基礎
名詞解釋
ACK  TCP報頭的控制位之一,對資料進行確認.確認由目的端發出,用它來告訴傳送端這個序列號之前的資料段
都收到了.比如,確認號為X,則表示前X-1個數據段都收到了,只有當ACK=1時,確認號才有效,當ACK=0時,確認號無效,這時會要求重傳資料,保證資料的完整性.
SYN  同步序列號,TCP建立連線時將這個位置1
FIN  傳送端完成傳送任務位,當TCP完成資料傳輸需要斷開時,提出斷開連線的一方將這位置1
TCP的包頭結構:
源埠 16位
目標埠 16位
序列號 32位
迴應序號 32位
TCP頭長度 4位
reserved 6位
控制程式碼 6位
視窗大小 16位
偏移量 16位
校驗和 16位
選項  32位(可選)
這樣我們得出了TCP包頭的最小長度,為20位元組。


UDP(User Data Protocol,使用者資料報協議)
(1) UDP是一個非連線的協議,傳輸資料之前源端和終端不建立連線,當它想傳送時就簡單地去抓取來自應用程式的資料,並儘可能快地把它扔到網路上。在傳送端,UDP傳送資料的速度僅僅是受應用程式生成資料的速度、計算機的能力和傳輸頻寬的限制;在接收端,UDP把每個訊息段放在佇列中,應用程式每次從佇列中讀一個訊息段。
(2) 由於傳輸資料不建立連線,因此也就不需要維護連線狀態,包括收發狀態等,因此一臺服務機可同時向多個客戶機傳輸相同的訊息。
(3) UDP資訊包的標題很短,只有8個位元組,相對於TCP的20個位元組資訊包的額外開銷很小。
(4) 吞吐量不受擁擠控制演算法的調節,只受應用軟體生成資料的速率、傳輸頻寬、源端和終端主機效能的限制。
(5)UDP使用盡最大努力交付,即不保證可靠交付,因此主機不需要維持複雜的連結狀態表(這裡面有許多引數)。
(6)UDP是面向報文的。傳送方的UDP對應用程式交下來的報文,在新增首部後就向下交付給IP層。既不拆分,也不合並,而是保留這些報文的邊界,因此,應用程式需要選擇合適的報文大小。
我們經常使用“ping”命令來測試兩臺主機之間TCP/IP通訊是否正常,其實“ping”命令的原理就是向對方主機發送UDP資料包,然後對方主機確認收到資料包,如果資料包是否到達的訊息及時反饋回來,那麼網路就是通的。
UDP的包頭結構:
源埠 16位
目的埠 16位
長度 16位
校驗和 16位


小結TCP與UDP的區別:
1.基於連線與無連線;
2.對系統資源的要求(TCP較多,UDP少);
3.UDP程式結構較簡單;
4.流模式與資料報模式 ;
5.TCP保證資料正確性,UDP可能丟包,TCP保證資料順序,UDP不保證。

相關推薦

--TCP&TCPUDP區別

TCP協議與UDP協議的區別     首先咱們弄清楚,TCP協議和UCP協議與TCP/IP協議的聯絡,很多人犯糊塗了,一直都是說TCP/IP協議與UDP協議的區別,我覺得這是沒有從本質上弄清楚網路通訊! TCP/IP協議是一個協議簇。裡面包括很多協議的。UDP只是其中的一個。之所以命名為TCP/IP協議,因為

深入淺出之 TCP協議(次握手次揮手、超時重發、流量控制、擁塞控制、UDP區別

TCP/IP 中有兩個具有代表性的傳輸層協議,分別是TCP、UDP。TCP提供可靠的通訊傳輸,而UDP則常被用於讓廣播和細節控制交給應用的通訊傳輸。 要知道TCP為了這簡單描述“可靠的通訊傳輸”背後所做的努力,你會深感佩服其強大性。TCP的特徵:序列化+確認應

TCP/IP詳解--TCP次握手建立連線次握手終止連線

1.TCP連線的建立 (1)首先是伺服器初始化的過程,從CLOSED(關閉)狀態開始通過順序呼叫SOCKET、BIND、LISTEN和ACCEPT原語建立Socket套接字,進入LISTEN(監聽)狀態,等待客戶端的TCP傳輸連線請求。      (2)客戶端最開始也是從CLOSED狀態開始呼叫SOCKET

TCPUDP區別總結

一對一 pin 就是 三次 撥號 應用 應用程序 之間 斷開 TCP與UDP區別總結:1.TCP面向連接(如打電話要先撥號建立連接);UDP是無連接的,即發送數據之前不需要建立連接2.TCP提供可靠的服務。也就是說,通過TCP連接傳送的數據,無差錯,不丟失,不重復,且按序到

TCPUDP區別小結

就會 SM 協議 流量控制 較高的 www 重傳 單獨 學習 TCP(Transmission Control Protocol):傳輸控制協議 UDP(User Datagram Protocol):用戶數據報協議 主要從連接性(Connecti

TCPUDP區別的深入瞭解

最近在做一款可靠UDP傳輸Client-Server軟體。通過多本書籍和網路文章的學習,加深了對UDP和TCP傳輸協議的認識。 簡單介紹 TCP: 自維持連線的資料“流”傳輸協議 UDP: 資料“報”形式的“單向”傳輸協議 表面上的區別 資料報頭部的長度(當然包括內容了); 傳送TCP報文

TCP UDP區別及使用場景總結

UDP與TCP 區別點: UDP協議:發簡訊 只管發生,不確認對方是否接收到 每個資料大小限制在64k之內 因為無需連結,因此是不可靠協議 速度快 應用場景(當對網路通訊質量有要求的時候,比如:整個資料要準確無誤的傳遞給對方,這往往用於一些要求可靠

_點到點和端到端的區別

在OSI參考模型中,自下而上第一個提供端到端服務的層次是? 答:傳輸層,傳輸層的是作用是負責為兩臺主機中應用程序之間的通訊提供服務,而對於網路層來說,提供的是主機到主機之間的通訊,所謂的端到端是指應用程序到應用程序 那麼提供點到點的服務的層次是哪個呢?

淺談 TCPUDP區別

TCP 傳輸控制協議,提供的是面向連線、可靠的位元組流服務。當客戶和伺服器彼此交換資料前,必須先在雙方之間建立一個TCP連線,之後才能傳輸資料。TCP提供超時重發,丟棄重複資料,檢驗資料,流量控制等功能,保證資料能從一端傳到另一端。 UDP—使用者資料報協

TCPUDP區別的深入了解(這裏只討論IPV4情況,當然,IPV6下的TCPUDP協議部分也能適用)

頭部 線程鎖 重傳 發送 協議 分開 讀寫操作 實現 單向 簡單介紹 TCP: 自維持連接的數據“流”傳輸協議 UDP: 數據“報”形式的“單向”傳輸協議 區別 頭部長度的區別: TCP報頭長20個字節,包括:源端口(2)、目的端口(2)、序號(4)、確認號(4)、頭長

python介面自動化()-封裝呼叫--函式和引數化(詳解)

簡介   前面雖然實現了引數的關聯,但是那種只是記流水賬的完成功能,不便於維護,也沒什麼可讀性,隨著水平和技能的提升,再返回頭去看前邊寫的程式碼,簡直是慘不忍睹那樣的程式碼是初級入門的程式碼水平都達不到。接下來這篇由我帶領小夥伴們把每一 個滑鼠點選動作寫成一個函式,這樣更方便維護了,而且可讀性也高,後期其

TCPUDP區別詳解

## TCP與UDP區別詳解 計算機與其他網路裝置相互通訊,通訊的雙方在傳送和接收資料包時必須基於相同的規則(例如:如何找到通訊目標、如何發起通訊、如何結束通訊等規則都需要事先確定),我們將這種規則稱為協議(Protocol)。 TCP/IP協議簇是 Internet 的基礎,其是一系列網路協議的總稱,例

由一次線上故障來理解下 TCP & Java 堆疊分析到原始碼的探祕

本文導讀: 生產故障場景介紹 TCP 建連三次握手過程 TCP 斷連四次揮手過程 結合 Java 堆疊剖析原始碼 再從堆疊中找到"罪魁禍首" 問題優化方案總結 1、生產故障場景介紹 業務簡介: 該服務主要是提供對外的代理介面,大部分介面都會呼叫第三方介面,獲取資料後做聚合處理後,提供給客戶端使用。 有一

python 絡協議-------------- tcp 次握手 次揮手 簡述

三次握手 四次揮手 語言簡述 三次握手:第一次:客戶端向服務器端發出鏈接請求第二次:服務器端向客戶端給出響應可以鏈接第三次:客戶端告訴服務器端鏈接成功四次揮手:第一次:客戶端向服務器端發起斷開鏈接請求第二次:服務器端響應客戶端等會兒斷開第三次:服務器端響應客戶端可以斷開了第四次:客戶端告知服務器端

腦殘式絡編程入門(一):跟著動畫來學TCP次握手和次揮手

syn 批量 一點 sock 基於 網絡編程 中間件 分析 著名 、引言 網絡編程中TCP協議的三次握手和四次揮手的問題,在面試中是最為常見的知識點之一。很多讀者都知道“三次”和“四次”,但是如果問深入一點,他們往往都無法作出準確回答。 本篇文章嘗試使用動畫圖片的方式,來對

關於TCP手鍊接,次握手關閉

轉自: http://blog.csdn.net/lostyears/article/details/7104349 TCP/IP 狀態機,如下圖所示:       在TCP/IP協議中,TCP協議提供可靠的連線服務,採用三次握手建立一個連線,如圖1所示。 (SYN包表示

五層協議及tcp次握手次揮手

p地址 電平 揮手 syn 服務端 局域網 dhcp 網絡層 數據 一.五層協議:物理層:傳送數據 通過高低電平傳輸數據數據鏈路層:ethernet 以太網協議 必須有一塊網卡:12位16進制數,前六位位廠商編號,後六位為流水線號 (定位到某一臺機

走入計算機的第天(基於tcpudp的套接字)

recv 設置 內存 tcp list dup lis 不知道 狀態 一 TCP套接字 1 low版TCP套接字 服務器端                              客戶端        2、改進版tcp套接字           服務端   

TCP次握手和次揮手

tcp握手和揮手TCP報文的頭部信息: SEQ SYN ACK FIN此時會用上ACK : TCP協議規定,只有ACK=1時有效,也規定連接建立後所有發送的報文的ACK必須為1SYN(SYNchronization) : 在連接建立時用來同步序號。當SYN=1而ACK=0時,表明這是一個連接請求報文。對方若同

TCP次握手次分手

int 有效 tcp三次握手 osi height -1 rcv time 就會 三次握手 解釋:客戶端A和服務器B剛開始處於CLOSED狀態,兩者之間沒有任何聯系,A主動打開,B被動打開由 CLOSED進入LISTEN狀態,這是A發送一個SYN=1的標