0

目前我正在使用 mysqlbackup 进行备份。这将调用“带读锁的刷新表”并增加锁定我的表的可能性,直到刷新完成并释放全局锁。

那么,有没有办法备份我的数据库,它真的很大,有超过 100 GB 的表,没有这个全局锁?

我读到的 mysqldump --single-transaction 之类的东西在小型数据库上很有用,但事实并非如此。是否有类似的适用于我的情况?

希望如此 !

4

1 回答 1

0

当您有这么大的表时,Percona Xtrabackup 是一个很好的选择。这主要是由于以下两点:

a) 从逻辑备份(即:由 mysqldump 创建)恢复 100GB 表所花费的时间会过多,因为 mysql 在重放 sql 时必须重建索引并进行大量 I/O 处理。

b) xtrabackup 可以在您进行第一次完整备份后进行增量备份,从而在磁盘空间方面使例行的每晚或每小时更快和更小。

也就是说,请注意,由于 xtrabackup 复制 /lib/mysql 目录中的所有相关文件,因此磁盘空间要求非常重要。如果您有一个在磁盘上分配了 200GB 的数据库(即使某些表上有一些空的分配空间),您的备份大小将是 200GB。

这与 mysqldump 的逻辑备份(可以重新创建数据、表结构、索引等的 sql 语句)相比,后者将占用一小部分空间。

在此处阅读有关 Percona xtrabackup 如何工作的更多信息:https ://www.percona.com/doc/percona-xtrabackup/LATEST/how_xtrabackup_works.html

mysqldump 与 innodb 表一起使用以及 --master-data 和 --single-transaction 选项的组合是一个不错的选择。它在所有表上获得一个全局读锁,但只需要足够长的时间来读取二进制日志坐标。通常,这将非常快,除非正在进行非常重要的更新,在这种情况下,它可能会停止,直到更新完成。

这为您提供了一致的时间点备份,并且在初始读取锁定之外没有锁定。

这是语法:

  mysqldump --all-databases --master-data --single-transaction > all_databases.sql

或者

  mysqldump --master-data --single-transaction my-database > my-database.sql

备份单个数据库。

可以在此处的 dev.mysql.com 站点上阅读有关此的更多信息:https ://dev.mysql.com/doc/refman/5.7/en/mysqldump.html#option_mysqldump_single-transaction

于 2017-06-23T13:12:04.947 回答