【概念】什么事GTIDS(Global Transactions Identifier)是MySQL5.6.5新加入的一项新特性。
- 当使用GTIDS时,无论是在Master上提交事物还是在Slave上应用,每一个事物都可以被识别并跟踪;
- 添加新的Slave或者当发生故障需要将Master身份迁移到Slave上时,都无需考虑哪一个二进制日志以及哪个position,极大的简化了操作步骤;
- GTIDs是完全基于事务的。因此,不支持MYISAM存储引擎;
【关于GTID】GTID由source_id和transaction_id两部门组成。
- source_id来自于server_uuid,可以在auto.cnf文件中查看;
- tranction_id是一个序列数字,从小到达自动生成;
[root@t-db01 mysql]# cat auto.cnf
mysql> show global variables like 'gtid_executed'; |
【构建主从数据库】
环境说明:
主库信息 | 从库信息 | |
数据库版本 | 5.6.23 | 5.6.23 |
IP地址 | 192.168.47.169 | 192.168.47.186 |
同步数据库 | JOHN_DB | |
同步用户 | repl |
1、主库参数的设置
server_id = 1 binlog-format=ROW #建议使用ROW格式 log-bin=mysql-bin #打开binlog report-port=3306 gtid-mode=on enforce-gtid-consistency=true log-slave-updates=true replicate_do_db=JOHN_DB |
2、从库参数的设置
server_id = 2 log-bin=mysql-bin report-port=3306 gtid-mode=on enforce-gtid-consistency=true log-slave-updates=true replicate_do_db=JOHN_DB skip-slave-start #启动的时候自动打开复制 |
检查gtid是否启用:show global variables like ‘%gtid%’;
3、在主库上面用户的创建
grant replication slave on JOHN_DB.* to 'repl'@'192.168.47.186' identified by 'repl'; |
4、进行从库数据的初始化
操作的步骤跟5.5的步骤一样,这边就偷懒不再重复了;
5、配置从库连接主库
从库连接主库: change master to master_host='192.168.47.169', master_user='repl',master_password='repl',master_auto_position=1; 启动从库: start slave; 检查状态: show slave status\G; mysql> show slave status\G; ERROR: 自动找到binlog位置,并进行同步; |
经过以上操作便完成了mysql主从架构的搭建;
【常见问题的处理方法】
1、场景的模拟
步骤一:主库上面创建表john,并插入3行数据。(这个时候从库和主库的数据是一致的) mysql> select * from john;
步骤二:从库关闭slave状态 mysql> stop slave;
步骤三:主库关闭写binlog mysql> set sql_log_bin=off; 关闭
步骤四:主库插入值4 mysql> insert into john values(4);
步骤五:主库启动binlog mysql> set sql_log_bin=on;
步骤六:主库插入值 5 mysql> insert into john values(5);
经过以上步骤,主库和从库中john的值已经不一致了; 主库如下:
从库如下:
步骤六:修改主库id为4的行,这个时候从库就会报错了 |
Executed_Gtid_Set: a989adc2-2a8e-11e5-a308-000c296ecd05:1-29 从库执行Gtid序号
2、问题原因:由于id=4是没有写日志的,所以id=4并没有同步到从库,当主库删除id=4这条记录的时候,从库找不到这条记录所以报错了;
3、解决方法:GTIDs模式下的主从问题,操作如下:
mysql> stop slave; mysql> set GTID_NEXT=’268e23d1-2216-11e5-abcc-000c296ecd05:1-30’; #跳过当前从库的该序号 mysql> BEGIN; mysql> COMMIT; mysql> SET GTID_NEXT=’AUTOMATIC’; mysql> START SLAVE; |
经过以上操作完成了基于GTIDs的主从数据库的配置和常见问题的处理,单从便捷的角度上确实提高了主从搭建的速度;