mysql MGR集群

介绍

MySQL Group Replication(简称MGR)是MySQL官方于2016年12月推出的一个全新的高可用与高扩展的解决方案。MySQL Group Replication提供了高可用、高扩展、高可靠的MySQL集群服务

MGR基础结构要求:

1、引擎必须为innodb,因为需事务支持在commit时对各节点进行冲突检查
2、每个表必须有主键,在进行事务冲突检测时需要利用主键值对比
3、必须开启binlog且为row格式
4、开启GTID,且主从状态信息存于表中(–master-info-repository=TABLE 、–relay-log-info-repository=TABLE),–log-slave-updates打开
5.一致性检测设置–transaction-write-set-extraction=XXHASH64

部署MGR集群

1.准备三台mysql,三台都设置hostname和ip映射
vim /etc/hosts 输入以下

192.168.100.10   master
192.168.100.20   slave1
192.168.100.30   slave2

2.配置master主配置文件
vim /etc/my.cnf 添加以下 ##红色部分修改组名和自己主机名

server_id=100  #服务ID
gtid_mode=ON  #全局事务
enforce_gtid_consistency=ON  #强制GTID的一致性
master_info_repository=TABLE  #将master.info元数据保存在系统表中
relay_log_info_repository=TABLE  #将relay.info元数据保存在系统表中
binlog_checksum=NONE  #禁用二进制日志事件校验
log_slave_updates=ON  #级联复制
log_bin=binlog   #开启二进制日志记录
binlog_format=ROW  #以行的格式记录
3.transaction_write_set_extraction=XXHASH64 #使用哈希算法将其编码为散列
loose-group_replication_group_name='ce9be252-2b71-11e6-b8f4-00212844f856' #加入的组名
loose-group_replication_start_on_boot=off     #不自动启用组复制集群
loose-group_replication_local_address='cong11:33061'
#以本机端口33061接受来自组中成员的传入连接
loose-group_replication_group_seeds='cong11:33061,cong12:33061,cong13:33061'
#组中成员访问表
loose-group_replication_bootstrap_group=off #不启用引导组

Uuidgen 可以自动生成组名
Systemctl restart mysqld ##重启
3,授权账户
进入mysql里

mysql> set SQL_LOG_BIN=0;   #停掉日志记录
mysql> grant replication slave on *.* to repl@' 192.168.1.%' identified by '123456';
mysql> flush privileges;
mysql> set SQL_LOG_BIN=1;  #开启日志记录
mysql>change master to master_user='repl',master_password='123456'  for channel 'group_replication_recovery';  #构建group replication集群,如果报错,重启mysql,再执行。

mysql MGR集群_第1张图片
4,安装group replication

install PLUGIN group_replication SONAME 'group_replication.so';

查看

Show plugins

mysql MGR集群_第2张图片
5,启动master上mysql的group replication
Set global group_replication_bootstrap_group=ON; ##group_replication_bootstrap_group为ON是为了标示以后加入集群的服务器以这台服务器为基准,以后加入的就不需要设置。

start group_replication;
set global group_replication_bootstrap_group=OFF;

查看mgr状态

select * from performance_schema.replication_group_members;

mysql MGR集群_第3张图片

测试插入一些数据

mysql MGR集群_第4张图片
mysql MGR集群_第5张图片

6,复制组添加新实例slave1,修改配置文件

第二台虚拟机配置
vim /etc/my.cnf ##添加以下 注意,ip不一样,组名三台都要一样

server_id=101   #注意服务ID不一样
gtid_mode=ON
enforce_gtid_consistency=ON
master_info_repository=TABLE
relay_log_info_repository=TABLE
binlog_checksum=NONE
log_slave_updates=ON
log_bin=binlog
binlog_format=ROW

transaction_write_set_extraction=XXHASH64
loose-group_replication_group_name='ce9be252-2b71-11e6-b8f4-00212844f856'
loose-group_replication_start_on_boot=off
loose-group_replication_local_address='cong12:33061'
loose-group_replication_group_seeds='cong11:33061,cong12:33061,cong13:33061'
loose-group_replication_bootstrap_group=off

mysql MGR集群_第6张图片

Systemctl restart mysqld ##重启
7,授权,和上面一样
mysql MGR集群_第7张图片
8,安装group replication 插件
和上面一样
把实例添加到之前的复制组

set global group_replication_allow_local_disjoint_gtids_join=ON;
start group_replication;

mysql MGR集群_第8张图片
查看复制组状态

select * from performance_schema.replication_group_members;

mysql MGR集群_第9张图片
mysql MGR集群_第10张图片
9,复制组添加新实例slave2,修改配置文件,添加以下
vim /etc/my.cnf ##组名,主机名和id

server_id=102   #注意服务ID不一样
gtid_mode=ON
enforce_gtid_consistency=ON
master_info_repository=TABLE
relay_log_info_repository=TABLE
binlog_checksum=NONE
log_slave_updates=ON
log_bin=binlog
binlog_format=ROW

