成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

別逗了,你真以為分庫分表就能無限擴容嗎?

開發(fā) 前端
像我這樣的菜鳥,總會有各種疑問,剛開始是對 JDK API 的疑問,對 NIO 的疑問,對 JVM 的疑問...

 像我這樣的菜鳥,總會有各種疑問,剛開始是對 JDK API 的疑問,對 NIO 的疑問,對 JVM 的疑問...

[[278647]] 

圖片來自 Pexels

當工作幾年后,對服務的可用性,可擴展性也有了新的疑問,什么疑問呢?其實是老生常談的話題:服務的擴容問題。

正常情況下的服務演化之路

讓我們從最初開始。

單體應用

每個創(chuàng)業(yè)公司基本都是從類似 SSM 和 SSH 這種架構起來的,沒什么好講的,基本每個程序員都經(jīng)歷過。

RPC 應用

當業(yè)務越來越大,我們需要對服務進行水平擴容,擴容很簡單,只要保證服務是無狀態(tài)的就可以了,如下圖:

 

當業(yè)務又越來越大,我們的服務關系錯綜復雜,同時,有很多服務訪問都是不需要連接 DB 的,只需要連接緩存即可,那么就可以做成分離的,減少 DB 寶貴的連接。

如下圖:

 

我相信大部分公司都是在這個階段。Dubbo 就是為了解決這個問題而生的。

分庫分表

如果你的公司產(chǎn)品很受歡迎,業(yè)務繼續(xù)高速發(fā)展,數(shù)據(jù)越來越多,SQL 操作越來越慢,那么數(shù)據(jù)庫就會成為瓶頸。

那么你肯定會想到分庫分表,不論通過 ID Hash 或者 Range 的方式都可以,如下圖:

 

這下應該沒問題了吧。任憑你用戶再多,并發(fā)再高,我只要無限擴容數(shù)據(jù)庫,無限擴容應用,就可以了。

這也是本文的標題,分庫分表就能解決無限擴容嗎?實際上,像上面的架構,并不能解決。

其實,這個問題和 RPC 的問題有點類似:數(shù)據(jù)庫連接過多!

通常,我們的 RPC 應用由于是使用中間件進行數(shù)據(jù)庫訪問,應用實際上是不知道到底要訪問哪個數(shù)據(jù)庫的,訪問數(shù)據(jù)庫的規(guī)則由中間件決定,例如 Sharding JDBC。

這就導致,這個應用必須和所有的數(shù)據(jù)庫連接,就像我們上面的架構圖一樣,一個 RPC 應用需要和 3 個 MySQL 連接。

如果是 30 個 RPC 應用,每個 RPC 的數(shù)據(jù)庫連接池大小是 8,每個 MySQL 需要維護 240 個連接。

我們知道,MySQL 默認連接數(shù)是 100,最大連接數(shù)是 16384,也就是說,假設每個應用的連接池大小是 8 ,超過 2048 個應用就無法再繼續(xù)連接了,也就無法繼續(xù)擴容了。

注意,由于每個物理庫有很多邏輯庫,再加上微服務運動如火如荼,2048 并沒有看起來那么大。

也許你說,我可以通過前面加一個 Proxy 來解決連接數(shù)的問題,實際上,代理的性能也會成為問題,為什么?

代理的連接數(shù)也是不能超過 16384 的,如果并發(fā)超過 16384,變成 163840,那么 Proxy 也解決不了問題。

怎么辦?讓我們再看看上面的架構圖:

 

我們發(fā)現(xiàn),問題是出在“每個 RPC 應用都要連所有的庫”,導致擴容應用的同時,每個數(shù)據(jù)庫連接數(shù)就要增加。

就算增加數(shù)據(jù)庫,也不能解決連接數(shù)的問題。那怎么辦呢?

單元化

單元化,聽起來高大上,通常在一些 XXX 大會上,分享“關于兩地三中心”,“三地五中心”,“異地多活”等等牛逼的名詞的時候,單元化也會一起出現(xiàn)。

這里我們不討論那么牛逼的,就只說“數(shù)據(jù)庫連接數(shù)過多” 的問題。實際上,思路很簡單:我們不讓應用連接所有的數(shù)據(jù)庫就可以了。

