超碰人人精品,中文字幕观看,天天躁日日躁狠狠躁喷水,日本不卡一区在线,一级片在线观看网站,午夜两性做爰免费视频,国产视频二区在线观看

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

2018-01-10 17:10:12 架構(gòu)師之路  點(diǎn)擊量: 評(píng)論 (0)
RD:?jiǎn)螏?kù)數(shù)據(jù)量太大,數(shù)據(jù)庫(kù)扛不住了,我要申請(qǐng)一個(gè)數(shù)據(jù)庫(kù)從庫(kù),讀寫(xiě)分離。DBA:數(shù)據(jù)量多少?RD:5000w左右。DBA:讀寫(xiě)吞吐量呢?RD:讀QPS
RD:?jiǎn)螏?kù)數(shù)據(jù)量太大,數(shù)據(jù)庫(kù)扛不住了,我要申請(qǐng)一個(gè)數(shù)據(jù)庫(kù)從庫(kù),讀寫(xiě)分離。

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

RD:5000w左右。

DBA:讀寫(xiě)吞吐量呢?

RD:讀QPS約200,寫(xiě)QPS約30左右。

 

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

 

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

 

一、讀寫(xiě)分離

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

 

答:一主多從,讀寫(xiě)分離,主動(dòng)同步,是一種常見(jiàn)的數(shù)據(jù)庫(kù)架構(gòu),一般來(lái)說(shuō):

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

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

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

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

 

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

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

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

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

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

 

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

 

二、水平切分

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

 

答:水平切分,也是一種常見(jiàn)的數(shù)據(jù)庫(kù)架構(gòu),一般來(lái)說(shuō):

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

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

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

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

 

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

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

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

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

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

 

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

 

三、為什么不喜歡讀寫(xiě)分離

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

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

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

  • 有潛在的主庫(kù)從庫(kù)一致性問(wèn)題

 

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

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

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

 

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

 

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

 

四、總結(jié)

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

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

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

大云網(wǎng)官方微信售電那點(diǎn)事兒

責(zé)任編輯:售電衡衡

免責(zé)聲明:本文僅代表作者個(gè)人觀點(diǎn),與本站無(wú)關(guān)。其原創(chuàng)性以及文中陳述文字和內(nèi)容未經(jīng)本站證實(shí),對(duì)本文以及其中全部或者部分內(nèi)容、文字的真實(shí)性、完整性、及時(shí)性本站不作任何保證或承諾,請(qǐng)讀者僅作參考,并請(qǐng)自行核實(shí)相關(guān)內(nèi)容。
我要收藏
個(gè)贊
?