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

我目前正在使用:

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

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


当前回答

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

其他回答

如果您使用Percona XtraDB集群- 我发现 ——skip-add-locks 到mysqldump命令 允许Percona XtraDB集群运行转储文件 转储文件中的LOCK TABLES命令没有问题。

    mysqldump -uuid -ppwd --skip-opt --single-transaction --max_allowed_packet=1G -q db |   mysql -u root --password=xxx -h localhost db

——skip-add-locks帮了我大忙

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

--lock-tables=false

答案取决于您使用的存储引擎。最理想的情况是使用InnoDB。在这种情况下,您可以使用——single-transaction标志,它将在转储开始时为您提供数据库的一致快照。