HTTP協(xié)議簡介_動力節(jié)點(diǎn)Java學(xué)院整理
TCP協(xié)議對應(yīng)于傳輸層,而HTTP協(xié)議對應(yīng)于應(yīng)用層,從本質(zhì)上來說,二者沒有可比性。Http協(xié)議是建立在TCP協(xié)議基礎(chǔ)之上的,當(dāng)瀏覽器需要從服務(wù)器獲取網(wǎng)頁數(shù)據(jù)的時(shí)候,會發(fā)出一次Http請求。Http會通過TCP建立起一個(gè)到服務(wù)器的連接通道,當(dāng)本次請求需要的數(shù)據(jù)完畢后,Http會立即將TCP連接斷開,這個(gè)過程是很短的。所以Http連接是一種短連接,是一種無狀態(tài)的連接。所謂的無狀態(tài),是指瀏覽器每次向服務(wù)器發(fā)起請求的時(shí)候,不是通過一個(gè)連接,而是每次都建立一個(gè)新的連接。如果是一個(gè)連接的話,服務(wù)器進(jìn)程中就能保持住這個(gè)連接并且在內(nèi)存中記住一些信息狀態(tài)。而每次請求結(jié)束后,連接就關(guān)閉,相關(guān)的內(nèi)容就釋放了,所以記不住任何狀態(tài),成為無狀態(tài)連接。
隨著時(shí)間的推移,html頁面變得復(fù)雜了,里面可能嵌入了很多圖片,這時(shí)候每次訪問圖片都需要建立一次tcp連接就顯得低效了。因此Keep-Alive被提出用來解決效率低的問題。從HTTP/1.1起,默認(rèn)都開啟了Keep-Alive,保持連接特性,簡單地說,當(dāng)一個(gè)網(wǎng)頁打開完成后,客戶端和服務(wù)器之間用于傳輸HTTP數(shù)據(jù)的TCP連接不會關(guān)閉,如果客戶端再次訪問這個(gè)服務(wù)器上的網(wǎng)頁,會繼續(xù)使用這一條已經(jīng)建立的連接Keep-Alive不會永久保持連接,它有一個(gè)保持時(shí)間,可以在不同的服務(wù)器軟件(如Apache)中設(shè)定這個(gè)時(shí)間。雖然這里使用TCP連接保持了一段時(shí)間,但是這個(gè)時(shí)間是有限范圍的,到了時(shí)間點(diǎn)依然是會關(guān)閉的,所以我們還把其看做是每次連接完成后就會關(guān)閉。后來,通過Session, Cookie等相關(guān)技術(shù),也能保持一些用戶的狀態(tài)。但是還是每次都使用一個(gè)連接,依然是無狀態(tài)連接。
為什么Http是無狀態(tài)的短連接,而TCP是有狀態(tài)的長連接?Http不是建立在TCP的基礎(chǔ)上嗎,為什么還能是短連接? Http就是在每次請求完成后就把TCP連接關(guān)了,所以是短連接。而我們直接通過Socket編程使用TCP協(xié)議的時(shí)候,因?yàn)槲覀冏约嚎梢酝ㄟ^代碼區(qū)控制什么時(shí)候打開連接什么時(shí)候關(guān)閉連接,只要我們不通過代碼把連接關(guān)閉,這個(gè)連接就會在客戶端和服務(wù)端的進(jìn)程中一直存在,相關(guān)狀態(tài)數(shù)據(jù)會一直保存著。
在Java中會有Socket,實(shí)際上socket是對TCP/IP協(xié)議的封裝,Socket本身并不是協(xié)議,而是一個(gè)調(diào)用接口(API)。Socket的出現(xiàn)只是使得程序員更方便地使用TCP/IP協(xié)議棧而已,是對TCP/IP協(xié)議的抽象,從而形成了我們知道的一些最基本的函數(shù)接口,比如create、listen、connect、accept、send、read和write等等。
比較形象的描述:HTTP是轎車,提供了封裝或者顯示數(shù)據(jù)的具體形式;Socket是發(fā)動機(jī),提供了網(wǎng)絡(luò)通信的能力。對于從C#編程的角度來講,為了方便,你可以直接選擇已經(jīng)制造好的轎車Http來與服務(wù)器交互。但是有時(shí)候往往因?yàn)榄h(huán)境因素或者其他的一些定制的請求,必須要使用TCP協(xié)議,這時(shí)就需要使用Socket編程,然后自己去處理獲取的數(shù)據(jù)。就像是你用已有的發(fā)動機(jī),自己造了一輛卡車,去從服務(wù)器交互。
HTTP/1.0和HTTP/1.1都把TCP作為底層的傳輸協(xié)議。HTTP客戶首先發(fā)起建立與服務(wù)器TCP連接。一旦建立連接,瀏覽器進(jìn)程和服務(wù)器進(jìn)程就可以通過各自的套接字來訪問TCP。如前所述,客戶端套接字是客戶進(jìn)程和TCP連接之間的“門”,服務(wù)器端套接字是服務(wù)器進(jìn)程和同一TCP連接之間的“門”。客戶往自己的套接字發(fā)送HTTP請求消息,也從自己的套接字接收HTTP響應(yīng)消息。類似地,服務(wù)器從自己的套接字接收HTTP請求消息,也往自己的套接字發(fā)送HTTP響應(yīng)消息。客戶或服務(wù)器一旦把某個(gè)消息送入各自的套接字,這個(gè)消息就完全落入TCP的控制之中。TCP給HTTP提供一個(gè)可靠的數(shù)據(jù)傳輸服務(wù);這意味著由客戶發(fā)出的每個(gè)HTTP請求消息最終將無損地到達(dá)服務(wù)器,由服務(wù)器發(fā)出的每個(gè)HTTP響應(yīng)消息最終也將無損地到達(dá)客戶。
WebService不需要連接,一秒中至少可以支持上萬/十萬的請求,每次請求然后釋放,沒有空余的內(nèi)存消耗。一般不會限制同時(shí)連接的個(gè)數(shù),這是優(yōu)勢。因?yàn)槊總€(gè)連接即使沒有在請求數(shù)據(jù),也會在內(nèi)存中占用一定的空間存儲。會限制,比如SQL Server數(shù)據(jù)庫服務(wù)器,一般最多同時(shí)連接16個(gè)。
Http協(xié)議一定通過指定的端口,80,所以一般計(jì)算機(jī)上不會限制這個(gè)端口,所以Http協(xié)議能夠順利通過所有機(jī)器上的防火墻。而使用Socket編程的話,就需要自己指定特定的端口,那么很可能這個(gè)端口是在某個(gè)環(huán)境中禁用的,那么就無法穿透防火墻。
apache使用的是80端口,也就是這個(gè)程序一直在監(jiān)聽著這個(gè)端口。一旦發(fā)現(xiàn)有人要建立到這個(gè)端口的連接,他就會響應(yīng),然后建立連接。這里說的連接都是短連接。所以你對服務(wù)器上的網(wǎng)址的請求,都是通過80端口送到網(wǎng)站程序的。然后通過這個(gè)端口發(fā)送的客戶端瀏覽器。
相關(guān)文章
adb shell input keyevent 控制按鍵輸入的數(shù)值(收藏版)
adb shell的功能很強(qiáng)大,可以使用很多功能,今天我們說下通過控制按鍵輸入,需要的朋友可以參考下2019-10-10自定義?Github?Action?庫實(shí)戰(zhàn)詳解
這篇文章主要為大家介紹了自定義?Github?Action?庫實(shí)戰(zhàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09Tortoise Git(烏龜git)常用命令總結(jié)
Git作為一個(gè)復(fù)雜的版本控制系統(tǒng),命令之多,即使經(jīng)常使用,一些命令也記不住,一般只記住幾個(gè)常用的命令,本文主要介紹了Tortoise Git(烏龜git)常用命令總結(jié),具有一定的參考價(jià)值,感興趣的可以了解一下2023-08-08Prompt 編程產(chǎn)生背景技術(shù)原理應(yīng)用實(shí)例解析
這篇文章主要為大家介紹了Prompt 編程產(chǎn)生背景技術(shù)原理應(yīng)用實(shí)例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-11-11