当前位置:  开发笔记 > 编程语言 > 正文

当DDL同时使用时,如何使用mysqldump和单事务获取正确的转储?

如何解决《当DDL同时使用时,如何使用mysqldump和单事务获取正确的转储?》经验,为你挑选了1个好方法。

我是MySQL的新手,我正在找出使用它进行在线热逻辑备份的最佳方法mysqldump. 此页面显示此命令行:

mysqldump --single-transaction --flush-logs --master-data=2
          --all-databases > backup_sunday_1_PM.sql

但是......如果你仔细阅读文档,你会发现:

--single-transaction转储正在进行时,为了确保有效的转储文件(正确的表内容和二进制日志位置),其他任何连接都不应使用以下语句:ALTER TABLE, DROP TABLE, RENAME TABLE, TRUNCATE TABLE.一致读取不会与这些语句隔离,因此在要转储的表上使用它们会导致SELECT执行者mysqldump检索表内容以获取不正确的内容或失败.

那么,有没有办法防止这种可能的转储损坏情况?即可以暂时阻止这些语句的命令.

PS:关于这个主题的MySQL错误条目http://bugs.mysql.com/bug.php?id=27850



1> Bill Karwin..:

打开mysql命令窗口并发出以下命令:

mysql> FLUSH TABLES WITH READ LOCK;

这将锁定此MySQL实例上所有数据库中的所有表,直到您发出(或终止保存这些读锁的客户端连接).UNLOCK TABLES

为了证实这一点,你可以打开另一个命令窗口,并尝试做一个ALTER,DROP,RENAMETRUNCATE.这些命令挂起,等待释放读锁定.按Ctrl-C终止等待.

但是,虽然表具有读锁定,但您仍可以执行mysqldump备份.

FLUSH TABLES WITH READ LOCK命令可以与使用--lock-all-tables选项相同mysqldump.这还不完全清楚,但这个文档似乎支持它:

UNLOCK TABLES的另一个用途是释放使用FLUSH TABLES WITH READ LOCK获取的全局读锁.

两者FLUSH TABLES WITH READ LOCK--lock-all-tables用短语"全球读锁,"所以我认为这是有可能的是,这些做同样的事情.因此,您应该能够使用该选项mysqldump并防止并发ALTER,DROP,RENAME和TRUNCATE.


回覆.您的评论:以下内容来自您链接到的MySQL错误日志中的Guilhem Bichot:

你好.--lock-all-tables调用带有READ LOCK的FLUSH TABLES.因此,它应该阻止ALTER,DROP,RENAME或TRUNCATE(除非有错误或我错了).但是, - lock-all-tables --single-transaction无法正常工作(mysqldump会抛出错误消息):因为lock-all-tables会在备份期间锁定服务器的所有表以防写入,而单一事务则是旨在让备份期间发生写入(通过在事务中使用一致读取SELECT),它们本质上是不兼容的.

从这一点来看,听起来你不能在备份期间获得并发访问,同时阻止ALTER,DROP,RENAME和TRUNCATE.

推荐阅读
吻过彩虹的脸_378
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有