我想将一个实时生产数据库复制到本地开发数据库中。是否有一种方法可以在不锁定生产数据库的情况下做到这一点?
我目前正在使用:
mysqldump -u root --password=xxx -h xxx my_db1 | mysql -u root --password=xxx -h localhost my_db1
但是它在运行时锁定了每个表。
我想将一个实时生产数据库复制到本地开发数据库中。是否有一种方法可以在不锁定生产数据库的情况下做到这一点?
我目前正在使用:
mysqldump -u root --password=xxx -h xxx my_db1 | mysql -u root --password=xxx -h localhost my_db1
但是它在运行时锁定了每个表。
当前回答
如果您使用Percona XtraDB集群- 我发现 ——skip-add-locks 到mysqldump命令 允许Percona XtraDB集群运行转储文件 转储文件中的LOCK TABLES命令没有问题。
其他回答
对于InnoDB表使用flag——single-transaction
它在BEGIN时转储数据库的一致状态 没有阻止任何申请
MySQL文档
http://dev.mysql.com/doc/refman/5.1/en/mysqldump.html#option_mysqldump_single-transaction
老实说,我会为此设置复制,因为如果不锁定表,就会从转储中获得不一致的数据。
如果转储需要较长的时间,则已经转储的表可能已经更改,而某些表可能即将被转储。
因此,要么锁定表,要么使用复制。
另一个迟来的回答是:
如果您正在尝试对服务器数据库进行热复制(在linux环境中),并且所有表的数据库引擎都是MyISAM,您应该使用mysqlhotcopy。
相应的文件:
它使用FLUSH TABLES、LOCK TABLES和cp或scp来创建数据库 备份。这是一种快速备份数据库或单个数据库的方法 表,但是它只能在数据库所在的同一台机器上运行 目录被定位。Mysqlhotcopy只适用于备份 MyISAM和ARCHIVE表。
LOCK TABLES时间取决于服务器复制MySQL文件的时间(它不转储)。
这和那个说他迟到的人比起来差不多晚了,但在我的情况下(在Windows 7上通过WAMP下载MySQL),我不得不使用:
--skip-lock-tables