基于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 |
+--------------------+-------+
基于Galera Cluster多主结构的Mysql高可用集群的更多相关文章
- Mysql 高可用集群PXC
PXC是percona公司的percona xtraDB cluster,简称PXC.它是基于Galera协议的高可用集群方案.可以实现多个节点间的数据同步复制以及读写,并且可保障数据库的服务高可 ...
- MySQL高可用集群方案
一.Mysql高可用解决方案 方案一:共享存储 一般共享存储采用比较多的是 SAN/NAS 方案. 方案二:操作系统实时数据块复制 这个方案的典型场景是 DRBD,DRBD架构(MySQL+DRBD+ ...
- MySQL高可用集群MHA方案
MySQL高可用集群MHA方案 爱奇艺在用的数据库高可用方案 MHA 是目前比较成熟及流行的 MySQL 高可用解决方案,很多互联网公司正是直接使用或者基于 MHA 的架构进行改造实现 MySQL 的 ...
- Mysql高可用集群环境介绍
MySQL高可用集群环境搭建 01.MySQL高可用环境方案 02.MySQL主从复制原理 03.MySQL主从复制作用 04.在Linux环境上安装MySQL 05.在MySQL集群环境上配置主从复 ...
- 部署MYSQL高可用集群
mysql-day08 部署MYSQL高可用集群 u 集群架构 ...
- heatbeat-gui实现基于nfs的mysql高可用集群
一.简述HA高可用集群 高可用集群就是当集群中的一个节点发生各种软硬件及人为故障时,集群中的其他节点能够自动接管故障节点的资源并向外提供服务.以实现减少业务中断时间,为用户提供更可靠,更高效的服务. ...
- keepalived+MySQL高可用集群
基于keepalived搭建MySQL的高可用集群 MySQL的高可用方案一般有如下几种: keepalived+双主,MHA,MMM,Heartbeat+DRBD,PXC,Galera Clus ...
- corosync+pacemaker and drbd实现mysql高可用集群
DRBD:Distributed Replicated Block Device 分布式复制块设备,原理图如下 DRBD 有主双架构和双主架构的,当处于主从架构时,这个设备一定只有一个节点是可以读写的 ...
- MYSQL高可用集群架构-MHA架构
1 MHA简介:MHA(Master High Availability)目前在MySQL高可用方面是一个相对成熟的解决方案,它由日本DeNA公司youshimaton(现就职于Facebook公司 ...
随机推荐
- java.sql.SQLException: Access denied for user 'root'@'localhost' (using password: NO)报错
今天用spring整合mybatis的时候,报了这个错误.去网上查了一下,网上大多数都是用户权限问题,但是我用SQLyog视图使用root用户crud没有问题,排除了是权限的问题,后面发现是idea提 ...
- jQuery选择器 大于 空格 波浪线 加号
JQuery选择器 大于 空格 波浪线 加号的区别 元素遍历 符号 说明 空格 $(‘parent child’)表示获取parent下的所有的child节点(所有的子孙). 大于号 $(‘paren ...
- (记录)Ubuntu系统中运行需要导入jar包的Java程序
在学习Redis的过程中,在学到Redis客户端Jedis的时候,考虑到能不能在ubuntu下用Vim编写Java程序并且能够运行呢? 于是,首先在网上调研了一番用Vim写Java程序的可实现性. 相 ...
- Spring Cloud alibaba网关 sentinel zuul 四 限流熔断
spring cloud alibaba 集成了 他内部开源的 Sentinel 熔断限流框架 Sentinel 介绍 官方网址 随着微服务的流行,服务和服务之间的稳定性变得越来越重要.Sentine ...
- 完美解决Python与anaconda之间的冲突问题
anaconda指的是一个开源的Python发行版本,其包含了conda.Python等180多个科学包及其依赖项.因为包含了大量的科学包,Anaconda 的下载文件比较大(约 515 MB),如果 ...
- python:__name__的使用
1.python中__name__是什么意思? 很多python的初学者可能都会遇到一个问题:__name__是什么意思? 在刚开始学习python的时候,我们总会看到这样一句代码: if __nam ...
- 虚拟机linux centos7 查找ip不到的设置
1.centos7 系统后查找ip信息,不用ifconfig -a 命令,开始使用ip Addr命令 输入ip Addr 命令后,并没有看到实际的ip地址,记住上述图片中红色标记的ens32 这个就是 ...
- 大前端技术系列:TWA技术+TensorFlow.js => 集成原生和AI功能的app
大前端技术系列:TWA技术+TensorFlow.js => 集成原生和AI功能的app ( 本文内容为melodyWxy原作,git地址:https://github.com/melodyWx ...
- 为什么磁盘慢会导致Linux负载飙升?
一.CPU利用率和负载率的区别 这里要区别CPU负载和CPU利用率,它们是不同的两个概念,但它们的信息可以在同一个top命令中进行显示.CPU利用率显示的是程序在运行期间实时占用的CPU百分比,这是对 ...
- MIT线性代数:9.线性相关,基,维数。