基于Galera Cluster多主结构的Mysql高可用集群
Galera Cluster特点
1、多主架构:真正的多点读写的集群,在任何时候读写数据,都是最新的 2、同步复制:集群不同节点之间数据同步,没有延迟,在数据库挂掉之后,数据不会丢失 3、并发复制:从节点APPLY数据时,支持并行执行,更好的性能 4、故障切换:在出现数据库故障时,因支持多点写入,切换容易 5、热插拔:在服务期间,如果数据库挂了,只要监控程序发现的够快,不可服务时间就会非常少。在节点故障期间,节点本身对集群的影响非常小 6、自动节点克隆:在新增节点,或者停机维护时,增量数据或者基础数据不需要人工手动备份提供,Galera Cluster会自动拉取在线节点数据,最终集群会变为一致 7、对应用透明:集群的维护,对应用程序是透明的
Galera Cluster工作过程
客户端发送更新指令到mysql服务器,服务器回复OK,但客户端有可能以事务方式执行,并没有发送确认指令(commit);当客户端发送commit指令确认后,mysql服务器会把数据库的更新复制到同一个集群的其他节点;集群中的所有节点会对数据库的更新进行校验,检查更新完的数据与数据库中的数据是否冲突,如果不冲突,服务器端会回复OK;如果更新的数据与集群中的任意一个节点数据发生冲突,则都会回复error
实现Galera Cluster集群
至少需要三台机器;并且Galera Cluster也是一个数据库服务,下载Galera Cluster必须卸载服务器现有的mysql数据库服务
master1配置
[root@centos7 ~]# vim /etc/yum.repos.d/base.repo #编辑yum源仓库 [mysql] name=mysql baseurl=https://mirrors.tuna.tsinghua.edu.cn/mariadb/mariadb-10.0.38/yum/centos7-amd64/ gpgcheck=0 enabled=1 [root@centos7 ~]# scp /etc/yum.repos.d/base.repo 192.168.38.37:/etc/yum.repos.d/mysql.repo #发送给另外两个主节点 [root@centos7 ~]# scp /etc/yum.repos.d/base.repo 192.168.38.47:/etc/yum.repos.d/mysql.repo [root@centos7 ~]# yum install MariaDB-Galera-server -y [root@centos7 ~]# vim /etc/my.cnf.d/server.cnf #编辑galera配置文件 [galera] wsrep_provider=/usr/lib64/galera/libgalera_smm.so #启用galera模块 wsrep_cluster_address="gcomm://192.168.38.7,192.168.38.37,192.168.38.47" #指定集群中节点的IP binlog_format=row #二进制日志格式必须为行 default_storage_engine=InnoDB #存储引擎 innodb_autoinc_lock_mode=2 bind-address=0.0.0.0 #绑定本机的所有IP wsrep_cluster_name='mycluster' #设置集群名 wsrep_node_name='node1' #设置节点名 wsrep_node_address='192.168.38.7' #指定本节点的IP [root@centos7 ~]# service mysql start --wsrep-new-cluster #第一次启动,三个节点中必须有一个节点添加--wsrep-new-cluster参数启动
master2
[root@localhost ~]# yum install MariaDB-Galera-server -y #yum源不用配,前面master1主节点已经把yum源和galera配置文件发送到所有节点中 [root@localhost ~]# vim /etc/my.cnf.d/server.cnf [galera] wsrep_cluster_name='mycluster' #上面的galera信息不用修改,修改一下本节点的信息 wsrep_node_name='node2' wsrep_node_address='192.168.38.37' [root@localhost ~]# service mysql start
master3
[root@localhost ~]# yum install MariaDB-Galera-server -y [root@localhost ~]# vim /etc/my.cnf.d/server.cnf [galera] wsrep_cluster_name='mycluster' wsrep_node_name='node3' wsrep_node_address='192.168.38.47' [root@localhost ~]# service mysql start
在一个主节点更新数据,会同步到这个集群的其他主节点上;但是假如三个主节点同时创建一张db1表,会发现有两个主节点报错,一个主节点成功;这个就是galera cluster的工作特性;最先执行创建表的主节点询问其余主节点数据是否发生冲突,不发生冲突则创建表,一个主节点成功创建了db1表,其余两个主节点创建的时候也回去询问,但是有一主节点已经创建完毕,所以会发生数据冲突,则其余两个主节点都会报错
SHOW VARIABLES LIKE 'wsrep_%'; #可以在mysql中查询集群的相关状态信息 SHOW STATUS LIKE 'wsrep_%'; SHOW STATUS LIKE 'wsrep_cluster_size';
往现有集群中添加一个主节点master4
通过master1,把yum源仓库文件和galera的配置文件都拷贝给master4
[root@localhost ~]# yum install MariaDB-Galera-server -y [root@localhost ~]# vim /etc/my.cnf.d/server.cnf [galera] wsrep_cluster_address="gcomm://192.168.38.7,192.168.38.37,192.168.38.47,192.168.38.57" #把新的节点master4的IP添加上去 wsrep_cluster_name='mycluster' wsrep_node_name='node4' wsrep_node_address='192.168.38.57' [root@localhost ~]# service mysql start
其余所有节点的galera的配置文件都需要添加新的主节点的IP,添加完之后重启服务
[root@localhost ~]# vim /etc/my.cnf.d/server.cnf wsrep_cluster_address="gcomm://192.168.38.7,192.168.38.37,192.168.38.47,192.168.38.57" [root@localhost ~]# service mysql restart [root@localhost ~]# mysql -e 'SHOW STATUS LIKE "wsrep_cluster_size";' #集群中有4个节点 +--------------------+-------+ | Variable_name | Value | +--------------------+-------+ | wsrep_cluster_size | 4 | +--------------------+-------+
版权声明:本文为dongzhanyi123原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。