真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

mysql集群方案詳解

本文主要給大家簡(jiǎn)單講講MySQL集群方案詳解,相關(guān)專業(yè)術(shù)語(yǔ)大家可以上網(wǎng)查查或者找一些相關(guān)書籍補(bǔ)充一下,這里就不涉獵了,我們就直奔mysql集群方案詳解主題吧,希望可以給大家?guī)?lái)一些實(shí)際幫助。

為雞東等地區(qū)用戶提供了全套網(wǎng)頁(yè)設(shè)計(jì)制作服務(wù),及雞東網(wǎng)站建設(shè)行業(yè)解決方案。主營(yíng)業(yè)務(wù)為網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè)、雞東網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠(chéng)的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長(zhǎng)期合作。這樣,我們也可以走得更遠(yuǎn)!

集群的好處

  • 高可用性:故障檢測(cè)及遷移,多節(jié)點(diǎn)備份。
  • 可伸縮性:新增數(shù)據(jù)庫(kù)節(jié)點(diǎn)便利,方便擴(kuò)容。
  • 負(fù)載均衡:切換某服務(wù)訪問(wèn)某節(jié)點(diǎn),分?jǐn)倖蝹€(gè)節(jié)點(diǎn)的數(shù)據(jù)庫(kù)壓力。

集群要考慮的風(fēng)險(xiǎn)

  • 網(wǎng)絡(luò)分裂:群集還可能由于網(wǎng)絡(luò)故障而拆分為多個(gè)部分,每部分內(nèi)的節(jié)點(diǎn)相互連接,但各部分之間的節(jié)點(diǎn)失去連接。
  • 腦裂:導(dǎo)致數(shù)據(jù)庫(kù)節(jié)點(diǎn)彼此獨(dú)立運(yùn)行的集群故障稱為“腦裂”。這種情況可能導(dǎo)致數(shù)據(jù)不一致,并且無(wú)法修復(fù),例如當(dāng)兩個(gè)數(shù)據(jù)庫(kù)節(jié)點(diǎn)獨(dú)立更新同一表上的同一行時(shí)。

@[toc]

一,mysql原廠出品

1,MySQL Replication

mysql復(fù)制(MySQL Replication),是mysql自帶的功能。

原理簡(jiǎn)介:

主從復(fù)制是通過(guò)重放binlog實(shí)現(xiàn)主庫(kù)數(shù)據(jù)的異步復(fù)制。即當(dāng)主庫(kù)執(zhí)行了一條sql命令,那么在從庫(kù)同樣的執(zhí)行一遍,從而達(dá)到主從復(fù)制的效果。在這個(gè)過(guò)程中,master對(duì)數(shù)據(jù)的寫操作記入二進(jìn)制日志文件中(binlog),生成一個(gè) log dump 線程,用來(lái)給從庫(kù)的 i/o線程傳binlog。而從庫(kù)的i/o線程去請(qǐng)求主庫(kù)的binlog,并將得到的binlog日志寫到中繼日志(relaylog)中,從庫(kù)的sql線程,會(huì)讀取relaylog文件中的日志,并解析成具體操作,通過(guò)主從的操作一致,而達(dá)到最終數(shù)據(jù)一致。

mysql集群方案詳解

MySQL Replication一主多從的結(jié)構(gòu),主要目的是實(shí)現(xiàn)數(shù)據(jù)的多點(diǎn)備份(沒(méi)有故障自動(dòng)轉(zhuǎn)移和負(fù)載均衡)。相比于單個(gè)的mysql,一主多從下的優(yōu)勢(shì)如下:

  • 如果讓后臺(tái)讀操作連接從數(shù)據(jù)庫(kù),讓寫操作連接主數(shù)據(jù)庫(kù),能起到讀寫分離的作用,這個(gè)時(shí)候多個(gè)從數(shù)據(jù)庫(kù)可以做負(fù)載均衡。
  • 可以在某個(gè)從數(shù)據(jù)庫(kù)中暫時(shí)中斷復(fù)制進(jìn)程,來(lái)備份數(shù)據(jù),從而不影響主數(shù)據(jù)的對(duì)外服務(wù)(如果在master上執(zhí)行backup,需要讓master處于readonly狀態(tài),這也意味這所有的write請(qǐng)求需要阻塞)。

