為什么需要MySQL集群
傳統(tǒng)數(shù)據(jù)庫(kù)單機(jī)單節(jié)點(diǎn),容災(zāi)性能差,例如數(shù)據(jù)庫(kù)掛掉,整個(gè)網(wǎng)站就會(huì)掛掉。單機(jī)單節(jié)點(diǎn)的數(shù)據(jù)庫(kù)性能差,抗并發(fā)能力有限。
PXC集群方案特點(diǎn)
PXC方案保證數(shù)據(jù)的強(qiáng)一致性,當(dāng)程序向PXC的一個(gè)節(jié)點(diǎn)寫入,先同步其它節(jié)點(diǎn),如果其它節(jié)點(diǎn)同步失敗會(huì)立即回滾返回給程序插入數(shù)據(jù)失敗,只有所有節(jié)點(diǎn)都同步成功才返回給程序插入數(shù)據(jù)成功,所以PXC可以保證各數(shù)據(jù)庫(kù)節(jié)點(diǎn)數(shù)據(jù)的強(qiáng)一致性。
PXC方案只支持Innodb類型同步
PXC集群方案與Replication區(qū)別
PXC集群方案所有節(jié)點(diǎn)都是可讀可寫的,Replication從節(jié)點(diǎn)不能寫入,因?yàn)橹鲝耐绞菃蜗虻?,無(wú)法從slave節(jié)點(diǎn)向master點(diǎn)同步。
PXC同步機(jī)制是同步進(jìn)行的,這也是它能保證數(shù)據(jù)強(qiáng)一致性的根本原因,Replication同步機(jī)制是異步進(jìn)行的,它如果從節(jié)點(diǎn)停止同步,依然可以向主節(jié)點(diǎn)插入數(shù)據(jù),正確返回,造成數(shù)據(jù)主從數(shù)據(jù)的不一致性。
PXC是用犧牲性能保證數(shù)據(jù)的一致性,Replication在性能上是高于PXC的。所以兩者用途也不一致。PXC是用于重要信息的存儲(chǔ),例如:訂單、用戶信息等。Replication用于一般信息的存儲(chǔ),能夠容忍數(shù)據(jù)丟失,例如:購(gòu)物車,用戶行為日志等