图解MySQL | [原理解析] XtraBackup 备份恢复时为什么要加 apply-log-only 参数?

XtraBackup 在 MySQL 备份场景中被广泛使用,大家一定不陌生。我们也在之前的两篇文章中分享了其备份的原理。(详见 [[原理解析] XtraBackup全量备份还原](http://mp.weixin.qq.com/s?__b... & [[原理解析] XtraBackup增量备份还原](http://mp.weixin.qq.com/s?__b...)本文想要描述的是 XtraBackup 恢复时参数 apply-log-only 的作用,不知道大家有没有注意到,这个参数如果不设置,可能会产生数据不一致的惨剧。

使用 XtraBackup 对数据库做备份,实际上就是拷贝 MySQL 的数据文件,为了保证备份数据的最终一致,也会同时拷贝备份过程中的 Redo log。

如图 5 所示,正确的做法应该是除了最后一个增备,所有的备份恢复都应该设置 apply-log-only 参数(only 指的就是只回放 redo log 阶段,跳过 undo 阶段),避免未完成事务的回滚。如图所示,此时全备恢复后的数据文件才是完整的(包含了B->F)。所有增备恢复完成后的数据也是完整的。

参考:
https://www.percona.com/doc/p...

你可能感兴趣的:(mysql,xtrabackup,数据库,备份)