就各個(gè)集群方案來(lái)說(shuō),其優(yōu)勢(shì)為:

  • 主從復(fù)制是mysql自帶的,無(wú)需借助第三方。
  • 數(shù)據(jù)被刪除,可以從binlog日志中恢復(fù)。
  • 配置較為簡(jiǎn)單方便。

其劣勢(shì)為:

  • 從庫(kù)要從binlog獲取數(shù)據(jù)并重放,這肯定與主庫(kù)寫入數(shù)據(jù)存在時(shí)間延遲,因此從庫(kù)的數(shù)據(jù)總是要滯后主庫(kù)。
  • 對(duì)主庫(kù)與從庫(kù)之間的網(wǎng)絡(luò)延遲要求較高,若網(wǎng)絡(luò)延遲太高,將加重上述的滯后,造成最終數(shù)據(jù)的不一致。
  • 單一的主節(jié)點(diǎn)掛了,將不能對(duì)外提供寫服務(wù)。
2,MySQL Fabirc

mysql織物(MySQL Fabirc),是mysql官方提供的。

這是在MySQL Replication的基礎(chǔ)上,增加了故障檢測(cè)與轉(zhuǎn)移,自動(dòng)數(shù)據(jù)分片功能。不過(guò)依舊是一主多從的結(jié)構(gòu),MySQL Fabirc只有一個(gè)主節(jié)點(diǎn),區(qū)別是當(dāng)該主節(jié)點(diǎn)掛了以后,會(huì)從從節(jié)點(diǎn)中選擇一個(gè)來(lái)當(dāng)主節(jié)點(diǎn)。

就各個(gè)集群方案來(lái)說(shuō),其優(yōu)勢(shì)為:

  • mysql官方提供的工具,無(wú)需第三方插件。
  • 數(shù)據(jù)被刪除,可以從binlog日志中恢復(fù)。
  • 主節(jié)點(diǎn)掛了以后,能夠自動(dòng)從從節(jié)點(diǎn)中選擇一個(gè)來(lái)當(dāng)主節(jié)點(diǎn),不影響持續(xù)對(duì)外提供寫服務(wù)。

其劣勢(shì)為:

  • 從庫(kù)要從binlog獲取數(shù)據(jù)并重放,這肯定與主庫(kù)寫入數(shù)據(jù)存在時(shí)間延遲,因此從庫(kù)的數(shù)據(jù)總是要滯后主庫(kù)。
  • 對(duì)主庫(kù)與從庫(kù)之間的網(wǎng)絡(luò)延遲要求較高,若網(wǎng)絡(luò)延遲太高,將加重上述的滯后,造成最終數(shù)據(jù)的不一致。
  • 2014年5月推出的產(chǎn)品,數(shù)據(jù)庫(kù)資歷較淺,應(yīng)用案例不多,網(wǎng)上各種資料相對(duì)較少。
  • 事務(wù)及查詢只支持在同一個(gè)分片內(nèi),事務(wù)中更新的數(shù)據(jù)不能跨分片,查詢語(yǔ)句返回的數(shù)據(jù)也不能跨分片。
  • 節(jié)點(diǎn)故障恢復(fù)30秒或更長(zhǎng)(采用InnoDB存儲(chǔ)引擎的都這樣)。
3,MySQL Cluster

mysql集群(MySQL Cluster)也是mysql官方提供的。

MySQL Cluster是多主多從結(jié)構(gòu)的

就各個(gè)集群方案來(lái)說(shuō),其優(yōu)勢(shì)為:

  • mysql官方提供的工具,無(wú)需第三方插件。
  • 高可用性優(yōu)秀,99.999%的可用性,可以自動(dòng)切分?jǐn)?shù)據(jù),能跨節(jié)點(diǎn)冗余數(shù)據(jù)(其數(shù)據(jù)集并不是存儲(chǔ)某個(gè)特定的MySQL實(shí)例上,而是被分布在多個(gè)Data Nodes中,即一個(gè)table的數(shù)據(jù)可能被分散在多個(gè)物理節(jié)點(diǎn)上,任何數(shù)據(jù)都會(huì)在多個(gè)Data Nodes上冗余備份。任何一個(gè)數(shù)據(jù)變更操作,都將在一組Data Nodes上同步,以保證數(shù)據(jù)的一致性)。
  • 可伸縮性優(yōu)秀,能自動(dòng)切分?jǐn)?shù)據(jù),方便數(shù)據(jù)庫(kù)的水平拓展。
  • 負(fù)載均衡優(yōu)秀,可同時(shí)用于讀操作、寫操作都都密集的應(yīng)用,也可以使用SQL和NOSQL接口訪問(wèn)數(shù)據(jù)。
  • 多個(gè)主節(jié)點(diǎn),沒(méi)有單點(diǎn)故障的問(wèn)題,節(jié)點(diǎn)故障恢復(fù)通常小于1秒。