transaction_write_set_extraction=XXHASH64
loose-group_replication_group_name='ce9be252-2b71-11e6-b8f4-00212844f856'
loose-group_replication_start_on_boot=off
loose-group_replication_local_address='cong13:33061'
loose-group_replication_group_seeds='cong11:33061,cong12:33061,cong13:33061'
loose-group_replication_bootstrap_group=off

systemctl restart mysqld ##重启

配置slave2

10,授权
同上
mysql MGR集群_第11张图片
安装group replication
同上
mysql MGR集群_第12张图片
查看状态

select * from performance_schema.replication_group_members;

mysql MGR集群_第13张图片
同步完成
11,查看集群参数设置列表

show variables like 'group_replication%';

mysql MGR集群_第14张图片
查看主服务器id

SHOW STATUS LIKE 'group_replication_primary_member';

mysql MGR集群_第15张图片

multi-primary模式(多主master模式)

1,由单主改为多主
在原来单主的主节点上
进入mysql

stop GROUP_REPLICATION;
set global group_replication_single_primary_mode=off;         #关闭单master模式
set global group_replication_enforce_update_everywhere_checks=ON;          #这个参数设置多主模式下各个节点严格一致性检查
SET GLOBAL group_replication_bootstrap_group=ON;
START GROUP_REPLICATION;         #加入到复制组
SET GLOBAL group_replication_bootstrap_group=OFF;

mysql MGR集群_第16张图片

2,在slave1和slave2上配置

配置两个一样
进入mysql

 stop GROUP_REPLICATION;      ##停止复制组
set global group_replication_allow_local_disjoint_gtids_join=ON;               #即使含有组中不存在的事务,也允许当前server加入组
set global group_replication_single_primary_mode=off;          #关闭单master模式
set global group_replication_enforce_update_everywhere_checks=ON;                  #这个参数设置多主模式下各个节点严格一致性检查
 start group_replication;    #加入到复制组

mysql MGR集群_第17张图片
mysql MGR集群_第18张图片

3,搭建多主master模式 在master上

vim /etc/my.cnf ##进入添加 , 再把主机名改一下

#roup Replication
server_id = 100  #服务ID
gtid_mode = ON  #全局事务
enforce_gtid_consistency = ON  #强制GTID的一致性
master_info_repository = TABLE  #将master.info元数据保存在系统表中
relay_log_info_repository = TABLE  #将relay.info元数据保存在系统表中
binlog_checksum = NONE  #禁用二进制日志事件校验
log_slave_updates = ON  #级联复制
log_bin = binlog   #开启二进制日志记录
binlog_format= ROW  #以行的格式记录

transaction_write_set_extraction = XXHASH64 #使用哈希算法将其编码为散列
loose-group_replication_group_name = 'ce9be252-2b71-11e6-b8f4-00212844f856' #加入的组名
loose-group_replication_start_on_boot = off #不自动启用组复制集群
loose-group_replication_local_address = 'cong11:33061' #以本机端口33061接受来自组中成员的传入连接
loose-group_replication_group_seeds = 'cong11:33061,cong12:33062,cong13:33063' #组中成员访问表
loose-group_replication_bootstrap_group = off  #不启用引导组
loose-group_replication_single_primary_mode = off  #关闭单master模式
loose-group_replication_enforce_update_everywhere_checks = ON  #多主一致性检查

mysql MGR集群_第19张图片

进入mysql

stop GROUP_REPLICATION;
reset master;   #重置所有的日志

4,在从服务器上配置,slave1 slave2

Vim /etc/my.cnf ##添加以下 修改主机名

 # Group Replication
server_id = 101  #服务ID
gtid_mode = ON  #全局事务
enforce_gtid_consistency = ON  #强制GTID的一致性
master_info_repository = TABLE  #将master.info元数据保存在系统表中
relay_log_info_repository = TABLE  #将relay.info元数据保存在系统表中
binlog_checksum = NONE  #禁用二进制日志事件校验
log_slave_updates = ON  #级联复制
log_bin = binlog   #开启二进制日志记录
binlog_format= ROW  #以行的格式记录

transaction_write_set_extraction = XXHASH64 #使用哈希算法将其编码为散列
loose-group_replication_group_name = 'ce9be252-2b71-11e6-b8f4-00212844f856' #加入的组名
loose-group_replication_start_on_boot = off #不自动启用组复制集群
loose-group_replication_local_address = 'cong12:33061' #以本机端口33061接受来自组中成员的传入连接
loose-group_replication_group_seeds = 'cong11:33061,cong12:33062,cong13:33063' #组中成员访问表
loose-group_replication_bootstrap_group = off  #不启用引导组
loose-group_replication_single_primary_mode = off  #关闭单master模式
loose-group_replication_enforce_update_everywhere_checks = ON  #多主一致
性检查 

/etc/init.d/mysqld restart ##重启

 select * from performance_schema.replication_group_members;

mysql MGR集群_第20张图片
mysql MGR集群_第21张图片
Slave2配置同上
配置完重启,查看状态

select * from performance_schema.replication_group_members;

mysql MGR集群_第22张图片
mysql MGR集群_第23张图片
完成

实验到这里就结束了,如果有问题请小伙伴们留言,谢谢~~

你可能感兴趣的:(mysql MGR集群)