假設我們根據(jù) Range 分成了 10 個庫,現(xiàn)在有 10 個應用,我們讓每個應用只連一個庫,當應用增多變成 20 個,數(shù)據(jù)庫的連接不夠用了,我們就將 10 個庫分成 20 個庫。

這樣,無論你應用擴容到多少個,都可以解決數(shù)據(jù)庫連接數(shù)過多的問題。

注意:做這件事的前提是,你必須保證,訪問你這個應用的 Request 請求的數(shù)據(jù)庫一定是在這個應用的。

換個說法,當用戶從 DNS 那里進來的時候,就知道自己要去那個應用了,所以,規(guī)則在 DNS 之前就定好了,雖然這有點夸張,但肯定在進應用之前就知道要去哪個庫了。

所以,這通常需要一個規(guī)則,例如通過用戶 ID Hash,由配置中心廣播 Hash 規(guī)則。

這樣,所有的組件都能保持一致的規(guī)則,從而正確的訪問到數(shù)據(jù)庫,如下圖:

 

到這里,我們終于解決了無限擴容的問題。

最后

本文從單體應用開始,逐步講述了一個正常后臺的演進歷程,知道了分庫分表并不能解決“無限擴容”的問題。

只有單元化才能解決這問題,而單元化則帶來更多的復雜性。但是好處不言而喻,單元化帶來了更多的思路。

有了單元化,解決了無限擴容的問題,但是我們還沒有考慮單點的問題,即服務的可用性。要知道,我們這里的數(shù)據(jù)庫都是單點的。

這就是另一個話題——異地多活,下次再聊。

 

責任編輯:武曉燕 來源: 博客園
相關推薦

2019-01-29 19:24:06

分庫分表數(shù)據(jù)庫

2022-07-11 08:16:47

NewSQL關系數(shù)據(jù)庫系統(tǒng)

2025-06-05 01:11:00

2014-12-26 09:52:52

2025-04-01 08:45:00

2025-02-17 10:30:01

2024-08-07 10:34:46

2023-03-28 08:58:47

分庫分表TiDB

2019-12-17 09:29:02

數(shù)據(jù)庫架構分庫分表

2019-09-09 08:28:48

互聯(lián)網(wǎng)數(shù)據(jù)磁盤

2021-03-01 10:10:39

數(shù)據(jù)遷移擴容

2022-12-09 09:21:10

分庫分表算法

2020-07-30 17:59:34

分庫分表SQL數(shù)據(jù)庫

2024-01-23 08:00:00

區(qū)間評分法電影評分算法

2024-03-12 10:19:25

分庫分表擴容

2023-09-26 00:45:11

MySQL拆表分片

2020-06-24 09:00:43

分庫分表MySQL

2019-11-12 09:54:20

分庫分表數(shù)據(jù)

2017-09-07 10:19:30

PC臺式機行業(yè)

2022-12-27 19:07:52

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美一区二区三区在线看 | 99久久免费精品 | 国产资源一区二区三区 | 免费看91| 国产精品视频久久久 | 欧美精品乱码久久久久久按摩 | 亚洲一区二区中文字幕在线观看 | 国产三区精品 | 先锋资源网 | 亚洲精品一区中文字幕 | 国产成人在线视频播放 | 欧美一级二级三级视频 | 99久久99| 在线观看视频91 | 久久国产精品一区二区 | 日韩一区二区三区精品 | 国产 日韩 欧美 中文 在线播放 | av片在线免费看 | 欧美一区二区三区精品 | 久久一| 黄免费观看视频 | 久久精品国产免费一区二区三区 | 久久激情五月丁香伊人 | 久久成人人人人精品欧 | 电影91久久久 | 91国内外精品自在线播放 | 99九九视频 | 亚洲www啪成人一区二区 | 亚洲狠狠丁香婷婷综合久久久 | 国产清纯白嫩初高生在线播放视频 | 老牛影视av一区二区在线观看 | 日日干夜夜操 | 日韩日b视频 | 免费黄色的网站 | 成年人网站国产 | 伊人精品在线 | 亚洲日本一区二区三区四区 | 亚洲精品久久久久avwww潮水 | 91精品国产综合久久精品 | 久久综合狠狠综合久久综合88 | 日韩综合一区 |