热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

基于GaleraCluster多主结构的Mysql高可用集群

GaleraCluster特点1、多主架构:真正的多点读写的集群,在任何时候读写数据,都是最新的2、同步复制:集群不同节点之间数据同步,没有延迟,在数据库挂掉之后,数据不会丢失3、

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     |
+--------------------+-------+

基于Galera Cluster多主结构的Mysql高可用集群


推荐阅读
  • Voicewo在线语音识别转换jQuery插件的特点和示例
    本文介绍了一款名为Voicewo的在线语音识别转换jQuery插件,该插件具有快速、架构、风格、扩展和兼容等特点,适合在互联网应用中使用。同时还提供了一个快速示例供开发人员参考。 ... [详细]
  • 本文内容为asp.net微信公众平台开发的目录汇总,包括数据库设计、多层架构框架搭建和入口实现、微信消息封装及反射赋值、关注事件、用户记录、回复文本消息、图文消息、服务搭建(接入)、自定义菜单等。同时提供了示例代码和相关的后台管理功能。内容涵盖了多个方面,适合综合运用。 ... [详细]
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • Windows下配置PHP5.6的方法及注意事项
    本文介绍了在Windows系统下配置PHP5.6的步骤及注意事项,包括下载PHP5.6、解压并配置IIS、添加模块映射、测试等。同时提供了一些常见问题的解决方法,如下载缺失的msvcr110.dll文件等。通过本文的指导,读者可以轻松地在Windows系统下配置PHP5.6,并解决一些常见的配置问题。 ... [详细]
  • 本文介绍了C#中数据集DataSet对象的使用及相关方法详解,包括DataSet对象的概述、与数据关系对象的互联、Rows集合和Columns集合的组成,以及DataSet对象常用的方法之一——Merge方法的使用。通过本文的阅读,读者可以了解到DataSet对象在C#中的重要性和使用方法。 ... [详细]
  • 解决VS写C#项目导入MySQL数据源报错“You have a usable connection already”问题的正确方法
    本文介绍了在VS写C#项目导入MySQL数据源时出现报错“You have a usable connection already”的问题,并给出了正确的解决方法。详细描述了问题的出现情况和报错信息,并提供了解决该问题的步骤和注意事项。 ... [详细]
  • Java验证码——kaptcha的使用配置及样式
    本文介绍了如何使用kaptcha库来实现Java验证码的配置和样式设置,包括pom.xml的依赖配置和web.xml中servlet的配置。 ... [详细]
  • 本文介绍了指针的概念以及在函数调用时使用指针作为参数的情况。指针存放的是变量的地址,通过指针可以修改指针所指的变量的值。然而,如果想要修改指针的指向,就需要使用指针的引用。文章还通过一个简单的示例代码解释了指针的引用的使用方法,并思考了在修改指针的指向后,取指针的输出结果。 ... [详细]
  • CSS标签、类名和ID选择器的使用区别
    本文讲解了CSS中标签选择器、类名选择器和ID选择器的使用区别,主要包括加空格和不加空格的区别。通过示例代码,说明了加空格表示选择当前节点的后代节点,而不加空格表示一个元素的多个类名不能加空格的规则。 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • Mac OS 升级到11.2.2 Eclipse打不开了,报错Failed to create the Java Virtual Machine
    本文介绍了在Mac OS升级到11.2.2版本后,使用Eclipse打开时出现报错Failed to create the Java Virtual Machine的问题,并提供了解决方法。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文详细介绍了Linux中进程控制块PCBtask_struct结构体的结构和作用,包括进程状态、进程号、待处理信号、进程地址空间、调度标志、锁深度、基本时间片、调度策略以及内存管理信息等方面的内容。阅读本文可以更加深入地了解Linux进程管理的原理和机制。 ... [详细]
author-avatar
sylvia
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有