分享

MySQL常用集群方案---PXC /Repliaction

 夜空小雄 2018-12-23
了解 MySQL 集群之前,先看看单节点数据库的弊病:

大型互联网程序用户群体庞大,所以架构需要特殊设计。
单节点数据库无法满足大并发时性能上的要求。
单节点的数据库没有冗余设计,无法满足高可用。
单节点 MySQL无法承载巨大的业务量,数据库负载巨大。
一、常见 MySQL 集群方案
Repliaction 集群方案
PXC 集群方案( Percona XtraDB Cluster )
两种集群方案特性如下图: 
 
 

二、PXC方案 和 Replication方案对比 
1. 先看看 PXC方案 
  
 
很明显 PXC方案在任何一个节点写入的数据都会同步到其他节点,数据双向同步的(在任何节点上都可以同时读写)。

2. Replication 集群方案: 
  
 
Replication方案只能在Master数据库进行写操作,在Slave数据库进行读操作。如果在Slave数据库中写入数据,Master数据库是不能知道的(单向同步的)。

3. PXC 数据的强一致性

PXC 采用同步复制,事务在所有集群节点要么同时提交,要么不提交。 
Replication 采用异步复制,无法保证数据的一致性。

下面看看 PXC写入操作: 
  
 
当一个写入请求到达PXC集群中的一个 mysql(node1数据库) 数据库时,node1数据库会将该写入请求同步给集群中的其他所有数据库,等待所有数据库都成功提交事务后,node1节点才会将写入成功的结果告诉给 node1的客户端。

PXC 的强一致性对保存高价值数据时特别重要。

在看Replication集群写入操作: 
  
 
当一个写入请求到达 Master数据库时,Master数据库执行写入操作,然后 Master 向客户端返回写入成功,同时异步的复制写入操作给 Slave数据库,如果异步复制时出现问题,从数据库将无法执行写入操作,而客户端得到的是写入成功。这也是弱一致性的体现。

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多