LVS:
1. 抗負(fù)載能力強(qiáng),性能高,能達(dá)到F5的60%,對(duì)內(nèi)存和CPU資源消耗比較低
2. 工作在網(wǎng)絡(luò)4層,通過VRRP協(xié)議(僅作代理之用),具體的流量是由linux內(nèi)核來處理,因此沒有流量的產(chǎn)生。
3. 穩(wěn)定,可靠性高,自身有完美的熱備方案(Keepalived+lvs)
4. 不支持正則處理,不能做動(dòng)靜分離。
5. 支持多種負(fù)載均衡算法:rr(輪詢),wrr(帶權(quán)輪詢)、lc(最小連接)、wlc(帶權(quán)最小連接)
6. 配置相對(duì)復(fù)雜,對(duì)網(wǎng)絡(luò)依賴比較大,穩(wěn)定性很高。
7. LVS工作模式有4種:
(1) nat 地址轉(zhuǎn)換
(2) dr 直接路由
(3) tun 隧道
(4) full-nat
Nginx:
1. 工作在網(wǎng)絡(luò)7層,可以針對(duì)http應(yīng)用做一些分流的策略,比如針對(duì)域名,目錄結(jié)構(gòu)
2. Nginx對(duì)網(wǎng)絡(luò)的依賴較小,理論上能ping通就能進(jìn)行負(fù)載功能
3. Nginx安裝配置比較簡(jiǎn)單,測(cè)試起來很方便
4. 也可以承擔(dān)較高的負(fù)載壓力且穩(wěn)定,nginx是為解決c10k問題而誕生的
5. 對(duì)后端服務(wù)器的健康檢查,只支持通過端口來檢測(cè),不支持通過url來檢測(cè)
6. Nginx對(duì)請(qǐng)求的異步處理可以幫助節(jié)點(diǎn)服務(wù)器減輕負(fù)載壓力
7. Nginx僅能支持http、https和Email協(xié)議,這樣就在適用范圍較小。
8. 不支持Session的直接保持,但能通過ip_hash來解決。對(duì)Big request header的支持不是很好。
9. Nginx還能做Web服務(wù)器即Cache功能。
第6點(diǎn)補(bǔ)充:
什么是nginx的異步處理:
squid同步處理:瀏覽器發(fā)起請(qǐng)求,而后請(qǐng)求會(huì)立刻被轉(zhuǎn)到后端,于是在瀏覽器和后臺(tái)之間就建立了一個(gè)通道。從請(qǐng)求發(fā)起直到請(qǐng)求完成,這條通道都是一直存在的。
nginx異步處理:瀏覽器發(fā)起請(qǐng)求,請(qǐng)求不會(huì)立刻轉(zhuǎn)到后端,而是請(qǐng)求數(shù)據(jù)(header)先收到nignx上,然后nginx再把這個(gè)請(qǐng)求發(fā)到后端,后端處理完成后把數(shù)據(jù)返回到nginx上,nginx將數(shù)據(jù)流發(fā)到瀏覽器。
使用異步處理的好處:
1. 假設(shè)用戶執(zhí)行一個(gè)上傳文件操作,因?yàn)橛脩艟W(wǎng)速又比較慢,因此需要花半個(gè)小時(shí)才能把文件傳到服務(wù)器。squid的同步代理在用戶開始上傳后就和后臺(tái)建立了連接,半小時(shí)后文件上傳結(jié)束,由此可見,后臺(tái)服務(wù)器連接保持了半個(gè)小時(shí);而nginx異步代理就是先將此文件收到nginx上,因此僅僅是nginx和用戶保持了半小時(shí)連接,后臺(tái)服務(wù)器在這半小時(shí)內(nèi)沒有為這個(gè)請(qǐng)求開啟連接,半小時(shí)后用戶上傳結(jié)束,nginx才將上傳內(nèi)容發(fā)到后臺(tái),nginx和后臺(tái)之間的帶寬是很充裕的,所以只花了一秒鐘就將請(qǐng)求發(fā)送到了后臺(tái),由此可見,后臺(tái)服務(wù)器連接保持了一秒。同步傳輸花了后臺(tái)服務(wù)器半個(gè)小時(shí),異步傳輸只花一秒,可見優(yōu)化 程度很大。
2. 在上面這個(gè)例子中,假如后臺(tái)服務(wù)器因?yàn)榉N種原因重啟了,上傳文件就自然中斷了,這對(duì)用戶來說是非常惱火的一件事情,想必各位也有上傳文件傳到一半被中斷的 經(jīng)歷。用nginx代理之后,后臺(tái)服務(wù)器的重啟對(duì)用戶上傳的影響減少到了極點(diǎn),而nginx是非常穩(wěn)定的并不需要常去重啟它,即使需要重啟,利用kill -HUP就可以做到不間斷重啟nginx。
3. 異步傳輸可以令負(fù)載均衡器更有保障,為什么這么說呢?在其它的均衡器(lvs/haproxy/apache等)里,每個(gè)請(qǐng)求都是只有一次機(jī)會(huì)的,假如用 戶發(fā)起一個(gè)請(qǐng)求,結(jié)果該請(qǐng)求分到的后臺(tái)服務(wù)器剛好掛掉了,那么這個(gè)請(qǐng)求就失敗了;而nginx因?yàn)槭钱惒降模赃@個(gè)請(qǐng)求可以重新發(fā)往下一個(gè)后臺(tái),下一個(gè) 后臺(tái)返回了正常的數(shù)據(jù),于是這個(gè)請(qǐng)求就能成功了。還是用用戶上傳文件這個(gè)例子,假如不但用了nginx代理,而且用了負(fù)載均衡,nginx把上傳文件發(fā)往 其中一臺(tái)后臺(tái),但這臺(tái)服務(wù)器突然重啟了,nginx收到錯(cuò)誤后,會(huì)將這個(gè)上傳文件發(fā)到另一臺(tái)后臺(tái),于是用戶就不用再花半小時(shí)上傳一遍。
4. 假如用戶上傳一個(gè)10GB大小的文件,而后臺(tái)服務(wù)器沒有考慮到這個(gè)情況,那么后臺(tái)服務(wù)器豈不要崩潰了。用nginx就可以把這些東西都攔在nginx上,通過nginx的上傳文件大小限制功能來限制,另外nginx性能非常有保障,就放心的讓互聯(lián)網(wǎng)上那些另類的用戶和nginx對(duì)抗去吧。
用異步傳輸會(huì)造成問題:
后臺(tái)服務(wù)器有提供上傳進(jìn)度的功能的話,用了nginx代理就無法取得進(jìn)度,這個(gè)需要使用nginx的一個(gè)第三方模塊來實(shí)現(xiàn)。
第8點(diǎn)補(bǔ)充:
Nginx upstream支持的分配策略及原理:
1. 輪詢(默認(rèn)):每個(gè)請(qǐng)求按照順序逐一分配到不同的后端服務(wù)器。如后端服務(wù)器down掉,就切換到另一臺(tái)并剔除down的后端主機(jī)
2. weight:指定輪詢幾率,weight和訪問比率成正比,用于后端服務(wù)器性能不均的情況。
3. ip_hash:每個(gè)請(qǐng)求按照訪問ip的hash結(jié)果分配,不同ip的請(qǐng)求被分配到后端不同的服務(wù)器上,可以解決session的問題。
HAProxy:
1. 支持兩種代理模式:TCP(四層)和HTTP(七層),支持虛擬主機(jī);
2. 能夠補(bǔ)充Nginx的一些缺點(diǎn)比如Session的保持,Cookie的引導(dǎo)等工作
3. 支持url檢測(cè)后端的服務(wù)器出問題的檢測(cè)會(huì)有很好的幫助。
4. 更多的負(fù)載均衡策略比如:動(dòng)態(tài)加權(quán)輪循(Dynamic Round Robin),加權(quán)源地址哈希(Weighted Source Hash),加權(quán)URL哈希和加權(quán)參數(shù)哈希(Weighted Parameter Hash)已經(jīng)實(shí)現(xiàn)
5. 單純從效率上來講HAProxy更會(huì)比Nginx有更出色的負(fù)載均衡速度。
6. HAProxy可以對(duì)Mysql進(jìn)行負(fù)載均衡,對(duì)后端的DB節(jié)點(diǎn)進(jìn)行檢測(cè)和負(fù)載均衡。
7. 支持負(fù)載均衡算法:Round-robin(輪循)、Weight-round-robin(帶權(quán)輪循)、source(原地址保持)、RI(請(qǐng)求URL)、rdp-cookie(根據(jù)cookie)
8. 不能做Web服務(wù)器即Cache。
三大主流軟件負(fù)載均衡器適用業(yè)務(wù)場(chǎng)景:
1. 網(wǎng)站建設(shè)初期,可以選用Nginx、HAProxy作為反向代理負(fù)載均衡(流量不大時(shí),可以不選用負(fù)載均衡),因?yàn)槠渑渲煤?jiǎn)單,性能也能滿足一般業(yè)務(wù)場(chǎng)景。如果考慮到負(fù)載均衡器是有單點(diǎn)問題,可以采用Nginx+Keepalived/HAproxy+Keepalived避免負(fù)載均衡器自身的單點(diǎn)問題。
2. 網(wǎng)站并發(fā)到達(dá)一定程度后,為了提高穩(wěn)定性和轉(zhuǎn)發(fā)效率,可以使用lvs,畢竟lvs比Nginx/HAProxy要更穩(wěn)定,轉(zhuǎn)發(fā)效率也更高。
注:nginx與HAProxy比較:nginx只支持七層,用戶量最大,穩(wěn)定性比較可靠。Haproxy支持四層和七層,支持更多的負(fù)載均衡算法,支持session等。
衡量負(fù)載均衡器好壞的幾個(gè)重要的因素:
1. 會(huì)話率 :?jiǎn)挝粫r(shí)間內(nèi)的處理的請(qǐng)求數(shù)
2. 會(huì)話并發(fā)能力:并發(fā)處理能力
3. 數(shù)據(jù)率:處理數(shù)據(jù)能力
2018年11月23日 上午10:32 沙發(fā)
時(shí)間真快,又到年底!正好有空,到這里看看!