其劣勢(shì)為:

  • 架構(gòu)模式和原理很復(fù)雜。
  • 只能使用存儲(chǔ)引擎 NDB ,與平常使用的InnoDB 有很多明顯的差距。比如在事務(wù)(其事務(wù)隔離級(jí)別只支持Read Committed,即一個(gè)事務(wù)在提交前,查詢不到在事務(wù)內(nèi)所做的修改),外鍵(雖然最新的NDB 存儲(chǔ)引擎已經(jīng)支持外鍵,但性能有問(wèn)題,因?yàn)橥怄I所關(guān)聯(lián)的記錄可能在別的分片節(jié)點(diǎn)),表限制上的不同,可能會(huì)導(dǎo)致日常開發(fā)出現(xiàn)意外。點(diǎn)擊查看具體差距比較
  • 作為分布式的數(shù)據(jù)庫(kù)系統(tǒng),各個(gè)節(jié)點(diǎn)之間存在大量的數(shù)據(jù)通訊,比如所有訪問(wèn)都是需要經(jīng)過(guò)超過(guò)一個(gè)節(jié)點(diǎn)(至少有一個(gè) SQL Node和一個(gè) NDB Node)才能完成,因此對(duì)節(jié)點(diǎn)之間的內(nèi)部互聯(lián)網(wǎng)絡(luò)帶寬要求高。
  • Data Node數(shù)據(jù)會(huì)被盡量放在內(nèi)存中,對(duì)內(nèi)存要求大,而且重啟的時(shí)候,數(shù)據(jù)節(jié)點(diǎn)將數(shù)據(jù)load到內(nèi)存需要很長(zhǎng)時(shí)間。

官方的三兄弟的區(qū)別對(duì)比如下圖所示;

mysql集群方案詳解

二,mysql第三方優(yōu)化

4,MMM

MMM是在MySQL Replication的基礎(chǔ)上,對(duì)其進(jìn)行優(yōu)化。

MMM(Master Replication Manager for MySQL)是雙主多從結(jié)構(gòu),這是Google的開源項(xiàng)目,使用Perl語(yǔ)言來(lái)對(duì)MySQL Replication做擴(kuò)展,提供一套支持雙主故障切換和雙主日常管理的腳本程序,主要用來(lái)監(jiān)控mysql主主復(fù)制并做失敗轉(zhuǎn)移。

mysql集群方案詳解
注意:這里的雙主節(jié)點(diǎn),雖然叫做雙主復(fù)制,但是業(yè)務(wù)上同一時(shí)刻只允許對(duì)一個(gè)主進(jìn)行寫入,另一臺(tái)備選主上提供部分讀服務(wù),以加速在主主切換時(shí)刻備選主的預(yù)熱。

就各個(gè)集群方案來(lái)說(shuō),其優(yōu)勢(shì)為:

  • 自動(dòng)的主主Failover切換,一般3s以內(nèi)切換備機(jī)。
  • 多個(gè)從節(jié)點(diǎn)讀的負(fù)載均衡。

其劣勢(shì)為:

  • 無(wú)法完全保證數(shù)據(jù)的一致性。如主1掛了,MMM monitor已經(jīng)切換到主2上來(lái)了,而若此時(shí)雙主復(fù)制中,主2數(shù)據(jù)落后于主1(即還未完全復(fù)制完畢),那么此時(shí)的主2已經(jīng)成為主節(jié)點(diǎn),對(duì)外提供寫服務(wù),從而導(dǎo)致數(shù)據(jù)不一。
  • 由于是使用虛擬IP浮動(dòng)技術(shù),類似Keepalived,故RIP(真實(shí)IP)要和VIP(虛擬IP)在同一網(wǎng)段。如果是在不同網(wǎng)段也可以,需要用到虛擬路由技術(shù)。但是絕對(duì)要在同一個(gè)IDC機(jī)房,不可跨IDC機(jī)房組建集群。
5,MHA

MHA是在MySQL Replication的基礎(chǔ)上,對(duì)其進(jìn)行優(yōu)化。

