LB负载均衡集群--LVS
LB集群:
????LB集群是load balance 集群的簡(jiǎn)寫,翻譯成中文就是負(fù)載均衡集群。常用的負(fù)載均衡開源軟件有nginx、lvs、keepalived ,商業(yè)的硬件負(fù)載設(shè)備F5、Netscale。
LB集群架構(gòu):
????當(dāng)用戶的請(qǐng)求過來時(shí),會(huì)直接發(fā)到分發(fā)器(Director Server)上,然后它把用戶的請(qǐng)求根據(jù)預(yù)先設(shè)置好的算法,智能均衡地分發(fā)到后端的真正服務(wù)器(real server)上。如果不同的機(jī)器,可能用戶請(qǐng)求到的數(shù)據(jù)不一樣,為了避免這樣的情況發(fā)生,所以用到了共享存儲(chǔ),這樣保證所有用戶請(qǐng)求的數(shù)據(jù)是一樣的。
????????????LVS是一個(gè)實(shí)現(xiàn)負(fù)載均衡集群的開源軟件項(xiàng)目,LVS架構(gòu)從邏輯上可分為調(diào)度層(Director)、server集群層(Real server)和共享存儲(chǔ)。
LVS的三種模式:
(1)NAT(調(diào)度器將請(qǐng)求的目標(biāo)ip即vip地址改為Real server的ip, 返回的數(shù)據(jù)包也經(jīng)過調(diào)度器,調(diào)度器再把源地址修改為vip)。
(2)TUN(調(diào)度器將請(qǐng)求來的數(shù)據(jù)包封裝加密通過ip隧道轉(zhuǎn)發(fā)到后端的real server上,而real server會(huì)直接把數(shù)據(jù)返回給客戶端,而不再經(jīng)過調(diào)度器)。
(3)DR(調(diào)度器將請(qǐng)求來的數(shù)據(jù)包的目標(biāo)mac地址改為real server的mac地址,返回的時(shí)候也不經(jīng)過調(diào)度器,直接返回給客戶端)。
????????圖中出現(xiàn)的幾個(gè)IP概念,需要解釋一下,其中DIP(driector ip)為分發(fā)器的IP,NAT模式下它必須為公網(wǎng)IP,要對(duì)外服務(wù)。VIP(virtual ip)為虛擬IP,用在TUN和DR模式中,需要同時(shí)配置在分發(fā)器和后端真實(shí)服務(wù)器上。RIP(Real IP)為后端真實(shí)服務(wù)器的IP,在TUN和DR模式中,RIP為公網(wǎng)IP。
LVS的幾種算法:
1:輪詢算法(RR)就是按依次循環(huán)的方式將請(qǐng)求調(diào)度到不同的服務(wù)器上,該算法最大的特點(diǎn)就是實(shí)現(xiàn)簡(jiǎn)單。輪詢算法假設(shè)所有的服務(wù)器處理請(qǐng)求的能力都是一樣的,調(diào)度器會(huì)將所有的請(qǐng)求平均分配給每個(gè)真實(shí)服務(wù)器
2:加權(quán)輪詢算法(WRR)主要是對(duì)輪詢算法的一種優(yōu)化與補(bǔ)充,LVS會(huì)考慮每臺(tái)服務(wù)器的性能,并給每臺(tái)服務(wù)器添加一個(gè)權(quán)值,如果服務(wù)器A的權(quán)值為1,服務(wù)器B的權(quán)值為2,則調(diào)度到服務(wù)器B的請(qǐng)求會(huì)是服務(wù)器A的兩倍。權(quán)值越高的服務(wù)器,處理的請(qǐng)求越多。
3:最小連接調(diào)度算法(LC)將把請(qǐng)求調(diào)度到連續(xù)數(shù)量最小的服務(wù)器上,
4:加權(quán)最小連接算法(WLC)則是給每臺(tái)服務(wù)器一個(gè)權(quán)值,調(diào)度器會(huì)盡可能保持服務(wù)器連接數(shù)量與權(quán)值之間的平衡
5:基于局部性的最少連接調(diào)度算法(lblc)是請(qǐng)求數(shù)據(jù)包的目標(biāo)IP地址的一種調(diào)度算法,該算法先根據(jù)請(qǐng)求的目標(biāo)IP地址尋找最近的該目標(biāo)IP地址所有使用的服務(wù)器,如果這臺(tái)服務(wù)器依然可用,并且用能力處理該請(qǐng)求,調(diào)度器會(huì)盡量選擇相同的服務(wù)器,否則會(huì)繼續(xù)選擇其他可行的服務(wù)器。
6:帶復(fù)雜的基于局部性最少的連接算法(lblcr)激勵(lì)的不是一個(gè)目標(biāo)IP與一臺(tái)服務(wù)器之間的連接記錄,他會(huì)維護(hù)一個(gè)目標(biāo)IP到一組服務(wù)器之間的映射關(guān)系,防止單點(diǎn)服務(wù)器負(fù)責(zé)過高
7:目標(biāo)地址散列調(diào)度算法(DH)也是根據(jù)目標(biāo)IP地址通過散列函數(shù)將目標(biāo)IP與服務(wù)器建立映射關(guān)系,出現(xiàn)服務(wù)器不可用或負(fù)載過高的情況下,發(fā)往該目標(biāo)IP的請(qǐng)求會(huì)固定發(fā)給該服務(wù)器。
8:源地址散列調(diào)度算法(SH)與目標(biāo)地址散列調(diào)度算法類似,但它是根據(jù)源地址散列算法進(jìn)行靜態(tài)分配固定的服務(wù)器資源。
轉(zhuǎn)載于:https://blog.51cto.com/casparcc/1726735
總結(jié)
以上是生活随笔為你收集整理的LB负载均衡集群--LVS的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【excel技巧读书笔记001】清除打开
- 下一篇: iOS 点转成字符串,再字符串转换成点