掃二維碼與項目經(jīng)理溝通
我們在微信上24小時期待你的聲音
解答本文疑問/技術(shù)咨詢/運營咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流
什么是負(fù)載均衡?

負(fù)載均衡(Load Balance)是分布式系統(tǒng)架構(gòu)設(shè)計中必須考慮的因素之一,它通常是指,將請求/數(shù)據(jù)均勻分?jǐn)偟蕉鄠€操作單元上執(zhí)行,負(fù)載均衡的關(guān)鍵在于均勻。
常見的負(fù)載均衡方案有哪些?
常見互聯(lián)網(wǎng)分布式架構(gòu)如上,分為:
可以看到,每一個下游都有多個上游調(diào)用,只需要做到,每一個上游都均勻訪問每一個下游,就能實現(xiàn)整體的均勻分?jǐn)偂?/p>
***層:客戶端層到反向代理層
客戶端層到反向代理層的負(fù)載均衡,是通過“DNS輪詢”實現(xiàn)的。
DNS-server對于一個域名配置了多個解析ip,每次DNS解析請求來訪問DNS-server,會輪詢返回這些ip,保證每個ip的解析概率是相同的。這些ip就是nginx的外網(wǎng)ip,以做到每臺nginx的請求分配也是均衡的。
第二層:反向代理層到站點層
反向代理層到站點層的負(fù)載均衡,是通過“nginx”實現(xiàn)的。
畫外音:nginx是反向代理的泛指。
修改nginx.conf,可以實現(xiàn)多種均衡策略:
(1) 請求輪詢:和DNS輪詢類似,請求依次路由到各個web-server;
(2) 最少連接路由:哪個web-server的連接少,路由到哪個web-server;
(3) ip哈希:按照訪問用戶的ip哈希值來路由web-server,只要用戶的ip分布是均勻的,請求理論上也是均勻的,ip哈希均衡方法可以做到,同一個用戶的請求固定落到同一臺web-server上,此策略適合有狀態(tài)服務(wù),例如session;
畫外音:站點層可以存儲session,但強(qiáng)烈不建議這么做,站點層無狀態(tài)是分布式架構(gòu)設(shè)計的基本原則之一,session***放到數(shù)據(jù)層存儲。
(4) …
第三層:站點層到服務(wù)層
站點層到服務(wù)層的負(fù)載均衡,是通過“服務(wù)連接池”實現(xiàn)的。
上游連接池會建立與下游服務(wù)多個連接,每次請求會“隨機(jī)”選取連接來訪問下游服務(wù)。除了負(fù)載均衡,服務(wù)連接池還能夠?qū)崿F(xiàn)故障轉(zhuǎn)移、超時處理、限流限速、ID串行化等諸多功能。
第四層:訪問數(shù)據(jù)層
在數(shù)據(jù)量很大的情況下,由于數(shù)據(jù)層(db/cache)涉及數(shù)據(jù)的水平切分,所以數(shù)據(jù)層的負(fù)載均衡更為復(fù)雜一些,它分為“數(shù)據(jù)的均衡”,與“請求的均衡”。
業(yè)內(nèi)常見的水平切分方式有這么幾種:
一、按照range水平切分
每一個數(shù)據(jù)服務(wù),存儲一定范圍的數(shù)據(jù):
這個方案的好處是:
不足是:
二、按照id哈希水平切分
每一個數(shù)據(jù)服務(wù),存儲某個key值hash后的部分?jǐn)?shù)據(jù):
這個方案的好處是:
不足是:
總結(jié)
負(fù)載均衡(Load Balance)是分布式系統(tǒng)架構(gòu)設(shè)計中必須考慮的因素之一,它通常是指,將請求/數(shù)據(jù)均勻分?jǐn)偟蕉鄠€操作單元上執(zhí)行,其的關(guān)鍵在于均勻:
希望大家有收獲。
【本文為專欄作者“58沈劍”原創(chuàng)稿件,轉(zhuǎn)載請聯(lián)系原作者】
分享題目:關(guān)于負(fù)載均衡的一切
文章鏈接:http://uogjgqi.cn/article/cdeijgp.html

我們在微信上24小時期待你的聲音
解答本文疑問/技術(shù)咨詢/運營咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流