HTTP協(xié)議與TCP協(xié)議

TCP協(xié)議對(duì)應(yīng)于傳輸層家破,而HTTP協(xié)議對(duì)應(yīng)于應(yīng)用層。從本質(zhì)上來(lái)說(shuō)购岗,二者沒(méi)有可比性汰聋。HTTP協(xié)議是建立在TCP協(xié)議基礎(chǔ)之上的。當(dāng)瀏覽器需要從服務(wù)器獲取網(wǎng)頁(yè)數(shù)據(jù)的時(shí)候喊积,會(huì)發(fā)出一次Http請(qǐng)求烹困。Http會(huì)通過(guò)TCP建立起一個(gè)到服務(wù)器的連接通道,當(dāng)本次請(qǐng)求需要的數(shù)據(jù)完畢后乾吻,Http會(huì)立即將TCP連接斷開(kāi)髓梅,這個(gè)過(guò)程是很短的。所以Http連接是一種短連接绎签,是一種無(wú)狀態(tài)的連接枯饿。

所謂的無(wú)狀態(tài),是指瀏覽器每次向服務(wù)器發(fā)起請(qǐng)求的時(shí)候诡必,不是通過(guò)一個(gè)連接奢方,而是每次都建立一個(gè)新的連接。如果是一個(gè)連接的話,服務(wù)器進(jìn)程中就能保持住這個(gè)連接并且在內(nèi)存中記住一些信息狀態(tài)袱巨。而每次請(qǐng)求結(jié)束后阁谆,連接就關(guān)閉,相關(guān)的內(nèi)容就釋放了愉老,所以記不住任何狀態(tài)场绿,成為無(wú)狀態(tài)連接。
隨著時(shí)間的推移嫉入,html頁(yè)面變得復(fù)雜了焰盗,里面可能嵌入了很多圖片,這時(shí)候每次訪問(wèn)圖片都需要建立一次tcp連接就顯得低效了咒林。因此Keep-Alive被提出用來(lái)解決效率低的問(wèn)題熬拒。從HTTP/1.1起,默認(rèn)都開(kāi)啟了Keep-Alive垫竞,保持連接特性澎粟,簡(jiǎn)單地說(shuō),當(dāng)一個(gè)網(wǎng)頁(yè)打開(kāi)完成后欢瞪,客戶端和服務(wù)器之間用于傳輸HTTP數(shù)據(jù)的TCP連接不會(huì)關(guān)閉活烙,如果客戶端再次訪問(wèn)這個(gè)服務(wù)器上的網(wǎng)頁(yè),會(huì)繼續(xù)使用這一條已經(jīng)建立的連接Keep-Alive不會(huì)永久保持連接遣鼓,它有一個(gè)保持時(shí)間啸盏,可以在不同的服務(wù)器軟件(如Apache)中設(shè)定這個(gè)時(shí)間。雖然這里使用TCP連接保持了一段時(shí)間骑祟,但是這個(gè)時(shí)間是有限范圍的回懦,到了時(shí)間點(diǎn)依然是會(huì)關(guān)閉的,所以我們還把其看做是每次連接完成后就會(huì)關(guān)閉次企。后來(lái)怯晕,通過(guò)Session, Cookie等相關(guān)技術(shù),也能保持一些用戶的狀態(tài)抒巢。但是還是每次都使用一個(gè)連接贫贝,依然是無(wú)狀態(tài)連接。

以前有個(gè)概念很容忍搞不清楚蛉谜。就是為什么Http是無(wú)狀態(tài)的短連接稚晚,而TCP是有狀態(tài)的長(zhǎng)連接?Http不是建立在TCP的基礎(chǔ)上嗎型诚,為什么還能是短連接客燕?現(xiàn)在明白了,Http就是在每次請(qǐng)求完成后就把TCP連接關(guān)了狰贯,所以是短連接也搓。而我們直接通過(guò)Socket編程使用TCP協(xié)議的時(shí)候赏廓,因?yàn)?code>我們自己可以通過(guò)代碼區(qū)控制什么時(shí)候打開(kāi)連接什么時(shí)候關(guān)閉連接,只要我們不通過(guò)代碼把連接關(guān)閉傍妒,這個(gè)連接就會(huì)在客戶端和服務(wù)端的進(jìn)程中一直存在幔摸,相關(guān)狀態(tài)數(shù)據(jù)會(huì)一直保存著。

