mysqldump命令之single-transaction

=========================================================
在mysqldump中指定single-transaction时,会使用可重复读(REPEATABLE READ)事务隔离级别来保证整个dump过程当中数据一致性,该选项仅对InnoDB表有用,且不能与ALTER TABLE/CREATE TABLE/DROP TABLE/RENAME TABLE/TRUNCATE TABLE等DDL操做并行。html

mysqldump的操做步骤以下: FLUSH TABLES; FLUSH TABLES WITH READ LOCK; SET SESSION TRANSACTION ISOLATION LEVEL REPEATABLE READ; START TRANSACTION WITH CONSISTENT SNAPSHOT; SHOW MASTER STATUS; UNLOCK TABLES; SHOW TABLES LIKE 'xxx'
SET OPTION SQL_QUOTE_SHOW_CREATE=1 SHWO CREATE TABLE 'xxx' SHOW FIELDS FROM 'xxx' SHOW TABLE STATUS LIKE 'xxx'
SELECT /*!40001 SQL_NO_CACHE */ * FROM xxx QUIT

经过FLUSH TABLES WITH READ LOCK来锁定全部表,而后开启事务,因为外部事务不能对表数据进行修改,所以SHOW MASTER STATUS的数据不会发生变化,而因为事务隔离级别为REPEATABLE READ,所以在整个mysqldump过程当中,获取到的数据为开始事务时的数据,所以能够保证mysqldump出来的数据一致性,并能够结合SHOW MASTER STATUS出来的数据进行恢复。


=========================================================
在MySQL不一样版本中,mysqldump --single-transaction与DDL操做发生并行时会出现问题:
http://www.cnblogs.com/TeyGao/p/7121232.html
https://www.cnblogs.com/TeyGao/p/7122924.html



=========================================================
若是从库上开启并行复制,在从库执行mysqldump备份,执行"FLUSH TABLES WITH READ LOCK;"会与并行复制发生相互阻塞。
https://www.cnblogs.com/TeyGao/p/8654933.html

mysql

相关文章
相关标签/搜索