自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

關(guān)于負(fù)載均衡的一切

開發(fā) 開發(fā)工具
負(fù)載均衡(Load Balance)是分布式系統(tǒng)架構(gòu)設(shè)計中必須考慮的因素之一,它通常是指,將請求/數(shù)據(jù)均勻分?jǐn)偟蕉鄠€操作單元上執(zhí)行,負(fù)載均衡的關(guān)鍵在于均勻。

什么是負(fù)載均衡?

負(fù)載均衡(Load Balance)是分布式系統(tǒng)架構(gòu)設(shè)計中必須考慮的因素之一,它通常是指,將請求/數(shù)據(jù)均勻分?jǐn)偟蕉鄠€操作單元上執(zhí)行,負(fù)載均衡的關(guān)鍵在于均勻。

常見的負(fù)載均衡方案有哪些?

常見互聯(lián)網(wǎng)分布式架構(gòu)如上,分為:

  • 客戶端層
  • 反向代理層
  • 站點層
  • 服務(wù)層
  • 數(shù)據(jù)層

可以看到,每一個下游都有多個上游調(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,但強烈不建議這么做,站點層無狀態(tài)是分布式架構(gòu)設(shè)計的基本原則之一,session***放到數(shù)據(jù)層存儲。

(4) …

第三層:站點層到服務(wù)層

站點層到服務(wù)層的負(fù)載均衡,是通過“服務(wù)連接池”實現(xiàn)的。

上游連接池會建立與下游服務(wù)多個連接,每次請求會“隨機”選取連接來訪問下游服務(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ù)的均衡”,與“請求的均衡”。

  • 數(shù)據(jù)的均衡是指:水平切分后的每個服務(wù)(db/cache),數(shù)據(jù)量是均勻的。
  • 請求的均衡是指:水平切分后的每個服務(wù)(db/cache),請求量是均勻的。

業(yè)內(nèi)常見的水平切分方式有這么幾種:

一、按照range水平切分

每一個數(shù)據(jù)服務(wù),存儲一定范圍的數(shù)據(jù):

  • user0服務(wù):存儲uid范圍1-1kw
  • user1服務(wù):存儲uid范圍1kw-2kw

這個方案的好處是:

  • 規(guī)則簡單,service只需判斷一下uid范圍就能路由到對應(yīng)的存儲服務(wù)
  • 數(shù)據(jù)均衡性較好
  • 比較容易擴展,可以隨時加一個uid[2kw,3kw]的數(shù)據(jù)服務(wù)

不足是:

  • 請求的負(fù)載不一定均衡,一般來說,新注冊的用戶會比老用戶更活躍,大range的服務(wù)請求壓力會更大

二、按照id哈希水平切分

每一個數(shù)據(jù)服務(wù),存儲某個key值hash后的部分?jǐn)?shù)據(jù):

  • user0服務(wù):存儲偶數(shù)uid數(shù)據(jù)
  • user1服務(wù):存儲奇數(shù)uid數(shù)據(jù)

這個方案的好處是:

  • 規(guī)則簡單,service只需對uid進行hash能路由到對應(yīng)的存儲服務(wù)
  • 數(shù)據(jù)均衡性較好
  • 請求均勻性較好

不足是:

  • 不容易擴展,擴展一個數(shù)據(jù)服務(wù),hash方法改變時候,可能需要進行數(shù)據(jù)遷移

總結(jié)

負(fù)載均衡(Load Balance)是分布式系統(tǒng)架構(gòu)設(shè)計中必須考慮的因素之一,它通常是指,將請求/數(shù)據(jù)均勻分?jǐn)偟蕉鄠€操作單元上執(zhí)行,其的關(guān)鍵在于均勻:

  • 反向代理層的負(fù)載均衡,是通過“DNS輪詢”實現(xiàn)的
  • 站點層的負(fù)載均衡,是通過“nginx”實現(xiàn)的
  • 服務(wù)層的負(fù)載均衡,是通過“服務(wù)連接池”實現(xiàn)的
  • 數(shù)據(jù)層的負(fù)載均衡,要考慮“數(shù)據(jù)的均衡”與“請求的均衡”兩個點,常見的方式有“按照范圍水平切分”與“hash水平切分”

希望大家有收獲。

【本文為51CTO專欄作者“58沈劍”原創(chuàng)稿件,轉(zhuǎn)載請聯(lián)系原作者】

戳這里,看該作者更多好文

責(zé)任編輯:趙寧寧 來源: 51CTO專欄
相關(guān)推薦

2018-01-17 09:15:52

負(fù)載均衡算法

2018-01-05 14:23:36

計算機負(fù)載均衡存儲

2020-09-11 10:55:10

useState組件前端

2016-09-14 15:57:53

架構(gòu)分布式系統(tǒng)負(fù)載均衡

2021-02-28 09:47:54

軟件架構(gòu)軟件開發(fā)軟件設(shè)計

2021-02-19 23:08:27

軟件測試軟件開發(fā)

2020-10-14 08:04:28

JavaScrip

2021-05-28 07:12:59

Python閉包函數(shù)

2022-08-21 17:35:31

原子多線程

2023-04-20 10:15:57

React組件Render

2023-04-12 14:04:48

光纖網(wǎng)絡(luò)

2022-08-17 06:25:19

偽共享多線程

2022-04-02 09:38:00

CSS3flex布局方式

2023-07-10 10:36:17

人工智能AI

2023-02-10 08:44:05

KafkaLinkedIn模式

2021-08-09 14:40:02

物聯(lián)網(wǎng)IOT智能家居

2012-12-31 11:22:58

開源開放

2021-10-05 21:03:54

BeautifulSo 爬蟲

2018-06-15 23:00:56

2022-07-15 14:58:26

數(shù)據(jù)分析人工智能IT
點贊
收藏

51CTO技術(shù)棧公眾號