MySQL集群技术在分布式系统中为MySQL数据提供了冗余特性,增强了安全性,使得单个MySQL服务器故障不会对系统产生巨大的负面效应,系统的稳定性得到保障。

mysql集群和主从复制的区别:   集群:nothing-sharing  同步     主从:data-sharing  异步

mysql集群节点: 管理节点    数据节点   sql节点

管理节点:

数据节点:  负责存储数据

SQL节点:  通过它进行sql操作

                        三个节点的启动顺序为:管理节点,数据节点,sql节点   管理节点为一个,数据节点和sql节点配置多个

mysql集群存储数据过程:

                   1.     Mysqlcluster数据节点组内主从同步采用的是同步复制,来保证组内节点数据的一致性。一般通过两阶段提交 协议来实现,一般工作过程如                              下

                            a、Master执行提交语句时,事物被发送到Slave,slave开始准备事务的提交。

                            b、每个slave都要准备事务,然后向Master发送OK或者ABORT表明事务已经准备好或者无法准备该事务。

                            c、Master等待所以Slave发送OK或ABORT消息

                            d、如果Master收到所有 Slave的OK消息,它就会向所有Slave发送提交消息,告诉Slave提交该事务;

                                 如果Master收到来自任何一个Slave的ABORT消息,它就向所有 Slave发送ABORT消息,告诉Slave去中止事务。

                            e、每个Slave等待来自Master的OK或ABORT消息。

                                 如果Slave收到提交请求,它们就会提交事务,并向Master发送事务已提交 的确认;

                                 如果Slave收到取消请求,它们就会撤销所有改变并释放所占有的资源,从而中止事务,然后向Masterv送事务已中止的确认。

                             f、 当Master收到来自所有Slave的确认后,就会报告该事务被提交(或中止),然后继续进行下一个事务处理。

 由于同步复制一共需要4次消息传递,故mysql  cluster的数据更新速度比单机mysql要慢。

               2.           Mysqlcluster将所有的索引列都保存在主存中,其他非索引列可以存储在内存中或者通过建立表空间存储到磁盘上。如果数据发生改变

                             insert,update,delete等),mysql 集群将发生改变的记录写入重做日志,然后通过检查点定期将数据定入磁盘。由于重做日志是异步提交  

                            的,所以故障期间可能有少量事务丢失。为了减少事务丢失,mysql集群实现延迟写入(默认延迟两秒,可配置),这样就可以在故障发生时

                            完成检查点写入,而不会丢失最后一个检查点。一般单个数据节点故障不会导致任何数据丢失,因为集群内部采用同步数据复制。