MySQL讀寫(xiě)分離是在主從復(fù)制的基礎(chǔ)上進(jìn)一步通過(guò)在master上執(zhí)行寫(xiě)操作,在slave上執(zhí)行讀操作來(lái)實(shí)現(xiàn)的。通過(guò)主從復(fù)制,master上的數(shù)據(jù)改動(dòng)能夠同步到slave上,從而保持了數(shù)據(jù)的一致性。實(shí)現(xiàn)數(shù)據(jù)的讀寫(xiě)分離能帶來(lái)的好處有:
增加物理服務(wù)器,提升機(jī)器處理能力,也就是拿硬件換性能。
主從只負(fù)責(zé)各自的讀和寫(xiě),極大程度緩解X鎖和S鎖爭(zhēng)用。
slave可以配置myIasm引擎,提升查詢性能以及節(jié)約系統(tǒng)開(kāi)銷。
master直接寫(xiě)是并發(fā)的,slave通過(guò)主庫(kù)發(fā)送來(lái)的binlog恢復(fù)數(shù)據(jù)是異步。
slave可以單獨(dú)設(shè)置一些參數(shù)來(lái)提升其讀的性能。
增加冗余,提高可用性。
常見(jiàn)的實(shí)現(xiàn)數(shù)據(jù)庫(kù)讀寫(xiě)分離的方案大致有兩種:應(yīng)用層,代理層
在應(yīng)用層也就是在代碼中進(jìn)行操作,通過(guò)對(duì)數(shù)據(jù)庫(kù)操作類型的不同手動(dòng)指定數(shù)據(jù)源,可以通過(guò)AOP的方式進(jìn)行實(shí)現(xiàn),不過(guò)對(duì)于一個(gè)已經(jīng)搭建起來(lái)并正在運(yùn)行的系統(tǒng)來(lái)說(shuō),這個(gè)方案應(yīng)該比較復(fù)雜。
另外一種實(shí)現(xiàn)方式是通過(guò)數(shù)據(jù)庫(kù)代理層,代理對(duì)應(yīng)用層呢個(gè)是透明的,所有的讀寫(xiě)分離操作由代理層來(lái)完成,好處就是對(duì)于開(kāi)發(fā)應(yīng)用層來(lái)說(shuō)是透明的,不需要管理數(shù)據(jù)源,缺點(diǎn)在于應(yīng)用原來(lái)直接訪問(wèn)數(shù)據(jù)庫(kù)現(xiàn)在變成了通過(guò)代理訪問(wèn)數(shù)據(jù)庫(kù),性能上肯定會(huì)有影響,不過(guò)如果代理層實(shí)現(xiàn)的很優(yōu)秀的話這個(gè)影響應(yīng)該不大。
通過(guò)代理層實(shí)現(xiàn)數(shù)據(jù)庫(kù)讀寫(xiě)分離又有兩種方案可供選擇,其一是使用MySQL-Proxy,另一種是使用Amoeba。最開(kāi)始找到的實(shí)現(xiàn)方案是基于MySQL-Proxy的,由于它沒(méi)有配置文件,所要完成的工作需要由Lua腳本來(lái)實(shí)現(xiàn),這對(duì)于一個(gè)Lua門(mén)外漢來(lái)說(shuō)壓力不小。后來(lái)找到的Amoeba實(shí)現(xiàn)起來(lái)很簡(jiǎn)單,只需要簡(jiǎn)單地配置就能實(shí)現(xiàn)數(shù)據(jù)庫(kù)的讀寫(xiě)分離,所以這里記錄我通過(guò)使用Amoeba來(lái)實(shí)現(xiàn)數(shù)據(jù)庫(kù)讀寫(xiě)分離的過(guò)程。
Amoeba簡(jiǎn)介:
Amoeba(變形蟲(chóng))致力于MySQL的分布式數(shù)據(jù)庫(kù)前端代理層,它主要在應(yīng)用層訪問(wèn)MySQL的 時(shí)候充當(dāng)SQL路由功能,專注于分布式數(shù)據(jù)庫(kù)代理層(Database Proxy)開(kāi)發(fā)。座落與 Client、DB Server(s)之間,對(duì)客戶端透明。具有負(fù)載均衡、高可用性、SQL 過(guò)濾、讀寫(xiě)分離、可路由相關(guān)的到目標(biāo)數(shù)據(jù)庫(kù)、可并發(fā)請(qǐng)求多臺(tái)數(shù)據(jù)庫(kù)合并結(jié)果。 通過(guò)Amoeba你能夠完成多數(shù)據(jù)源的高可用、負(fù)載均衡、數(shù)據(jù)切片的功能。
Amoeba使用:
一、準(zhǔn)備工作
amoeba使用java編寫(xiě),所以運(yùn)行amoeba的運(yùn)行環(huán)境要安裝好java環(huán)境,并配置好環(huán)境變量,jdk版本要在1.5以上,因?yàn)閍moeba就是用jdk1.5編寫(xiě)的;我的服務(wù)器java版本為1.7。
amoeba是在主從同步的基礎(chǔ)上工作的,所以要先配置好MySQL的主從同步功能,我在另一篇日志中記錄了我實(shí)現(xiàn)Mysql主從同步的過(guò)程,可以參考:MySQL主從復(fù)制(Master-Slave)實(shí)