實(shí)際上Socket是對(duì)TCP/IP協(xié)議的封裝颤练,Socket本身并不是協(xié)議既忆,而是一個(gè)調(diào)用接口(API)。

Socket的出現(xiàn)只是使得程序員更方便地使用TCP/IP協(xié)議棧而已嗦玖,是對(duì)TCP/IP協(xié)議的抽象患雇,從而形成了我們知道的一些最基本的函數(shù)接口,比如create宇挫、listen苛吱、connect、accept器瘪、send翠储、read和write等等。

比較形象的描述:HTTP是轎車(chē)娱局,提供了封裝或者顯示數(shù)據(jù)的具體形式;Socket是發(fā)動(dòng)機(jī)彰亥,提供了網(wǎng)絡(luò)通信的能力。對(duì)于從C#編程的角度來(lái)講衰齐,為了方便,你可以直接選擇已經(jīng)制造好的轎車(chē)Http來(lái)與服務(wù)器交互继阻。但是有時(shí)候往往因?yàn)榄h(huán)境因素或者其他的一些定制的請(qǐng)求耻涛,必須要使用TCP協(xié)議,這時(shí)就需要使用Socket編程瘟檩,然后自己去處理獲取的數(shù)據(jù)抹缕。就像是你用已有的發(fā)動(dòng)機(jī),自己造了一輛卡車(chē)墨辛,去從服務(wù)器交互卓研。

HTTP/1.0HTTP/1.1都把TCP作為底層的傳輸協(xié)議。HTTP客戶首先發(fā)起建立與服務(wù)器TCP連接睹簇。一旦建立連接奏赘,瀏覽器進(jìn)程和服務(wù)器進(jìn)程就可以通過(guò)各自的套接字來(lái)訪問(wèn)TCP。

客戶端套接字是客戶進(jìn)程和TCP連接之間的“門(mén)”太惠,服務(wù)器端套接字是服務(wù)器進(jìn)程和同一TCP連接之間的“門(mén)”磨淌。

C#代碼連接遠(yuǎn)程數(shù)據(jù)庫(kù)用的是TCP協(xié)議。

每次new 一個(gè)connection的時(shí)候凿渊,connection.open就打開(kāi)了這個(gè)TCP連接梁只。connection.Close的時(shí)候就關(guān)閉了這個(gè)連接缚柳。FTP的底層也是TCP, 不過(guò)是長(zhǎng)連接的搪锣。
傳輸大文件比較快秋忙。 需要看具體場(chǎng)景。在服務(wù)器端构舟,如果程序是采取的長(zhǎng)連接的方式灰追,那么就能控制同時(shí)連接到這個(gè)服務(wù)器的連接個(gè)數(shù),防止同時(shí)有多個(gè)連接旁壮。但是采取短連接的方式监嗜,那么就不能控制同時(shí)連接到這個(gè)服務(wù)器上的連接的個(gè)數(shù),這也是一個(gè)優(yōu)點(diǎn)抡谐,可以同時(shí)處理大量連接請(qǐng)求裁奇。但是如果連接請(qǐng)求量太大的話,可能造成服務(wù)器停止工作麦撵。

WebService不需要連接刽肠,一秒中至少可以支持上萬(wàn)/十萬(wàn)的請(qǐng)求,每次請(qǐng)求然后釋放免胃,沒(méi)有空余的內(nèi)存消耗音五。一般不會(huì)限制同時(shí)連接的個(gè)數(shù),這是優(yōu)勢(shì)羔沙。

