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

數(shù)據(jù)庫讀寫分離架構(gòu),為什么我不喜歡

數(shù)據(jù)庫
讀寫分離,解決“數(shù)據(jù)庫讀性能瓶頸”問題;水平切分,解決“數(shù)據(jù)庫數(shù)據(jù)量大”問題;對(duì)于互聯(lián)網(wǎng)大數(shù)據(jù)量,高并發(fā)量,高可用要求高,一致性要求高,前端面向用戶的業(yè)務(wù)場(chǎng)景,微服務(wù)緩存架構(gòu),可能比數(shù)據(jù)庫讀寫分離架構(gòu)更合適。

RD:?jiǎn)螏鞌?shù)據(jù)量太大,數(shù)據(jù)庫扛不住了,我要申請(qǐng)一個(gè)數(shù)據(jù)庫從庫,讀寫分離。

DBA:數(shù)據(jù)量多少?

RD:5000w左右。

DBA:讀寫吞吐量呢?

RD:讀QPS約200,寫QPS約30左右。

 

上周在公司聽到兩個(gè)技術(shù)同學(xué)討論,感覺對(duì)讀寫分離解決什么問題沒有弄清楚,有些奔潰。

 

另,對(duì)于互聯(lián)網(wǎng)某些業(yè)務(wù)場(chǎng)景,并不是很喜歡數(shù)據(jù)庫讀寫分離架構(gòu),一些淺見見文末。

 

一、讀寫分離

什么是數(shù)據(jù)庫讀寫分離?

 

答:一主多從,讀寫分離,主動(dòng)同步,是一種常見的數(shù)據(jù)庫架構(gòu),一般來說:

  • 主庫,提供數(shù)據(jù)庫寫服務(wù)

  • 從庫,提供數(shù)據(jù)庫讀服務(wù)

  • 主從之間,通過某種機(jī)制同步數(shù)據(jù),例如mysql的binlog

一個(gè)組從同步集群通常稱為一個(gè)“分組”。

 

分組架構(gòu)究竟解決什么問題?

答:大部分互聯(lián)網(wǎng)業(yè)務(wù)讀多寫少,數(shù)據(jù)庫的讀往往***成為性能瓶頸,如果希望:

  • 線性提升數(shù)據(jù)庫讀性能

  • 通過消除讀寫鎖沖突提升數(shù)據(jù)庫寫性能

此時(shí)可以使用分組架構(gòu)。

 

一句話,分組主要解決“數(shù)據(jù)庫讀性能瓶頸”問題,在數(shù)據(jù)庫扛不住讀的時(shí)候,通常讀寫分離,通過增加從庫線性提升系統(tǒng)讀性能。

 

二、水平切分

什么是數(shù)據(jù)庫水平切分?

 

答:水平切分,也是一種常見的數(shù)據(jù)庫架構(gòu),一般來說:

  • 每個(gè)數(shù)據(jù)庫之間沒有數(shù)據(jù)重合,沒有類似binlog同步的關(guān)聯(lián)

  • 所有數(shù)據(jù)并集,組成全部數(shù)據(jù)

  • 會(huì)用算法,來完成數(shù)據(jù)分割,例如“取模”

一個(gè)水平切分集群中的每一個(gè)數(shù)據(jù)庫,通常稱為一個(gè)“分片”。

 

水平切分架構(gòu)究竟解決什么問題?

答:大部分互聯(lián)網(wǎng)業(yè)務(wù)數(shù)據(jù)量很大,單庫容量容易成為瓶頸,如果希望:

  • 線性降低單庫數(shù)據(jù)容量

  • 線性提升數(shù)據(jù)庫寫性能

此時(shí)可以使用水平切分架構(gòu)。

 

一句話總結(jié),水平切分主要解決“數(shù)據(jù)庫數(shù)據(jù)量大”問題,在數(shù)據(jù)庫容量扛不住的時(shí)候,通常水平切分。

 

三、為什么不喜歡讀寫分離

對(duì)于互聯(lián)網(wǎng)大數(shù)據(jù)量,高并發(fā)量,高可用要求高,一致性要求高,前端面向用戶的業(yè)務(wù)場(chǎng)景,如果數(shù)據(jù)庫讀寫分離:

  • 數(shù)據(jù)庫連接池需要區(qū)分:讀連接池,寫連接池

  • 如果要保證讀高可用,讀連接池要實(shí)現(xiàn)故障自動(dòng)轉(zhuǎn)移

  • 有潛在的主庫從庫一致性問題

 

  • 如果面臨的是“讀性能瓶頸”問題,增加緩存可能來得更直接,更容易一點(diǎn)

  • 關(guān)于成本,從庫的成本比緩存高不少

  • 對(duì)于云上的架構(gòu),以阿里云為例,主庫提供高可用服務(wù),從庫不提供高可用服務(wù)

 

所以,上述業(yè)務(wù)場(chǎng)景下,樓主建議使用緩存架構(gòu)來加強(qiáng)系統(tǒng)讀性能,替代數(shù)據(jù)庫主從分離架構(gòu)。

 

當(dāng)然,使用緩存架構(gòu)的潛在問題:如果緩存掛了,流量全部壓到數(shù)據(jù)庫上,數(shù)據(jù)庫會(huì)雪崩。不過幸好,云上的緩存一般都提供高可用的服務(wù)。

 

四、總結(jié)

  • 讀寫分離,解決“數(shù)據(jù)庫讀性能瓶頸”問題

  • 水平切分,解決“數(shù)據(jù)庫數(shù)據(jù)量大”問題

  • 對(duì)于互聯(lián)網(wǎng)大數(shù)據(jù)量,高并發(fā)量,高可用要求高,一致性要求高,前端面向用戶的業(yè)務(wù)場(chǎng)景,微服務(wù)緩存架構(gòu),可能比數(shù)據(jù)庫讀寫分離架構(gòu)更合適

 

責(zé)任編輯:龐桂玉 來源: 架構(gòu)師之路
相關(guān)推薦

2018-01-15 05:54:45

數(shù)據(jù)庫讀寫分離互聯(lián)網(wǎng)

2020-07-28 10:45:51

數(shù)據(jù)庫三范式MySQL

2015-10-26 09:58:53

程序員主流

2018-10-16 16:45:05

數(shù)據(jù)庫讀寫分離

2012-04-04 22:07:12

Android

2022-06-04 15:28:42

微服務(wù)架構(gòu)編程語言

2022-12-15 09:44:29

數(shù)據(jù)庫利器

2021-01-30 10:51:07

Python編程語言開發(fā)

2020-05-26 10:42:31

數(shù)據(jù)庫讀寫分離數(shù)據(jù)庫架構(gòu)

2019-10-23 15:53:16

JavaScript可選鏈對(duì)象

2018-02-24 19:37:33

Java8數(shù)據(jù)庫中間件

2017-03-14 13:12:19

2022-12-05 07:51:24

數(shù)據(jù)庫分庫分表讀寫分離

2009-06-04 17:33:08

EJB 3.1EJB 3.0

2019-08-28 10:53:35

JavaScriptOptional Ch代碼

2010-08-23 09:46:17

開發(fā)者

2020-12-11 09:20:01

數(shù)據(jù)庫架構(gòu)緩存

2024-09-20 07:38:00

數(shù)據(jù)庫性能策略

2020-03-24 14:16:18

ProxySQLMySQL數(shù)據(jù)庫

2025-01-15 09:06:58

CSSRegEx前端
點(diǎn)贊
收藏

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