socket、tcp、udp、http 的認識及區別

1、先來一個講TCP、UDP和HTTP關係的程序員

一、TCP/IP是個協議組,可分爲三個層次:網絡層、傳輸層和應用層。編程

在網絡層有IP協議、ICMP協議、ARP協議、RARP協議和BOOTP協議。 在傳輸層中有TCP協議與UDP協議。設計模式

在應用層有FTP、HTTP、TELNET、SMTP、DNS等協議。瀏覽器

所以,HTTP自己就是一個協議,是從Web服務器傳輸超文本到本地瀏覽器的傳送協議。安全

 

二、HTTP協議是創建在請求/響應模型上的。服務器

首先由客戶創建一條與服務器的TCP連接,併發送一個請求到服務器,網絡

請求中包含請求方法、URI、協議版本以及相關的MIME樣式的消息。併發

服務器響應一個狀態行,包含消息的協議版本、一個成功和失敗碼以及相關的MIME式樣的消息。socket

HTTP/1.0爲每一次HTTP的請求/響應創建一條新的TCP連接,tcp

所以一個包含HTML內容和圖片的頁面將須要創建屢次的短時間的TCP連接。

一次TCP連接的創建將須要3次握手。

另外,爲了得到適當的傳輸速度,則須要TCP花費額外的迴路連接時間(RTT)。

每一次連接的創建須要這種常常性的開銷,而其並不帶有實際有用的數據,只是保證連接的可靠性,所以HTTP/1.1提出了可持續連接的實現方法。

HTTP/1.1將只創建一次TCP的連接而重複地使用它傳輸一系列的請求/響應消息,所以減小了連接創建的次數和常常性的連接開銷。

 

三、結論:

雖然HTTP自己是一個協議,但其最終仍是基於TCP的。不過,目前,有人正在研究基於TCP+UDP混合的HTTP協議。

Socket是什麼呢?Socket是應用層與TCP/IP協議族通訊的中間軟件抽象層,它是一組接口。在設計模式中,

Socket其實就是一個門面模式,它把複雜的TCP/IP協議族隱藏在Socket接口後面,

對用戶來講,一組簡單的接口就是所有,讓Socket去組織數據,以符合指定的協議。

HTTP、TCP、UDP、Socket <wbr> <wbr> <wbr>(轉)

 

2、TCP、UDP、HTTP、SOCKET之間的區別

TCP和UDP:傳輸層協議;

HTTP:應用層協議;

SOCKET:TCP/IP網絡的API。

TCP/IP表明傳輸控制協議/網際協議,指的是一系列協議。

TCP和UDP使用IP協議從一個網絡傳送數據包到另外一個網絡。把IP想像成一種高速公路,它容許其它協議在上面行駛並找到到其它電腦的出口。

TCP和UDP是高速公路上的「卡車」,它們攜帶的貨物就是像HTTP,文件傳輸協議FTP這樣的協議等。

TCP和UDP是FTP、HTTP和SMTP之類使用的傳輸層協議。

雖然TCP和UDP都是用來傳輸其餘協議的,它們卻有一個顯著的不一樣:TCP提供有保證的數據傳輸,而UDP不提供。

這意味着TCP有一個特殊的機制來確保數據安全的不出錯的從一個端點傳到另外一個端點,而UDP不提供任何這樣的保證。

HTTP(超文本傳輸協議)是利用TCP在兩臺電腦(一般是Web服務器和客戶端)之間傳輸信息的協議。

客戶端使用Web瀏覽器發起HTTP請求給Web服務器,Web服務器發送被請求的信息給客戶端。

記住,須要IP協議來鏈接網絡;TCP是一種容許咱們安全傳輸數據的機制,使用TCP協議來傳輸數據的HTTP是Web服務器和客戶端使用的特殊協議。

Socket 接口是TCP/IP網絡的API,Socket接口定義了許多函數或例程,用以開發TCP/IP網絡上的應用程序。

 

3、socket、tcp、udp、http 的認識及區別

網絡由下往上分爲物理層、數據鏈路層、網絡層、傳輸層、會話層、表示層和應用層。
IP 協議對應於網絡層,TCP協議對應於傳輸層,HTTP協議對應於應用層,三者從本質上來講沒有可比性,socket則是對TCP/IP協議的封裝和應用。
能夠說,TPC/IP協議是傳輸層協議,主要解決數據如何在網絡中傳輸,而HTTP是應用層協議,主要解決如何包裝數據

socket是對TCP/IP協議的封裝,Socket自己並非協議,而是一個調用接口(API),
經過Socket,咱們才能使用TCP/IP協議。
實際上,Socket跟TCP/IP協議沒有必然的聯繫。Socket編程接口在設計的時候,就但願也能適應其餘的網絡協議。
因此說,Socket的出現只是使得程序員更方便地使用TCP/IP協議棧而已,是對TCP/IP協議的抽象,
從而造成了咱們知道的一些最基本的函數接口,好比create、 listen、connect、accept、send、read和write等等

實際上,傳輸層的TCP是基於網絡層的IP協議的,而應用層的HTTP協議又是基於傳輸層的TCP協議的,
而Socket自己不算是協議,就像上面所說,它只是提供了一個針對TCP或者UDP編程的接口

TCP鏈接的三次握手:
第一次握手:客戶端發送syn包(syn=j)到服務器,並進入SYN_SEND狀態,等待服務器確認;
第二次握手:服務器收到syn包,必須確認客戶的SYN(ack=j+1),同時本身也發送一個SYN包(syn=k),即SYN+ACK包,此時服務器進入SYN_RECV狀態;
第三次握手:客戶端收到服務器的SYN+ACK包,向服務器發送確認包ACK(ack=k+1),此包發送完畢,客戶端和服務器進入ESTABLISHED狀態,完成三次握手。
握手過程當中傳送的包裏不包含數據,三次握手完畢後,客戶端與服務器才正式開始傳送數據
斷開鏈接時服務器和客戶端都可以主動發起斷開TCP鏈接的請求,斷開過程須要通過「四次握手」

TCP是面向連接的,雖說網絡的不安全不穩定特性決定了多少次握手都不能保證鏈接的可靠性,
但TCP的三次握手在最低限度上(實際上也很大程度上保證了)保證了鏈接的可靠性;
而UDP不是面向鏈接的,UDP傳送數據前並不與對方創建鏈接,對接收到的數據也不發送確認信號,
發送端不知道數據是否會正確接收,固然也不用重發,因此說UDP是無鏈接的、不可靠的一種數據傳輸協議
也正因爲上面的特色,使得UDP的開銷更小數據傳輸速率更高,由於沒必要進行收發數據的確認,因此UDP的實時性更好。

因此採用TCP傳輸協議的MSN比採用UDP的QQ傳輸文件慢,但並不能說QQ的通訊是不安全的,由於程序員能夠手動對UDP的數據收發進行驗證,好比發送方對每一個數據包進行編號而後由接收方進行驗證啊什麼的,即便是這樣,UDP由於在底層協議的封裝上沒有采用相似 TCP的「三次握手」而實現了TCP所沒法達到的傳輸效率。

相關文章
相關標籤/搜索