(1)GTID主从复制

1)环境介绍

/etc/redhat-release
CentOS Linux release 7.3.1611 (Core)

MySQL版本:5.7

mysql> select version();
+------------+
| version() |
+------------+
| 5.7.22-log |
+------------+

2) master端配置

  • 准备数据
mysql>	create database testdb;
mysql> create table testdb.t1(id int,name varchar(50));
mysql> insert into testdb.t1 values(1,'jack'),(2,'alex');
  • 开启二进制日志和配置server-id
#vim /etc/my.cnf
log-bin
server-id=1
gtid_mode=ON
enforce_gtid_consistency=1
  • 重启服务器
#systemctl restart mysqld
  • 创建授权账号
mysql> grant replication slave,replication client on *.* to 'rep'@'192.168.111.%' identified by 'Reprep@123';
mysql> flush privileges;
  • 备份数据库
mysqldump -uroot -pRedhat@123 -A -R --triggers --routines --events  --single-transaction --master-data=1 --flush-logs >$(date +%F)-mysql-all.sql
  • 把备份的数据库文件拷贝到从库主机上
scp -r 2018-04-26-mysql-all.sql root@192.168.111.152:/root
  • 在完整备份后在创建一些数据
mysql> insert into testdb.t1 values(3,'www');
mysql> insert into testdb.t1 values(4,'yyyy');

3)slave端配置

  • 验证主库创建的账号是否能够正常登陆,也验证是否有防火墙问题
# mysql -h192.168.111.151 -urep -p'Reprep@123'
  • 配置从库的server-id和设置从库只读

    注意应用程序连接从库的权限不要给所有权限,只让从库只读
#vim /etc/my.cnf
log-bin
server-id=2
read-only
gtid_mode=ON
enforce_gtid_consistency=1
master-info-repository=TABLE \\把mysql连接主库的信息保存在表中
relay-log-info-repository=TABLE
log_slave_updates = ON
  • 重启数据库
#systemctl restart mysqld
  • 把备份导入到从库上
mysql -uroot -pRedhat@123 </root/2018-04-26-mysql-all.sql
  • 连接主库
mysql> change master to
-> master_host='192.168.111.151', \\生成环境建议使用主机名,不建议使用ip地址
-> master_user='rep',
-> master_password='Reprep@123',
-> master_auto_position=1;
change master to master_host='192.168.111.151',master_user='rep',master_password='Reprep@123',master_auto_position=1;
  • 开启复制和验证状态
mysql> start slave;
mysql> show slave status\G
Slave_IO_Running: Yes
Slave_SQL_Running: Yes

主库上创建数据库:



从库上验证:

(2)GTID主主复制

  • 在master1作为从库上指向master2,注意:master2作为从库之前已经change过master1

    这里的host是master2,不要弄错了;同时生产环境建议不要使用ip
mysql> change master to master_host='192.168.111.152',master_user='rep',master_password='Reprep@123',master_auto_position=1;
mysql> start slave;
mysql>show slave\G
  • master1插入数据
mysql>  insert into testdb.t1 values(10,'aaaa');
  • master2插入数据同时把master2以前是slave的read-only删除
mysql> insert into testdb.t1 values(11,'bbbb');
  • 验证:发现两边master的数据都能正常同步,very good
mysql> select * from testdb.t1;
+------+------+
| id | name |
+------+------+
| 10 | aaaa |
| 11 | bbbb |

(3)GTID多主一从

MySQL5.7中使用的是多源复制

  • 在master1上备份全库,同时把备份文件传给slave1
#mysqldump -uroot -pRedhat@123 -A -R  --triggers --routines --events --single-transaction --master-data=1 --flush-logs > `date +%F`-mysql-all.sql
#scp -r 2018-04-26-mysql-all.sql 192.168.111.153:/root
  • slave配置
#vim /etc/my.cnf
server-id=3
read-only
gtid_mode=ON
enforce_gtid_consistency=1
master-info-repository=TABLE
relay-log-info-repository=TABLE
log_slave_updates = ON
  • 重启数据库
systemctl restart mysqld
  • 导入备份
mysql> reset master;
#mysql -uroot -pRedhat@123 </root/2018-04-26-mysql-all.sql
  • 连接主库
master> change master to master_host='192.168.111.151',master_user='rep',master_password='Reprep@123',master_auto_position=1 for channel 'rep-master1';
master> change master to master_host='192.168.111.152',master_user='rep',master_password='Reprep@123',master_auto_position=1 for channel 'rep-master2';
mysql> start slave;
``

