MySQL数据库完整备份与增量备份的原理简介

数据库 MySQL
本文我们简单介绍了MySQL数据库中增量备份与完整备份的原理,了解这些原理有助于我们更快地掌握增量备份与完整备份的操作,希望能够对您有所帮助。

MySQL数据库实现备份的操作包括完整备份增量备份等,本文我们主要介绍一下增量备份和完整备份的原理,接下来我们就一起来了解一下这部分内容。

完整备份的原理:

对于InnoDB,XtraBackup基于InnoDB的crash-recovery功能进行备份。

crash-recovery是这样的:InnoDB维护了一个redo log,又称为 transaction log,也叫事务日志,它包含了InnoDB数据的所有改动情况。InnoDB启动的时候先去检查datafile和transaction log,然后应用所有已提交的事务并回滚所有未提交的事务。

XtraBackup在备份的时候并不锁定表,而是一页一页地复制InnoDB的数据,与此同时,XtraBackup还有另外一个线程监视着transactions log,一旦log发生变化,就把变化过的log pages复制走(因为transactions log文件大小有限,写满之后,就会从头再开始写,新数据可能会覆盖到旧的数据,所以一旦变化就要立刻复制走)。在全部数据文件复制完成之后,停止复制logfile。

XtraBackup采用了其内置的InnoDB库以read-write模式打开InnoDB的数据文件,然后每次读写1MB(1MB/16KB=64page)的数据,一页一页地遍历,同时用InnoDB的buf_page_is_corrupted()函数检查此页的数据是否正常,如果正常则进行复制,如不正常则重新读取,最多重读10次,如果还是失败,则备份失败退出。复制transactions log的原理也是一样的,只不过每次读写512KB(512KB/16KB=32page)的数据。

由于XtraBackup其内置的InnoDB库打开文件的时候是rw的,所以运行XtraBackup的用户,必须对InnoDB的数据文件具有读写权限。

由于XtraBackup要从文件系统中复制大量的数据,所以它尽可能地使用posix_fadvise(),来告诉OS不要缓存读取到的数据(因为这些数据不会重用到了),从而提升性能。如果要缓存的话,大量的数据会对OS的虚拟内存造成很大的压力,其它进程(如mysqld)很有可能会被swap出去,这样就出问题了。同时,XtraBackup在读取数据的时候还尽可能地预读。

由于不锁表,所以复制出来的数据是不一致的,数据的一致性是在恢复的时候使用crash-recovery进行实现的。

对于MyISAM,XtraBackup还是首先锁定所有的表,然后复制所有文件。

增量备份的原理:

在完整备份和增量备份文件中都有一个文件xtrabackup_checkpoints会记录备份完成时检查点的LSN。在进行新的增量备份时,XtraBackup会比较表空间中每页的LSN是否大于上次备份完成的LSN,如果是,则备份该页,并记录当前检查点的LSN。

以上就是MySQL数据库完整备份和增量备份的原理的介绍,本文就介绍这里了,希望本次的介绍能够对您有所收获!

【编辑推荐】

  1. MySQL数据库中varchar的限制规则
  2. MySQL数据库负荷较高时的原因排查思路
  3. MySQL简单操作之alter table改变表的结构
  4. MySQL简单操作之用select查询表中的记录
  5. MySQL数据库主从服务器文档的部署与切换详解
责任编辑:赵鹏 来源: CSDN博客
相关推荐

2010-03-02 09:47:03

Fedora MySQ

2020-05-22 07:00:00

合成完整备份备份数据

2017-07-10 16:00:47

Mysql数据备份数据还原

2011-03-31 14:34:46

cactimysql备份

2011-03-30 13:57:41

MySQL数据库自动备份

2019-03-01 13:40:01

MySQL数据库备份案例

2010-05-26 10:25:50

MySQLdump增量

2011-08-15 09:19:22

2018-11-08 12:07:38

备份手动磁盘

2010-10-29 09:36:49

完全备份增量备份差异备份

2011-05-16 09:32:33

mysql数据库备份

2018-08-24 13:58:13

数据库MySQL备份

2019-02-28 21:20:50

MySQL备份与恢复数据库

2015-03-18 13:39:35

MySQLBackup数据库备份种类

2010-05-17 15:58:05

MySQL Admin

2011-07-26 13:55:01

MongoDB备份与恢复

2013-05-24 13:24:46

Mysql数据库自动备份

2010-05-20 15:22:37

2010-04-15 09:27:37

Oracle数据库

2011-04-06 09:09:17

MySQL数据库备份
点赞
收藏

51CTO技术栈公众号