squid,nginx,lighttpd反向代理的區別(同步VS異步模式)

反向代理從傳輸上分能夠分爲2種:html

1:同步模式(apache-mod_proxy和squid)nginx

2:異步模式(lighttpd 和 nginx)web

 

在nginx的文檔說明中,提到了異步傳輸模式並提到它能夠減小後端鏈接數和壓力,這是爲什麼?apache

下面就來說解下傳統的代理(apache/squid)的同步傳輸和lighttpd,nginx的異步傳輸的差別。後端

看圖:瀏覽器

 

同步傳輸:瀏覽器發起請求,然後請求會馬上被轉到後臺,因而在瀏覽器和後臺之間就創建了一個通道。在請求發起直到請求完成,這條通道都是一直存在的。
異步傳輸:瀏覽器發起請求,請求不會馬上轉到後臺,而是將請求數據(header)先收到nginx上,而後nginx再把這個請求發到後端,後端處理完以後把數據返回到nginx上,nginx將數據流發到瀏覽器,這點和lighttpd有點不一樣,lighttpd是將後端數據徹底接收後才發送到瀏覽器。服務器

小結:apache和squid的反向會增長後端web的負擔,由於每一個用戶請求都會在proxy上與後端server創建的長久連接,知道數據取完前,鏈接都不會消失。由於wan速度與lan速度的不一樣,雖然lan之間的速度是極度快的,可是用戶的wan鏈接決定了這個時間長。而lighttpd和nginx的異步模式,是無論你用戶要求的數據有多大,都是先收下來,再與後端聯繫,這是很是迅速的速度,因此proxy與後端鏈接時間也會很短,幾十M的東西也是幾秒內。後端不須要維護這麼多鏈接。而lighttpd也和nginx不一樣的異步,lighttpd是先收完再轉向客戶瀏覽器,而nginx是邊收數據邊轉向用戶瀏覽器。負載均衡

 

 

那麼這到底有什麼好處呢?異步

1. 假設用戶執行一個上傳文件操做,由於用戶網速又比較慢,所以須要花半個小時才能把文件傳到服務器。squid的同步代理在用戶開始上傳後就和後臺創建了鏈接,半小時後文件上傳結束,因而可知,後臺服務器鏈接保持了半個小時;而nginx異步代理就是先將此文件收到nginx上,所以僅僅是nginx和用戶保持了半小時鏈接,後臺服務器在這半小時內沒有爲這個請求開啓鏈接,半小時後用戶上傳結束,nginx纔將上傳內容發到後臺,nginx和後臺之間的帶寬是很充裕的,因此只花了一秒鐘就將請求發送到了後臺,因而可知,後臺服務器鏈接保持了一秒。同步傳輸花了後臺服務器半個小時,異步傳輸只花一秒,可見優化程度很大。post

2. 在上面這個例子中,假如後臺服務器由於種種緣由重啓了,上傳文件就天然中斷了,這對用戶來講是很是惱火的一件事情,想必各位也有上傳文件傳到一半被中斷的經歷。用nginx代理以後,後臺服務器的重啓對用戶上傳的影響減小到了極點,而nginx是很是穩定的並不須要常去重啓它,即便須要重啓,利用kill -HUP就能夠作到不間斷重啓nginx。

3. 異步傳輸能夠令負載均衡器更有保障,爲何這麼說呢?在其它的均衡器(lvs/haproxy/apache等)裏,每一個請求都是隻有一次機會的,假如用戶發起一個請求,結果該請求分到的後臺服務器恰好掛掉了,那麼這個請求就失敗了;而nginx由於是異步的,因此這個請求能夠從新發往下一個後臺,下一個後臺返回了正常的數據,因而這個請求就能成功了。仍是用用戶上傳文件這個例子,假如不但用了nginx代理,並且用了負載均衡,nginx把上傳文件發往其中一臺後臺,但這臺服務器忽然重啓了,nginx收到錯誤後,會將這個上傳文件發到另外一臺後臺,因而用戶就不用再花半小時上傳一遍。

4. 假如用戶上傳一個10GB大小的文件,然後臺服務器沒有考慮到這個狀況,那麼後臺服務器豈不要崩潰了。用nginx就能夠把這些東西都攔在nginx上,經過nginx的上傳文件大小限制功能來限制,另外nginx性能很是有保障,就放心的讓互聯網上那些另類的用戶和nginx對抗去吧。

用異步傳輸會形成問題:

後臺服務器有提供上傳進度的功能的話,用了nginx代理就沒法取得進度,這個須要使用nginx的一個第三方模塊來實現。

相關文章
相關標籤/搜索