Message Queue需要建立連接躺涝, 支持上千的連接就很吃力了。因?yàn)槊總€(gè)連接即使沒(méi)有在請(qǐng)求數(shù)據(jù)扼雏,也會(huì)在內(nèi)存中占用一定的空間存儲(chǔ)坚嗜。會(huì)限制,比如SQL Server數(shù)據(jù)庫(kù)服務(wù)器诗充,一般最多同時(shí)連接16個(gè)苍蔬。

Http協(xié)議一定通過(guò)指定的端口,80蝴蜓,所以一般計(jì)算機(jī)上不會(huì)限制這個(gè)端口碟绑,所以Http協(xié)議能夠順利通過(guò)所有機(jī)器上的防火墻。而使用Socket編程的話茎匠,就需要自己指定特定的端口格仲,那么很可能這個(gè)端口是在某個(gè)環(huán)境中禁用的,那么就無(wú)法穿透防火墻汽抚。IIS使用的是80端口抓狭,也就是這個(gè)程序一直在監(jiān)聽(tīng)著這個(gè)端口。一旦發(fā)現(xiàn)有人要建立到這個(gè)端口的連接造烁,他就會(huì)響應(yīng)否过,然后建立連接午笛。這里說(shuō)的連接都是短連接。所以你對(duì)服務(wù)器上的網(wǎng)址的請(qǐng)求苗桂,都是通過(guò)80端口送到網(wǎng)站程序的药磺。然后通過(guò)這個(gè)端口發(fā)送的客戶端瀏覽器。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末煤伟,一起剝皮案震驚了整個(gè)濱河市癌佩,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌便锨,老刑警劉巖围辙,帶你破解...
    沈念sama閱讀 211,194評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異放案,居然都是意外死亡姚建,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,058評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門(mén)吱殉,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)掸冤,“玉大人,你說(shuō)我怎么就攤上這事友雳「迨” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 156,780評(píng)論 0 346
  • 文/不壞的土叔 我叫張陵押赊,是天一觀的道長(zhǎng)饺藤。 經(jīng)常有香客問(wèn)我,道長(zhǎng)流礁,這世上最難降的妖魔是什么策精? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,388評(píng)論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮崇棠,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘丸卷。我一直安慰自己枕稀,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,430評(píng)論 5 384
  • 文/花漫 我一把揭開(kāi)白布谜嫉。 她就那樣靜靜地躺著萎坷,像睡著了一般。 火紅的嫁衣襯著肌膚如雪沐兰。 梳的紋絲不亂的頭發(fā)上哆档,一...
    開(kāi)封第一講書(shū)人閱讀 49,764評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音住闯,去河邊找鬼瓜浸。 笑死澳淑,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的插佛。 我是一名探鬼主播杠巡,決...
    沈念sama閱讀 38,907評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼雇寇!你這毒婦竟也來(lái)了氢拥?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,679評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤锨侯,失蹤者是張志新(化名)和其女友劉穎嫩海,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體囚痴,經(jīng)...
    沈念sama閱讀 44,122評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡叁怪,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,459評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了渡讼。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片骂束。...
    茶點(diǎn)故事閱讀 38,605評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖成箫,靈堂內(nèi)的尸體忽然破棺而出展箱,到底是詐尸還是另有隱情,我是刑警寧澤蹬昌,帶...
    沈念sama閱讀 34,270評(píng)論 4 329
  • 正文 年R本政府宣布混驰,位于F島的核電站,受9級(jí)特大地震影響皂贩,放射性物質(zhì)發(fā)生泄漏栖榨。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,867評(píng)論 3 312
  • 文/蒙蒙 一明刷、第九天 我趴在偏房一處隱蔽的房頂上張望婴栽。 院中可真熱鬧,春花似錦辈末、人聲如沸愚争。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,734評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)轰枝。三九已至,卻和暖如春组去,著一層夾襖步出監(jiān)牢的瞬間鞍陨,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,961評(píng)論 1 265
  • 我被黑心中介騙來(lái)泰國(guó)打工从隆, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留诚撵,地道東北人缭裆。 一個(gè)月前我還...
    沈念sama閱讀 46,297評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像砾脑,于是被迫代替她去往敵國(guó)和親幼驶。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,472評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容