MySQL-GTID-主从复制

■■GTID的概念
1)全局事务标识:global transaction identifiers
2)GTID是一个事务一一对应,并且全局唯一ID
3)一个GTID在一个服务器上只执行一次,避免重复执行导致数据混乱或者主从不一致
4)GTID用来代替传统复制方法,不再使用MASTER_LOG_FILE+MASTER_LOG_POS开启复制,而是使用MASTER_AUTO_POSTION=1的方式开始复制
5)MySQL-5.6.5开始支持的,MySQL-5.6.10后开始完善
6)在传统的slave端,binlog是不用开启的,但是在GTID中slave端的binlog是必须开启的,目的是记录执行过的GTID(强制)

■■GTID组成
GTID = source_id:transaction_id
source_id,用于鉴别原服务器,即mysql服务器唯一的的server_uuid,由于GTID会传递到slave,所以也可以理解为源ID
transaction_id,为当前服务器上已提交事务的一个序列号,通常从1开始自增长的序列,一个数值对应一个事务。
示例:
3E11FA47-71CA-11E1-9E33-C80AA9429562:23
前面的一串为服务器的server_uuid,即3E11FA47-71CA-11E1-9E33-C80AA9429562,后面的23为transaction_id

■■GTID原理
1、当一个事务在主库端执行并提交时,产生GTID,一同记录到binlog日志中
2、binlog传输到slave,并存储到slave的relaylog后,读取这个GTID的这个值设置gtid_next变量,即告诉Slave,下一个要执行的GTID值
3、sql线程从relaylog中获取GTID,然后对比slave端的binlog是否有该GTID
4、如有记录,说明该GTID的事务已执行,slave会忽略
5、如没有记录,slave就会执行该GTID事务,并记录该GTID到自身的binlog
【在读取执行事务前会先检查其他session是否持有该GTID,确保不被重复执行】
6、在解析过程中会判断是否有主键,如果没有就用二级索引,如果没有就用全部扫描

■■主从复制
主从复制过程存在三个线程,Master端的I/O线程,Slave的I/O线程与SQL线程。Master端需要开启binlog日志,Slave端需要开启relaylog。
1、Slave端的I/O读取master.info文件,获取binlog文件名和位置点,然后向Master端的I/O线程请求,该binlog文件名和位置点的binlog信息。
(master.info文件在配置主从复制时使用change master命令来指定生成)
2、Master端的I/O线程会根据Slave端的I/O线程请求的信息来读取Master的binlog日志信息与及读取到最新的binlog文件名和位置点一同返回给Slave的I/O线程。
3、Slave端的I/O线程会把获取到的binlog日志写入relaylog(中继日志)文件中,并且更新master.info文件信息。(把读取到Master最新的binlog日志文件名和位置点更新到master.info文件中,下一次当前位置去读取Master的binlog日志)
4、Slave端的SQL线程会定期读取relaylog,把二进制的日志解析成SQL语句,并执行这些SQL语句,同步数据到从库中

发表评论

电子邮件地址不会被公开。 必填项已用*标注