我想将一个实时生产数据库复制到本地开发数据库中。是否有一种方法可以在不锁定生产数据库的情况下做到这一点?

我目前正在使用:

mysqldump -u root --password=xxx -h xxx my_db1 | mysql -u root --password=xxx -h localhost my_db1

但是它在运行时锁定了每个表。


当前回答

当使用MySQL工作台时,在数据导出中,单击高级选项并取消选中“锁定表”选项。

其他回答

这已经太迟了,但对任何正在搜索这个话题的人来说都是好事。如果你不是innoDB,并且你不担心转储时锁定,那么就使用这个选项:

--lock-tables=false

老实说,我会为此设置复制,因为如果不锁定表,就会从转储中获得不一致的数据。

如果转储需要较长的时间,则已经转储的表可能已经更改,而某些表可能即将被转储。

因此,要么锁定表,要么使用复制。

由于这些方法对我都不起作用,我只是做了一个:

mysqldump [...] | grep -v "LOCK TABLE" | mysql [...]

它将排除LOCK TABLE <x>和UNLOCK TABLES命令。

注意:希望您的数据中不包含该字符串!

要转储大型表,您应该结合使用——single-transaction选项和——quick。

http://dev.mysql.com/doc/refman/5.1/en/mysqldump.html#option_mysqldump_single-transaction

当使用MySQL工作台时,在数据导出中,单击高级选项并取消选中“锁定表”选项。