是什么使網(wǎng)站變得很慢?

2022-04-28    分類: 網(wǎng)站建設

簡單說來,Web應用慢,是由于下面的三點原因造成的:
● 服務器花在處理客戶請求上的時間。
● 網(wǎng)絡花在傳輸請求和響應上的時間
● 客戶花在組裝并顯示結(jié)果內(nèi)容上的時間。
當然,實際情形遠比這要復雜,原因下面分別進行介紹。
服務發(fā)現(xiàn)
開始訪問任何網(wǎng)站時,客戶都需要先找到服務器。通常這是由DNS查詢完成的,盡管客戶可能已經(jīng)緩存了服務器的IP地址。有時候可能需要多走幾步才能找到正確的服務器,像HTTP重定向這種操作,就會把客戶引向另外的地方。

什么時候客戶需要從新的服務器獲取內(nèi)容,都要經(jīng)歷這種服務發(fā)現(xiàn)過程。結(jié)果,對于帶有很多組件的網(wǎng)站一這是一個日漸普遍的模式一一都會迫使客戶去解析很多網(wǎng)站,并且頁面的加載時間也延長了。
現(xiàn)代的網(wǎng)站都依賴于第三方組件提供諸如支付、嵌入式視頻、到社會媒體的鏈接、監(jiān)控等的功能。然而,每個附加組件都是一個令人擔心的失效點,并且也是導致頁面加載延遲的罪魁,硬生生地剝奪了高效網(wǎng)站的優(yōu)勢。
發(fā)送請求
網(wǎng)絡再快,客戶與服務器之間的往返也是需要時間的,部分原因是物理學上的限制:光從紐約到拉斯維加斯需要13毫秒,那么數(shù)據(jù)從紐約到拉斯維加斯就不可能比13毫秒更快從瀏覽器到內(nèi)容之間的網(wǎng)絡速度是導致延遲的首要因素。
Web請求可能會很簡單:GETindex.html,然而,更為常見的卻是很復雜的請求,包括cookies、URI參數(shù),甚至還有POSTS上載內(nèi)容的操作。請求包含的內(nèi)容越多,則網(wǎng)絡用來傳輸?shù)臅r間就越長。假如是一個安全頁面的話,還會有另外的延遲,用來在客戶與服務器之間進行加密協(xié)商。
再考慮響應
請求到達服務器的以后,另一個導致延遲的罪魁就登場了:主機。不論是從內(nèi)存中檢索靜態(tài)對象,還是利用后臺的第三方服務來完成一個復雜的請求,主機延遲都會對性能造成影響。關于后臺服務造成的延遲,本書其他章節(jié)有討論,這里就不多說了。主機延遲是造成糟糕用戶體驗的主要原因,所以,除了在后臺對其進行測量之外,在網(wǎng)站之外對其進行追蹤也是非常重要的。
記住,假如網(wǎng)站依賴于第三方組件,則也要對這些外部網(wǎng)站的主機延遲進行測量,而且還可以針對這些提供商起草一份服務水平協(xié)議(SLAs),確保他們的網(wǎng)站能夠滿足你的延遲標準。
發(fā)送響應
響應內(nèi)容一旦準備就緒,服務器就可以通過HTTP協(xié)議發(fā)送這些請求對象,正是這些對對象的發(fā)送造成了訪客體驗到的延遲。
雖然看起來似乎是帶寬一一給定時段內(nèi)客戶與服務器之間傳送的數(shù)據(jù)量一一對頁面延遲負有責任,事實上,頁面中的對象數(shù)量以及這些對象從何而來,通常決定著頁面加載所花費的時間。
Web頁面極少只包含一個對象,對于大多數(shù)頁面,容器對象(page.html)包含有對組件對象(Image.gif、video.mo、audio.Wav、movie.Swf)的引引用,從而,這些對象也要抽取過來。而瀏覽器對于在同時能夠檢索多少對象上也是有限制的。所以,頁面加載所用時間,是對象數(shù)量、對象大小、同時能夠檢索的對象數(shù)量、可用帶寬的綜合作用。
異步通信與刷新
某些應用包括一些客戶與服務器之間的通信,這些通信是獨立于頁面進行的,我們在拖拽GoogleMapl時就會觀察到這一點,此日時的背景拼貼就是獨立進行的,或者在你輸入搜索條目時,輸人框下面也會出現(xiàn)可供你選擇的建議列表。這些異步通信模式在Web2.0風格的網(wǎng)站上日漸普遍。
包含某種異步更新或刷新的應用,有不同的延遲測量指標。我們不能再用“頁面加載時間”了,因為此時流向瀏覽器的是持續(xù)的更新流。取而代之的是,我們對“每秒消息數(shù)”或“刷新時間”這樣的指標進行測量,其中,“刷新時間”表示的是從用戶做某件事情(在鍵盤上輸入一個字符,拖動地圖)到內(nèi)容得到刷新(建議列表被刷新,地圖被重繪)之間的延遲。
渲染時間
隨著客戶端越來越復雜,瀏覽器做的也越來越多。有可能是啟動高互聯(lián)網(wǎng)應用(RIA),這些RIAs都是構(gòu)建在Flash、Flex、HTML5、Java、Javascript以.及Silverlight之上的,也可能是運行諸如QuickTime及Windows媒體播放器等這樣的插件,甚至決定如何對復雜頁面進行布局也是需要花費時間的。所以,對于大量依賴客戶端進行渲染的網(wǎng)站,就必須考慮這種延遲。
好消息是,在構(gòu)建網(wǎng)站建設客戶端時,可以在其中包含代碼,對延遲進行測量,然后將數(shù)據(jù)送回給你,這樣就可以了解,對終端用戶而言,你的應用到底怎么樣。

當前文章:是什么使網(wǎng)站變得很慢?
本文地址:http://www.bm7419.com/news1/147101.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供App設計、虛擬主機響應式網(wǎng)站、電子商務、Google、動態(tài)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

商城網(wǎng)站建設