lvs特點:
1.抗負載能力強,使用ip負載均衡技術,只做分發,所以lvs本身并沒有多少流量產生;
2.穩定性、可靠性好,自身有完美的熱備方案;(如:lvs+keepalived)
3.應用范圍比較廣,可以對所有應用做負載均衡;
4.不支持正則處理,不能做動靜分離。
常用四種算法:
1.rr:輪叫,輪流分配到后端服務器;
2.wrr:權重輪叫,根據后端服務器負載情況來分配;
3.lc:最小連接,分配已建立連接最少的服務器上;
4.wlc:權重最小連接,根據后端服務器處理能力來分配。
可以采用ipvsadm –p(persistence)來保持Session,默認是300/s
nginx特點:
1.工作在7層,可以對做正則規則處理;(如:針對域名、目錄進行分流)
2.配置簡單,能ping通就能進行負載功能,可以通過端口檢測后端服務器狀態,不支持url檢測;
3.抗高并發,采用epoll網絡模型處理客戶請求;
4.只支持http和email,應用范圍比較少;
5.nginx主要是http和反向代理服務器,低系統資源消耗。
常用四種算法:
1.rr:(默認)輪詢,輪流分配到后端服務器;
2.weight:根據后端服務器性能分配;
3.ip_hash:每個請求按訪問ip的hash結果進行分配,并發小時合適,解決session問題;
4.fair:(擴展策略),默認不被編譯nginx內核,根據后端服務器響應時間判斷負載情況,選擇最輕的進行處理。
haproxy特點:
1.支持兩種代理模式:tcp(四層)和http(七層),支持虛擬主機;
1.配置簡單,支持url檢測后端服務器狀態;
2.僅做負載均衡軟件使用,在高并發情況下,處理速度高于nginx;
3.tcp層多用于mysql從(讀)服務器負載均衡。
四種常用算法:
1.roundrobin:輪詢,輪流分配到后端服務器;
2.Static-rr:根據后端服務器性能分配;
3.leastconn:最小連接者優先處理;
4.source:根據請求源ip,與nginx的ip_hash類似。
為什么要解決session會話呢?
負載均衡環境下,每個用戶都有可能不固定的訪問后端服務器,在有些應用情況下,是必須要求在一定時間內同一用戶訪問的所有請求都分配給后端同一臺服務器去處理,例如:電子商務網站,用戶注冊頁面等,一刷新頁面,就會分配到后端的另一臺服務器上,那剛才的頁面上的信息也都沒了,這種情況下,分配同一臺服務器處理請求是至關重要的!