一、前言
數(shù)據(jù)庫(kù)的數(shù)據(jù)量達(dá)到一定程度之后,為避免帶來(lái)系統(tǒng)性能上的瓶頸。需要進(jìn)行數(shù)據(jù)的處理,采用的手段是分區(qū)、分片、分庫(kù)、分表。
二、分片(類似分庫(kù))
分片是把數(shù)據(jù)庫(kù)橫向擴(kuò)展(Scale Out)到多個(gè)物理節(jié)點(diǎn)上的一種有效的方式,其主要目的是為突破單節(jié)點(diǎn)數(shù)據(jù)庫(kù)服務(wù)器的 I/O 能力限制,解決數(shù)據(jù)庫(kù)擴(kuò)展性問(wèn)題。Shard這個(gè)詞的意思是“碎片”。如果將一個(gè)數(shù)據(jù)庫(kù)當(dāng)作一塊大玻璃,將這塊玻璃打碎,那么每一小塊都稱為數(shù)據(jù)庫(kù)的碎片(DatabaseShard)。將整個(gè)數(shù)據(jù)庫(kù)打碎的過(guò)程就叫做分片,可以翻譯為分片。
形式上,分片可以簡(jiǎn)單定義為將大數(shù)據(jù)庫(kù)分布到多個(gè)物理節(jié)點(diǎn)上的一個(gè)分區(qū)方案。每一個(gè)分區(qū)包含數(shù)據(jù)庫(kù)的某一部分,稱為一個(gè)片,分區(qū)方式可以是任意的,并不局限于傳統(tǒng)的水平分區(qū)和垂直分區(qū)。一個(gè)分片可以包含多個(gè)表的內(nèi)容甚至可以包含多個(gè)數(shù)據(jù)庫(kù)實(shí)例中的內(nèi)容。每個(gè)分片被放置在一個(gè)數(shù)據(jù)庫(kù)服務(wù)器上。一個(gè)數(shù)據(jù)庫(kù)服務(wù)器可以處理一個(gè)或多個(gè)分片的數(shù)據(jù)。系統(tǒng)中需要有服務(wù)器進(jìn)行查詢路由轉(zhuǎn)發(fā),負(fù)責(zé)將查詢轉(zhuǎn)發(fā)到包含該查詢所訪問(wèn)數(shù)據(jù)的分片或分片集合節(jié)點(diǎn)上去執(zhí)行。
三、Scale Out/Scale Up 和 垂直切分/水平拆分
Mysql的擴(kuò)展方案包括Scale Out和Scale Up兩種。
Scale Out(橫向擴(kuò)展)是指Application可以在水平方向上擴(kuò)展。一般對(duì)數(shù)據(jù)中心的應(yīng)用而言,Scale out指的是當(dāng)添加