MHA(Master High Availability)是多主多從結(jié)構(gòu),這是日本DeNA公司的youshimaton開發(fā),主要提供更多的主節(jié)點(diǎn),但是缺少VIP(虛擬IP),需要配合keepalived等一起使用。

要搭建MHA,要求一個(gè)復(fù)制集群中必須最少有三臺(tái)數(shù)據(jù)庫(kù)服務(wù)器,一主二從,即一臺(tái)充當(dāng)master,一臺(tái)充當(dāng)備用master,另外一臺(tái)充當(dāng)從庫(kù)。

mysql集群方案詳解

就各個(gè)集群方案來(lái)說(shuō),其優(yōu)勢(shì)為:

  • 可以進(jìn)行故障的自動(dòng)檢測(cè)和轉(zhuǎn)移
  • 具備自動(dòng)數(shù)據(jù)補(bǔ)償能力,在主庫(kù)異常崩潰時(shí)能夠最大程度的保證數(shù)據(jù)的一致性。

其劣勢(shì)為:

  • MHA架構(gòu)實(shí)現(xiàn)讀寫分離,最佳實(shí)踐是在應(yīng)用開發(fā)設(shè)計(jì)時(shí)提前規(guī)劃讀寫分離事宜,在使用時(shí)設(shè)置兩個(gè)連接池,即讀連接池與寫連接池,也可以選擇折中方案即引入SQL Proxy。但無(wú)論如何都需要改動(dòng)代碼;

  • 關(guān)于讀負(fù)載均衡可以使用F5、LVS、HAPROXY或者SQL Proxy等工具,只要能實(shí)現(xiàn)負(fù)載均衡、故障檢查及備升級(jí)為主后的讀寫剝離功能即可,建議使用LVS
6,Galera Cluster

Galera Cluster是由Codership開發(fā)的MySQL多主結(jié)構(gòu)集群,這些主節(jié)點(diǎn)互為其它節(jié)點(diǎn)的從節(jié)點(diǎn)。不同于MySQL原生的主從異步復(fù)制,Galera采用的是多主同步復(fù)制,并針對(duì)同步復(fù)制過(guò)程中,會(huì)大概率出現(xiàn)的事務(wù)沖突和死鎖進(jìn)行優(yōu)化,就是復(fù)制不基于官方binlog而是Galera復(fù)制插件,重寫了wsrep api。

異步復(fù)制中,主庫(kù)將數(shù)據(jù)更新傳播給從庫(kù)后立即提交事務(wù),而不論從庫(kù)是否成功讀取或重放數(shù)據(jù)變化。這種情況下,在主庫(kù)事務(wù)提交后的短時(shí)間內(nèi),主從庫(kù)數(shù)據(jù)并不一致。

同步復(fù)制時(shí),主庫(kù)的單個(gè)更新事務(wù)需要在所有從庫(kù)上同步                                                                     更新。換句話說(shuō),當(dāng)主庫(kù)提交事務(wù)時(shí),集群中所有節(jié)點(diǎn)的數(shù)據(jù)保持一致。

對(duì)于讀操作,從每個(gè)節(jié)點(diǎn)讀取到的數(shù)據(jù)都是相同的。對(duì)于寫操作,當(dāng)數(shù)據(jù)寫入某一節(jié)點(diǎn)后,集群會(huì)將其同步到其它節(jié)點(diǎn)。

mysql集群方案詳解

就各個(gè)集群方案來(lái)說(shuō),其優(yōu)勢(shì)為:

  • 多主多活下,可對(duì)任一節(jié)點(diǎn)進(jìn)行讀寫操作,就算某個(gè)節(jié)點(diǎn)掛了,也不影響其它的節(jié)點(diǎn)的讀寫,都不需要做故障切換操作,也不會(huì)中斷整個(gè)集群對(duì)外提供的服務(wù)。
  • 拓展性優(yōu)秀,新增節(jié)點(diǎn)會(huì)自動(dòng)拉取在線節(jié)點(diǎn)的數(shù)據(jù)(當(dāng)有新節(jié)點(diǎn)加入時(shí),集群會(huì)選擇出一個(gè)Donor Node為新節(jié)點(diǎn)提供數(shù)據(jù)),最終集群所有節(jié)點(diǎn)數(shù)據(jù)一致,而不需要手動(dòng)備份恢復(fù)。

其劣勢(shì)為:

  • 能做到數(shù)據(jù)的強(qiáng)一致性,毫無(wú)疑問(wèn),也是以犧牲性能為代價(jià)。

