当前位置:Gxlcms > 数据库问题 > MySQL--当mysqldump --single-transaction遇到alter table

MySQL--当mysqldump --single-transaction遇到alter table

时间:2021-07-01 10:21:17 帮助过:18人阅读


--single-transaction dump is in process, to ensure a
valid dump file (correct table contents and binary log
position), no other connection should use the following
statements: ALTER TABLE, DROP TABLE, RENAME TABLE,
TRUNCATE TABLE, as consistent snapshot is not isolated
from them. Option automatically turns off --lock-tables.

红色字体部分是重点,但是看得有些迷糊,还是动手测试下。

根据《mysqldump的几个主要选项探究》的介绍,我们备份执行的命令mysqldump --single-transaction --master-data相当于执行下面代码:

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

 

 

场景1:mysqldump开始但尚未备份到表tb001时,另外回话对表tb001进行alter操作,然后mysqldump对表tb001进行导出

技术分享

alter操作顺利完成,但是mysqldump操作失败。

 

场景2:mysqldump开始备份并完成tb001的导出,在对其他表进行导出过程中,其他回话对表进行alter操作

技术分享

alter table操作被阻塞直至mysqldump完成或失败后退出。

 

##========================================================================##

总结: 

single-transaction参数通过Innodb的多版本来获得数据一致性,而ALTER TABLE, DROP TABLE, RENAME TABLE,TRUNCATE TABLE等操作会破坏数据一致性,两种操作不能并发执行。

如果修改表操作在 ”mysqldump开启后但还未导出修改表数据前“ 的时间段内开始,则修改表操作成功完成,而mysqldump会执行失败;

如果修改表操作在 “mysqldum已导出修改表数据但还未结束mysqldump操作前”的时间段内开始,则修改表操作被阻塞,mysqldum能成功完成,在mysqldump操作完成后修改表操作方可正常执行。

##========================================================================##

技术分享

MySQL--当mysqldump --single-transaction遇到alter table

标签:数据   UI   tomat   png   evel   ble   img   master   targe   

人气教程排行