1.TCP連接
? ? ? ?要想快速正確的發(fā)送數(shù)據(jù)贮懈,就需要了解TCP的一些基本常識仰迁。
? ? ? ?TCP為http提供了一條可靠的比特傳輸管道甸鸟。從TCP連接的一端填入的字節(jié)會從另一端以原有的順序傅蹂、正確的傳送出來励稳。http傳送報文時是以流的形式打開TCP連接南蹂,tcp收到數(shù)據(jù)流之后犬金,會將數(shù)據(jù)流看成被稱作段的小數(shù)據(jù)塊,并將其封裝在IP分組中六剥,通過因特網(wǎng)傳輸晚顷。
http事務時延:
? ? ?(1)如果最近沒有對url主機名進行過訪問,DNS解析主機名為 ? ? ? ? ?IP地址可能需要10s疗疟。
? ? ?(2)每建立一條新的TCP連接该默,通常最多需要1-2s,但是數(shù)百個 ? ? ? ?http事務的話策彤,這個值會快速疊加上去栓袖。
? ? ?(3)web服務器回送http響應,這也需要時間店诗。
對TCP的性能考慮:http為tcp上層裹刮,所以http的書屋性能很大程度上取決于底層tcp通道的性能。
? ? ? (1)TCP握手的時延:(如下圖)新的TCP連接時庞瘸,客戶端要向服務端發(fā)送一個小的TCP分組(40-60字節(jié))捧弃,這個分組中設置了一個特殊的SYN標記,說明這是一個連接請求恕洲。服務器如果接受了連接塔橡,會向客戶端返回一個TCP分組,包括SYN和ACK標記都被置位霜第,說明連接已接受葛家。最后客戶端回送一條確認連接成功建立的消息。程序員看不到這些分組泌类,只會看到創(chuàng)建TCP連接時存在的時延癞谒。
? ? ? (2)TCP慢啟動:為了防止因特網(wǎng)的突然過載和擁堵,TCP連接會自我調(diào)節(jié)刃榨,起初限制連接的最大速度弹砚,如果數(shù)據(jù)成功傳輸,會隨著時間的推移提高傳輸?shù)乃俣仁嘞!:唵蔚恼fTCP限制了傳輸?shù)姆纸M數(shù)桌吃,每成功接收一個分組,就獲得2個分組的權(quán)限苞轿。一次類推:1,2,4,8.....
2.HTTP連接
connection首部:在某些情況下茅诱,相鄰的兩個http應用程序會為它們的連接應用一組選項逗物。connection首部有一個由逗號分隔的連接標簽列表,承載3中不同類型的標簽
(1)http首部字段名瑟俭,列出只與此連接有關的首部
(2)任意標簽值翎卓,用于描述此連接的非標準選項
(3)值close,說明操作完成之后需關閉連接
如圖:
串行事務處理:每個事務都需要串行的建立一條新的連接摆寄,連接延時可能回合慢啟動疊加失暴。比如加載一個頁面加載一副圖片,其他地方?jīng)]有動靜微饥,會讓人覺得很慢逗扒。另一個缺點是瀏覽器無法再對象加載完畢后獲知對象的尺寸和加載進度,用戶面對的是一片空白屏幕畜号。
并行連接:允許客戶打開多條連接缴阎,并執(zhí)行多個http事務。并行連接前提是帶寬足夠好简软,同事還要控制并行的連接個數(shù)微峰,一般設置為4個垦垂。否則并行連接不一定比串行連接快娩鹉。不過并行連接會給客戶端一種錯覺典蜕,感覺比串行連接快。
持久連接:就是常說的長連接疼蛾,http允許http設備在事務處理結(jié)束之后將TCP連接保持打開狀態(tài)肛跌,以便未來的http請求重用現(xiàn)存的連接。
持久連接和并行連接配合使用可能是最高效的方式
3.HTTP版本
http有3個版本察郁,分別為0.9,1.0和1.1.本文主要說1.0和1.1衍慎。
http1.0用的是keep-alive連接。默認為短連接皮钠,支持長連接稳捆,可通過connection:keep-Alive來設置持久化連接。
http1.1是目前最新的版本麦轰,使用的是persistent連接乔夯。默認為持久連接(長連接),想要在事務處理結(jié)束后關閉連接可設置connection:close首部款侵。
另外http1.1允許在持久連接上可選的使用請求管道末荐,即管道化連接,在響應到達之前新锈,可以將多條請求放入隊列甲脏,當?shù)谝粭l請求通過網(wǎng)絡流向另一端服務器時,第二條和第三條請求也可以開始發(fā)送了。這樣做可以降低網(wǎng)絡的環(huán)回時間剃幌。另外客戶端不應該使用POST方式請求聋涨,應為此時管道化會產(chǎn)生副作用晾浴。如果發(fā)出一些數(shù)據(jù)請求之后负乡,收到返回結(jié)果之前,連接關閉了脊凰,客戶端無法確定服務器激發(fā)了多少次事務抖棘,有些事務,如GET一個html頁面狸涌,可以反復發(fā)生多次切省,也不會產(chǎn)生變化,而像非冪等事務POST提交一張訂單帕胆,就不能重復執(zhí)行朝捆,不然會有多張訂單的危險。