偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

負載均衡,架構(gòu)師到底需不需要了解這玩意?

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

什么是負載均衡?

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

常見的負載均衡方案有哪些?

典型的互聯(lián)網(wǎng)分層架構(gòu):

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

可以看到,每一個下游都有多個上游調(diào)用,只需要做到,每一個上游都均勻訪問每一個下游,就能實現(xiàn)整體的均勻分攤。

第一層:客戶端層到反向代理層。

DNS-server對于一個域名配置了多個解析ip,每次DNS解析請求來訪問DNS-server,會輪詢返回這些ip,保證每個ip的解析概率是相同的。這些ip就是nginx的外網(wǎng)ip,以做到每臺nginx的請求分配也是均衡的。

第二層:反向代理層到站點層。

畫外音:nginx是反向代理的泛指。

修改nginx.conf,可以實現(xiàn)多種均衡策略:

  • 請求輪詢:和DNS輪詢類似,請求依次路由到各個web-server;
  • 最少連接路由:哪個web-server的連接少,路由到哪個web-server;
  • ip哈希:按照訪問用戶的ip哈希值來路由web-server,只要用戶的ip分布是均勻的,請求理論上也是均勻的,ip哈希均衡方法可以做到,同一個用戶的請求固定落到同一臺web-server上,此策略適合有狀態(tài)服務,例如session;

畫外音:站點層可以存儲session,但強烈不建議這么做,站點層無狀態(tài)是分布式架構(gòu)設計的基本原則之一,session最好放到數(shù)據(jù)層存儲。

第三層:站點層到服務層。

上游連接池會建立與下游服務多個連接,每次請求會“隨機”選取連接來訪問下游服務。除了負載均衡,服務連接池還能夠?qū)崿F(xiàn)故障轉(zhuǎn)移、超時處理、限流限速、ID串行化等諸多功能。

第四層:訪問數(shù)據(jù)層。

在數(shù)據(jù)量很大的情況下,由于數(shù)據(jù)層(db/cache)涉及數(shù)據(jù)的水平切分,所以數(shù)據(jù)層的負載均衡更為復雜一些,它分為“數(shù)據(jù)的均衡”,與“請求的均衡”。

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

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

1. 按照range水平切分。

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

  • user0服務:存儲uid范圍1-1kw;
  • user1服務:存儲uid范圍1kw-2kw;

這個方案的好處是:

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

不足是:請求的負載不一定均衡,一般來說,新注冊的用戶會比老用戶更活躍,大range的服務請求壓力會更大

2. 按照id哈希水平切分。

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

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

這個方案的好處是:

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

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

總結(jié)

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

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

知其然,知其所以然。

思路比結(jié)論更重要。

責任編輯:趙寧寧 來源: 架構(gòu)師之路
相關推薦

2020-12-20 18:08:31

業(yè)務層服務化微服務

2020-09-09 10:07:06

導航手機導航北斗導航

2010-11-23 10:55:47

跳槽

2022-02-15 07:26:34

web前端算法題

2024-05-29 08:56:31

2022-04-21 08:01:34

React框架action

2021-07-14 18:21:50

負載均衡TCP網(wǎng)關

2023-10-04 00:19:00

Java開發(fā)

2011-09-02 09:45:39

交互設計Android

2022-09-14 15:10:40

前端架構(gòu)

2015-09-30 09:57:53

天分熱情工程師

2025-08-06 05:22:00

負載均衡HTTP連接RPC連接

2010-10-09 08:46:25

Windows PhoAndroid

2017-03-13 13:54:40

戴爾

2015-07-02 14:15:28

云遷移應用重構(gòu)頭號難題

2015-09-14 11:06:53

PYTHON運維

2020-02-29 15:58:37

iPhoneiOS安卓

2012-08-23 09:50:07

測試測試人員軟件測試

2009-11-23 12:45:22

2010-05-06 09:50:16

負載均衡產(chǎn)品
點贊
收藏

51CTO技術棧公眾號