(十四)基于GTID的主从复制的更多相关文章

  1. Mysql5.7实现主从复制、基于GTID的主从复制、并行复制

    (一.主从复制) 一.mysql主从复制原理    mysql的默认复制方式是主从复制.Mysql内建的复制功能是构建大型,高性能应用程序的基础.将Mysql的数据分布到多个系统上去,这种分布的机制, ...

  2. mysql主从之基于gtid的主从复制

    一 GITD介绍 1.1 gtid的含义 Global Transaction Identifier,全局事务标识 阿里云的rds目前已经使用gtid 基于gtid的主从复制原理 每个mysql数据库 ...

  3. percona mysql server5.7基于gtid的主从复制

    配置mysql基于gtid主从复制架构 一.二进制安装mysql [root@node5 data]# --Linux.x86_64.ssl101.tar.gz [root@node5 data]# ...

  4. MySQL5.7.18基于GTID的主从复制过程实现

    GTID是5.6时加入的,在5.7中被进一步完善,生产环境建议在5.7版本中使用.GTID全称为Global Transaction Identifiers,全局事务标识符.GTID的复制完全是基于事 ...

  5. 实现mysql的读写分离(mysql-proxy)____1(mysql的主从复制,基于gtid的主从复制,半同步复制,组复制)

    主从复制原理: 从库生成两个线程,一个I/O线程,一个SQL线程: i/o线程去请求主库 的binlog,并将得到的binlog日志写到relay log(中继日志) 文件中:主库会生成一个 log ...

  6. MySQL5.6基于GTID的主从复制配置

    全局事务标示符(Global Transactions Identifier)是MySQL 5.6复制的一个新特性. GTID实际上是由UUID+TID组成的.其中UUID是一个MySQL实例的唯一标 ...

  7. MySQL5.6:基于GTID的主从复制

    一.GTID简介 MySQL 5.6 的新特性之一,是加入了全局事务 ID (GTID) 来强化数据库的主备一致性,故障恢复,以及容错能力. 什么是GTID? 官方文档:http://dev.mysq ...

  8. redis之(十四)redis的主从复制的原理

    一:redis主从复制的原理,步骤.   第一步:复制初始化 --->从redis启动后,会根据配置,向主redis发送SYNC命令.2.8版本以后,发送PSYNC命令. --->主red ...

  9. mysql5.7.26 基于GTID的主从复制环境搭建

    简单工作原理: (1)从库执行 change master to 语句,会立即将主库信息记录到master.info中 (2)从库执行 start slave语句,会立即生成IO_T和SQL_T (3 ...

随机推荐

  1. lnmp1.4,400,500,错误

    Thinkphp5或其他主流框架,入口文件未放在根目录下,比如Thinkphp5 入口文件放在/public/index.php vhost需要指向/public目录 一键安装包通常会报 open_b ...

  2. 算法(10)Subarray Sum Equals K

    题目:在数组中找到一个子数组,让子数组的和是k. 思路:先发发牢骚,这两天做题是卡到不行哇,前一个题折腾了三天,这个题上午又被卡住,一气之下,中午睡觉,下午去了趟公司,竟然把namespace和cgr ...

  3. #define、const、typedef的区别

    #define.const.typedef的区别 #define 并不是定义变量, 只是用来做文本替换 例如: #define PI 3.1415926 float angel; angel=30*P ...

  4. 通过init-connect + binlog 实现MySQL审计功能

    背景: 假设这么一个情况,你是某公司mysql-DBA,某日突然公司数据库中的所有被人为删了. 尽管有数据备份,但是因服务停止而造成的损失上千万,现在公司需要查出那个做删除操作的人. 但是拥有数据库操 ...

  5. oracle的sequece的使用(主键自增长)

    在Oracle数据库中,sequence等同于序列号,每次取的时候sequence会自动增加,一般会作用于需要按序列号排序的地方. 1.Create Sequence (注释:你需要有CREATE S ...

  6. oracle与mysql的group by语句

    之所以去纠那么细节的问题,是因为之前有过一个这样的场景: 有个同学,给了一条数据库的语句给我,问,为啥这样子的语句在oracle语句下执行不了. 1 select * from xx where xx ...

  7. 手动安装GCC

    01sunxiaoqiang的博客 Centos离线手动安装gcc.g++教程 转载 2016-11-06 17:35:18 标签:linux应用笔记 在安装LINUX系统的时候很可能会没有安装gcc ...

  8. Nginx替换过滤文本模块replace-filter-nginx-module

    1.安装此模块需要先安装sregex运行库 apt-get update;apt-get install git make gcc -y #Centos改成yum git clone https:// ...

  9. C#中的弱引用(WeakReference)

    我们平常用的都是对象的强引用,如果有强引用存在,GC是不会回收对象的.我们能不能同时保持对对象的引用,而又可以让GC需要的时候回收这个对象呢?.NET中提供了WeakReference来实现.弱引用可 ...

  10. 取消eslint对指定代码进行代码检测

    eslint配置了不允许使用alert,但是有个需求需要用到. //eslint-disable-next-line alert('测试'); 如上,即可跳过当前行代码检查了