一、TCP/IP協定簡析
TCP/IP是個協定組,可分為三個層次:網絡層、傳輸層和應用層:
網絡層:IP協定、ICMP協定、ARP協定、RARP協定和BOOTP協定
傳輸層:TCP協定與UDP協定
應用層:FTP、HTTP、TELNET、SMTP、DNS等協定
HTTP是應用層協定,其傳輸都是被包裝成TCP協定傳輸。可以用SOCKET實作HTTP。
SOCKET是實作傳輸層協定的一種程式設計API,可以是TCP,也可以是UDP。
二、Socket連接配接與HTTP連接配接差別
【Socket】
由于通常情況下Socket連接配接就是TCP連接配接,是以Socket連接配接一旦建立,通信雙方即可開始互相發送資料内容,直到雙方連接配接斷開。但在實際網絡應用中,用戶端到伺服器之間的通信往往需要穿越多個中間節點,例如路由器、網關、防火牆等,大部分防火牆預設會關閉長時間處于非活躍狀态的連接配接而導緻 Socket 連接配接斷連,是以需要通過輪詢告訴網絡,該連接配接處于活躍狀态。
【Http】
HTTP協定是建立在TCP協定之上的一種應用,HTTP連接配接使用的是“請求—響應”的方式,不僅在請求時需要先建立連接配接,而且需要用戶端向伺服器送出請求後,伺服器端才能回複資料。在請求結束後,會主動釋放連接配接。從建立連接配接到關閉連接配接的過程稱為“一次連接配接”。由于HTTP在每次請求結束後都會主動釋放連接配接,是以HTTP連接配接是一種“短連接配接”,要保持用戶端程式的線上狀态,需要不斷地向伺服器發起連接配接請求。通常的做法是即時不需要獲得任何資料,用戶端也保持每隔一段固定的時間向伺服器發送一次“保持連接配接”的請求,伺服器在收到該請求後對用戶端進行回複,表明知道用戶端“線上”。若伺服器長時間無法收到用戶端的請求,則認為用戶端“下線”,若用戶端長時間無法收到伺服器的回複,則認為網絡已經斷開。
HTTP協定是建立在請求/響應模型上的。首先由客戶建立一條與伺服器的TCP連結,并發送一個請求到伺服器,請求中包含請求方法、URI、協定版本以及相關的MIME樣式的消息。伺服器響應一個狀态行,包含消息的協定版本、一個成功和失敗碼以及相關的MIME式樣的消息。
【适用情況】
很多情況下,需要伺服器端主動向用戶端推送資料,保持用戶端與伺服器資料的實時與同步。此時若雙方建立的是Socket連接配接,伺服器就可以直接将資料傳送給用戶端;
若雙方建立的是HTTP連接配接,則伺服器需要等到用戶端發送一次請求後才能将資料傳回給用戶端,是以,用戶端定時向伺服器端發送連接配接請求,不僅可以保持線上,同時也是在“詢問”伺服器是否有新的資料,如果有就将資料傳給用戶端。
【SOCKET原理】
(1).套接字(socket)概念:
套接字(socket)是通信的基石,是支援TCP/IP協定的網絡通信的基本操作單元。它是網絡通信過程中端點的抽象表示,包含進行網絡通信必須的五種資訊:連接配接使用的協定,本地主機的IP位址,本地程序的協定端口,遠地主機的IP位址,遠地程序的協定端口。
應用層通過傳輸層進行資料通信時,TCP會遇到同時為多個應用程式程序提供并發服務的問題。多個TCP連接配接或多個應用程式程序可能需要通過同一個 TCP協定端口傳輸資料。為了差別不同的應用程式程序和連接配接,許多計算機作業系統為應用程式與TCP/IP協定互動提供了套接字(Socket)接口。應用層可以和傳輸層通過Socket接口,區分來自不同應用程式程序或網絡連接配接的通信,實作資料傳輸的并發服務。
(2).建立socket連接配接:
建立Socket連接配接至少需要一對套接字,其中一個運作于用戶端,稱為ClientSocket ,另一個運作于伺服器端,稱為ServerSocket 。
套接字之間的連接配接過程分為三個步驟:伺服器監聽,用戶端請求,連接配接确認。
伺服器監聽:伺服器端套接字并不定位具體的用戶端套接字,而是處于等待連接配接的狀态,實時監控網絡狀态,等待用戶端的連接配接請求
用戶端請求:指用戶端的套接字提出連接配接請求,要連接配接的目标是伺服器端的套接字。為此,用戶端的套接字必須首先描述它要連接配接的伺服器的套接字,指出伺服器端套接字的位址和端口号,然後就向伺服器端套接字提出連接配接請求。
連接配接确認:當伺服器端套接字監聽到或者說接收到用戶端套接字的連接配接請求時,就響應用戶端套接字的請求,建立一個新的線程,把伺服器端套接字的描述發給用戶端,一旦用戶端确認了此描述,雙方就正式建立連接配接。而伺服器端套接字繼續處于監聽狀态,繼續接收其他用戶端套接字的連接配接請求。
(3).SOCKET連接配接與TCP連接配接
建立Socket連接配接時,可以指定使用的傳輸層協定,Socket可以支援不同的傳輸層協定(TCP或UDP),當使用TCP協定進行連接配接時,該Socket連接配接就是一個TCP連接配接。
三、TCP 與 UDP
【概念】
TCP傳輸控制協定,提供的是面向連接配接、可靠的位元組流服務。當客戶和伺服器彼此交換資料前,必須先在雙方之間建立一個TCP連接配接,之後才能傳輸資料。TCP提供逾時重發,丢棄重複資料,檢驗資料,流量控制等功能,保證資料能從一端傳到另一端。 理想狀态下,TCP連接配接一旦建立,在通信雙方中的任何一方主動關閉連接配接前,TCP 連接配接都将被一直保持下去。斷開連接配接時伺服器和用戶端均可以主動發起斷開TCP連接配接的請求
UDP使用者資料報協定,是一個無連接配接的簡單的面向資料報的運輸層協定。UDP不提供可靠性,它隻是把應用程式傳給IP層的資料報發送出去,但是并不能保證它們能到達目的地。由于UDP在傳輸資料報前不用在客戶和伺服器之間建立一個連接配接,且沒有逾時重發等機制,故而傳輸速度很快
TCP發送的包有序号,對方收到包後要給一個回報,如果超過一定時間還沒收到回報就自動執行逾時重發,是以TCP最大的優點是可靠。一般網頁(http)、郵件(SMTP)、遠端連接配接(Telnet)、檔案(FTP)傳送就用TCP
UDP是面向消息的協定,通信時不需要建立連接配接,資料的傳輸自然是不可靠的,UDP一般用于多點通信和實時的資料業務,比如語音廣播、視訊、QQ、TFTP(簡單檔案傳送)、SNMP(簡單網絡管理協定)、RTP(實時傳送協定)RIP(路由資訊協定,如報告股票市場,航空資訊)、DNS(域名解釋)。注重速度流暢。
【TCP連接配接的三次握手】
要了解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狀态,完成三次握手。
四、FTP協定
檔案傳輸協定(File Transfer Protocol, FTP)是TCP/IP網絡上兩台計算機傳送檔案的協定,FTP是在TCP/IP網絡和INTERNET上最早使用的協定之一,它屬于網絡協定組的應用層。FTP客戶機可以給伺服器發出指令來下載下傳檔案,上載檔案,建立或改變伺服器上的目錄。