MySQL讀寫分離原理詳細(xì)解析
一、讀寫分離的概念
讀寫分離是基于主從復(fù)制來實(shí)現(xiàn)的。在實(shí)際的應(yīng)用環(huán)境中,肯定是讀操作多,就像我們?cè)陔娚唐脚_(tái)上去購買東西,可能看了100個(gè)也就買了一兩個(gè)。所以讀操作永遠(yuǎn)比寫這種更新操作多很多。所以我們基于主從復(fù)制的讀寫分離配置,就是讓一個(gè)主庫專門用來做數(shù)據(jù)的修改,寫的時(shí)候?qū)iT在主庫上寫,主庫通過主從復(fù)制把數(shù)據(jù)的更改通過binlog同步到從庫上去,那么其他的客戶端查詢的請(qǐng)求都會(huì)最終映射到從庫上去,而我們一個(gè)主庫帶上兩三個(gè)從庫,主庫專門用來做數(shù)據(jù)的更新(寫操作),從庫專門用來做讀操作這樣一來可以很好的分?jǐn)傋x寫的壓力,不用全部都集中在主庫上,對(duì)于后端服務(wù)的并發(fā)處理能力有很大的提高,另外就是它的高可用容災(zāi),當(dāng)主庫掛了以后,可以把指定的從庫變成主庫。
MySQL client通過mysql 提供的API,用mysql自定義的基于TCP的數(shù)據(jù)協(xié)議(簡(jiǎn)稱mysql協(xié)議)與MySQL Server通信,訪問MySQL Server數(shù)據(jù)庫。
如果只有一臺(tái)服務(wù)器(單機(jī)環(huán)境),所有數(shù)據(jù)的增刪改查都是在一臺(tái)服務(wù)器上進(jìn)行,隨著我們的服務(wù)被越來越多的人使用,流量逐漸變大,需要并發(fā)能力逐漸提升,所以如果我們發(fā)現(xiàn)數(shù)據(jù)庫性能到瓶頸了,我們可以做讀寫分離操作,提高后臺(tái)服務(wù)。
圖中的MySQL主服務(wù)器專門做寫操作,下面連著2個(gè)MySQL從服務(wù)器專門做讀操作,讀請(qǐng)求轉(zhuǎn)發(fā)到B、C,寫請(qǐng)求轉(zhuǎn)發(fā)到A。
如果我們?cè)诳蛻舳松现苯佑么a寫死,insert、update等寫操作在A上做,show、select等讀操作在B、C上做,相當(dāng)于代碼和主從環(huán)境就是強(qiáng)綁定的。這就導(dǎo)致代碼的穩(wěn)定性不太好,因?yàn)楹铜h(huán)境強(qiáng)相關(guān)了,我們寫代碼得時(shí)候必須得知道哪個(gè)機(jī)器是負(fù)責(zé)寫操作的主庫,哪個(gè)機(jī)器是負(fù)責(zé)讀操作的從庫,由代碼來選擇。而這時(shí)如果有某個(gè)機(jī)器掛掉了,代碼也不會(huì)知道,還是按照原來的方式轉(zhuǎn)發(fā)請(qǐng)求,通信就會(huì)出現(xiàn)問題,所以把讀寫分離用代碼實(shí)現(xiàn)肯定不合適。所以在實(shí)際的解決方案中,讀寫分離需要依賴數(shù)據(jù)庫的中間件。
二、引入中間件MyCat
實(shí)際上,讀寫分離,分庫分表都是需要依賴數(shù)據(jù)庫中間件(mycat),mycat就是代理服務(wù)器的角色。
客戶端實(shí)際上區(qū)分不出來連的是MyCat還是MySQL,因?yàn)橥ㄐ哦际亲袷氐氖荕ySQL通信協(xié)議,之前怎么和MySQL通信,現(xiàn)在就怎么和MyCat通信,所以不用進(jìn)行區(qū)分。
在MyCat上配置讀寫分離,我們?cè)诳蛻舳松系拇a不用做任何變更,代碼上不需要區(qū)分哪個(gè)請(qǐng)求是讀,哪個(gè)請(qǐng)求是寫,代碼直接訪問的是MyCat,由MyCat解析請(qǐng)求,根據(jù)SQL的讀寫性質(zhì)轉(zhuǎn)發(fā)到負(fù)責(zé)相應(yīng)操作的服務(wù)器,實(shí)現(xiàn)讀寫分離。
在MyCat上需要配置主服務(wù)器和從服務(wù)器的信息,有3種情況:一主一從、一主多從、多主多從
一主多從場(chǎng)景:當(dāng)寫庫(master)掛了,MyCat還可以馬上把一個(gè)從庫(slave)直接變成一個(gè)寫庫(master),那相當(dāng)于又回到一臺(tái)機(jī)器的處理,因?yàn)閺膸旌蛷膸熘g并沒有主從復(fù)制的配置,所以我們還需要把變成寫庫的從庫還要和其他從庫之間配置一下主從復(fù)制。
多主多從:
可以看到圖中,MyCat服務(wù)器掛了兩套環(huán)境,如果其中1套的主庫宕機(jī)了(它對(duì)應(yīng)的從庫也就不能用了),此時(shí)MyCat會(huì)自動(dòng)切到另一套環(huán)境,因?yàn)?strong>M1和M2之間也是配置成互為主從的,所以M2可以同步M1的數(shù)據(jù),提供與M1環(huán)境完全相同的服務(wù),所以它的高可用容災(zāi)能力是非常不錯(cuò)的。
三、MyCat服務(wù)端口和管理端口
MySQL的服務(wù)端口是3306,MyCat服務(wù)端口是8066(這個(gè)端口也是可以改的),也就是MySQL Client連接的是8066端口,登錄8066端口看到的界面就和登錄MySQL Server的3306端口一樣。MyCat還有一個(gè)管理端口9066,登錄這個(gè)管理端口可以查看MyCat正在工作的所有狀態(tài)以及和后端服務(wù)器的連接,以及連接數(shù)據(jù)源的狀態(tài)等。
到此這篇關(guān)于MySQL讀寫分離原理詳細(xì)解析的文章就介紹到這了,更多相關(guān)MySQL讀寫分離 內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MySQL無法啟動(dòng)1067錯(cuò)誤的又一種解決方法(機(jī)房斷電)
今早在對(duì)一張table 創(chuàng)建primay key過程中發(fā)生了斷電,當(dāng)電腦再次啟動(dòng)時(shí)候,發(fā)現(xiàn)mysql 服務(wù)無法啟動(dòng),使用 net start 提示 1067錯(cuò)誤,折騰了2個(gè)小時(shí)無法解決,后來只能通過手工刪除數(shù)據(jù)文件,日志文件,再啟動(dòng)服務(wù),然后導(dǎo)入數(shù)據(jù)來完成2013-01-01MySQL essential版本和普通版本有什么區(qū)別?
安裝mysql的朋友可能會(huì)發(fā)現(xiàn)有時(shí)候我們看到essential版本,究竟與其它mysql版本有什么區(qū)別呢,這里簡(jiǎn)單介紹下2013-06-06MySQL優(yōu)化之如何了解SQL的執(zhí)行頻率
MySQL 客戶端連接成功后,通過 show [session|global]status 命令 可以提供服務(wù)器狀態(tài)信息,也可以在操作系統(tǒng)上使用 mysqladmin extended-status 命令獲得這些消息2014-05-05更改MySQL數(shù)據(jù)庫的編碼為utf8mb4問題
這篇文章主要介紹了更改MySQL數(shù)據(jù)庫的編碼為utf8mb4問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11M1芯片安裝mysql8.0數(shù)據(jù)庫的實(shí)現(xiàn)步驟(圖文)
這篇文章主要介紹了M1芯片安裝mysql8.0數(shù)據(jù)庫的實(shí)現(xiàn)實(shí)現(xiàn)步驟,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02