一種是經過硬件來進行進行,常見的硬件有比較昂貴的NetScaler、F五、Radware和Array等商用的負載均衡器,它的優勢就是有 專業的維護團隊來對這些服務進行維護、缺點就是花銷太大,因此對於規模較小的網絡服務來講暫時尚未須要使用;另一種就是相似於 LVS/HAProxy、Nginx的基於Linux的開源免費的負載均衡軟件策略,這些都是經過軟件級別來實現,因此費用很是低廉,因此我個也比較推薦 你們採用第二種方案來實施本身網站的負載均衡需求。 前端
近期朋友劉鑫(紫雨荷雪)的項目成功上線了,PV達到了億級/日的訪問量,最前端用的是HAProxy+Keepalived雙機做的負載均衡 器/反向代理,整個網站很是穩定;這讓我更堅決了之前跟老男孩前輩聊的關於網站架構比較合理設計的架構方案:即Nginx /HAProxy+Keepalived做Web最前端的負載均衡器,後端的MySQL數據庫架構採用一主多從,讀寫分離的方式,採用 LVS+Keepalived的方式。 web
在這裏我也有一點要跟你們申明下:不少朋友擔憂軟件級別的負載均衡在高併發流量衝擊下的穩定狀況,事實是咱們經過成功上線的許多網站發現,它們 的穩定性也是很是好的,宕機的可能性微乎其微,因此我如今作的項目,基本上沒考慮服務級別的高可用了。相信你們對這些軟件級別的負載均衡軟件都已經有了很 深的的認識,下面我就它們的特色和適用場合分別說明下。 算法
LVS:使用集羣技術和Linux操做系統實現一個高性能、高可用的服務器,它具備很好的可伸縮性(Scalability)、可靠性(Reliability)和可管理性(Manageability),感謝章文嵩博士爲咱們提供如此強大實用的開源軟件。 sql
LVS的特色是: 數據庫
一、抗負載能力強、是工做在網絡4層之上僅做分發之用,沒有流量的產生,這個特色也決定了它在負載均衡軟件裏的性能最強的; 後端
二、配置性比較低,這是一個缺點也是一個優勢,由於沒有可太多配置的東西,因此並不須要太多接觸,大大減小了人爲出錯的概率; 緩存
三、工做穩定,自身有完整的雙機熱備方案,如LVS+Keepalived和LVS+Heartbeat,不過咱們在項目實施中用得最多的仍是LVS/DR+Keepalived; 服務器
四、無流量,保證了均衡器IO的性能不會收到大流量的影響; cookie
五、應用範圍比較廣,能夠對全部應用作負載均衡; 網絡
六、軟件自己不支持正則處理,不能作動靜分離,這個就比較遺憾了;其實如今許多網站在這方面都有較強的需求,這個是Nginx/HAProxy+Keepalived的優點所在。
七、若是是網站應用比較龐大的話,實施LVS/DR+Keepalived起來就比較複雜了,特別後面有Windows Server應用的機器的話,若是實施及配置還有維護過程就比較複雜了,相對而言,Nginx/HAProxy+Keepalived就簡單多了。
Nginx的特色是:
一、工做在網絡的7層之上,能夠針對http應用作一些分流的策略,好比針對域名、目錄結構,它的正則規則比HAProxy更爲強大和靈活,這也是許多朋友喜歡它的緣由之一;
二、Nginx對網絡的依賴很是小,理論上能ping通就就能進行負載功能,這個也是它的優點所在;
三、Nginx安裝和配置比較簡單,測試起來比較方便;
四、也能夠承擔高的負載壓力且穩定,通常能支撐超過幾萬次的併發量;
五、Nginx能夠經過端口檢測到服務器內部的故障,好比根據服務器處理網頁返回的狀態碼、超時等等,而且會把返回錯誤的請求從新提交到另外一個節點,不過其中缺點就是不支持url來檢測;
六、Nginx僅能支持http和Email,這樣就在適用範圍上面小不少,這個它的弱勢;
七、Nginx不只僅是一款優秀的負載均衡器/反向代理軟件,它同時也是功能強大的Web應用服務器。LNMP如今也是很是流行的web架構,大有和之前最流行的LAMP架構分庭抗爭之勢,在高流量的環境中也有很好的效果。
八、Nginx如今做爲Web反向加速緩存愈來愈成熟了,不少朋友都已在生產環境下投入生產了,並且反映效果不錯,速度比傳統的Squid服務器更快,有興趣的朋友能夠考慮用其做爲反向代理加速器。
HAProxy的特色是:
一、HAProxy是支持虛擬主機的,之前有朋友說這個不支持虛擬主機,我這裏特此更正一下。
二、可以補充Nginx的一些缺點好比Session的保持,Cookie的引導等工做
三、支持url檢測後端的服務器出問題的檢測會有很好的幫助。
四、它跟LVS同樣,自己僅僅就只是一款負載均衡軟件;單純從效率上來說HAProxy更會比Nginx有更出色的負載均衡速度,在併發處理上也是優於Nginx的。
五、HAProxy能夠對Mysql讀進行負載均衡,對後端的MySQL節點進行檢測和負載均衡,不過在後端的MySQL slaves數量超過10臺時性能不如LVS,因此我向你們推薦LVS+Keepalived。
六、HAProxy的算法如今也愈來愈多了,具體有以下8種:
①roundrobin,表示簡單的輪詢,這個很少說,這個是負載均衡基本都具有的;
②static-rr,表示根據權重,建議關注;
③leastconn,表示最少鏈接者先處理,建議關注;
④ource,表示根據請求源IP,這個跟Nginx的IP_hash機制相似,咱們用其做爲解決session問題的一種方法,建議關注;
⑤ri,表示根據請求的URI;
⑥rl_param,表示根據請求的URl參數'balance url_param' requires an URL parameter name;
⑦hdr(name),表示根據HTTP請求頭來鎖定每一次HTTP請求;
⑧rdp-cookie(name),表示根據據cookie(name)來鎖定並哈希每一次TCP請求。