三,依托硬件配合

不同主機(jī)的數(shù)據(jù)同步不再依賴于MySQL的原生復(fù)制功能,而是通過(guò)同步磁盤數(shù)據(jù),來(lái)保證數(shù)據(jù)的一致性。

然后處理故障的方式是借助Heartbeat,它監(jiān)控和管理各個(gè)節(jié)點(diǎn)間連接的網(wǎng)絡(luò),并監(jiān)控集群服務(wù),當(dāng)節(jié)點(diǎn)出現(xiàn)故障或者服務(wù)不可用時(shí),自動(dòng)在其他節(jié)點(diǎn)啟動(dòng)集群服務(wù)。

7,heartbeat+SAN

SAN:共享存儲(chǔ),主庫(kù)從庫(kù)用的一個(gè)存儲(chǔ)。SAN的概念是允許存儲(chǔ)設(shè)施和解決器(服務(wù)器)之間建立直接的高速連接,通過(guò)這種連接實(shí)現(xiàn)數(shù)據(jù)的集中式存儲(chǔ)。

mysql集群方案詳解
就各個(gè)集群方案來(lái)說(shuō),其優(yōu)勢(shì)為:

  • 保證數(shù)據(jù)的強(qiáng)一致性;

  • 與mysql解耦,不會(huì)由于mysql的邏輯錯(cuò)誤發(fā)生數(shù)據(jù)不一致的情況;

其劣勢(shì)為:

  • SAN價(jià)格昂貴;
8,heartbeat+DRDB

DRDB:這是linux內(nèi)核板塊實(shí)現(xiàn)的快級(jí)別的同步復(fù)制技術(shù)。通過(guò)各主機(jī)之間的網(wǎng)絡(luò),復(fù)制對(duì)方磁盤的內(nèi)容。當(dāng)客戶將數(shù)據(jù)寫入本地磁盤時(shí),還會(huì)將數(shù)據(jù)發(fā)送到網(wǎng)絡(luò)中另一臺(tái)主機(jī)的磁盤上,這樣的本地主機(jī)(主節(jié)點(diǎn))與遠(yuǎn)程主機(jī)(備節(jié)點(diǎn))的數(shù)據(jù)即可以保證明時(shí)同步。

mysql集群方案詳解
就各個(gè)集群方案來(lái)說(shuō),其優(yōu)勢(shì)為:

  • 相比于SAN儲(chǔ)存網(wǎng)絡(luò),價(jià)格低廉;

  • 保證數(shù)據(jù)的強(qiáng)一致性;
  • 與mysql解耦,不會(huì)由于mysql的邏輯錯(cuò)誤發(fā)生數(shù)據(jù)不一致的情況;

其劣勢(shì)為:

  • 對(duì)io性能影響較大;

  • 從庫(kù)不提供讀操作;

四,其它

9,Zookeeper + proxy

Zookeeper使用分布式算法保證集群數(shù)據(jù)的一致性,使用zookeeper可以有效的保證proxy的高可用性,可以較好的避免網(wǎng)絡(luò)分區(qū)現(xiàn)象的產(chǎn)生。

mysql集群方案詳解
就各個(gè)集群方案來(lái)說(shuō),其優(yōu)勢(shì)為:

  • 擴(kuò)展性較好,可以擴(kuò)展為大規(guī)模集群。

缺其劣勢(shì)為:

  • 搭建Zookeeper 集群,在配置一套代理,整個(gè)系統(tǒng)的邏輯變得更加復(fù)雜。
10,Paxos

分布式一致性算法,Paxos 算法處理的問(wèn)題是一個(gè)分布式系統(tǒng)如何就某個(gè)值(決議)達(dá)成一致。這個(gè)算法被認(rèn)為是同類算法中最有效的。Paxos與MySQL相結(jié)合可以實(shí)現(xiàn)在分布式的MySQL數(shù)據(jù)的強(qiáng)一致性。

mysql集群方案詳解就先給大家講到這里,對(duì)于其它相關(guān)問(wèn)題大家想要了解的可以持續(xù)關(guān)注我們的行業(yè)資訊。我們的板塊內(nèi)容每天都會(huì)捕捉一些行業(yè)新聞及專業(yè)知識(shí)分享給大家的。


分享標(biāo)題:mysql集群方案詳解
分享鏈接:http://weahome.cn/article/gopghh.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部