失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > Percona Xtrabackup备份mysql大数据库(完整备份与增量备份)

Percona Xtrabackup备份mysql大数据库(完整备份与增量备份)

时间:2019-10-18 04:22:22

相关推荐

Percona Xtrabackup备份mysql大数据库(完整备份与增量备份)

Percona Xtrabackup备份mysql大数据库(完整备份与增量备份)

文章目录 [隐藏] Xtrabackup简介Xtrabackup安装Xtrabackup工具介绍innobackupex使用方法 完整备份及还原增量备份及还原

Xtrabackup简介

PerconaXtraBackup是开源免费的MySQL数据库热备份软件,它能对InnoDB和XtraDB存储引擎的数据库非阻塞地备份(对于MyISAM的备份同样需要加表锁)。XtraBackup支持所有的Percona Server、MySQL、MariaDB和Drizzle。

XtraBackup优势 :

1、无需停止数据库进行InnoDB热备

2、增量备份MySQL

3、流压缩到传输到其它服务器

4、能比较容易地创建主从同步

5、备份MySQL时不会增大服务器负载

Xtrabackup安装

这里只介绍Ubuntu-12.04下的安装方法,其它系统的安装方法请参考/doc/percona-xtrabackup/2.1/installation.html

apt-key adv --keyserver --recv-keys 1C4CBDCDCD2EFD2A

在/etc/apt/sources.list加入:

deb /apt precise maindeb-src /apt precise main

执行update及安装操作

apt-get updateapt-get install percona-xtrabackup

注:precise是Ubuntu-12.04的版本代号,如果是其它系统版本,需要更换。

Xtrabackup工具介绍

安装XtraBackup后,其实会有几个工具:

innobackupex:

这个是其实是下面三个工具的一个perl脚本封装,可以备份MyISAM, InnoDB, XtraDB表。

xtrabackup:

一个由C编译而来的二进制文件,只能备份InnoDB和XtraDB数据。

xbcrypt:

用来加密或解密备份的数据。

xbstream:

用来解压或压缩xbstream格式的压缩文件。

建议使用perl封装的innobackupex来作数据库备份,因为比较容易使用。所以下面只介绍innobackupex的使用。其它的使用参考:/doc/percona-xtrabackup/2.1/manual.html

innobackupex使用方法

完整的选项使用请执行innobackupex --help,这里只介绍使用常用的选项进行完整备份及增量备份和还原。

完整备份及还原

假如我们要备份centos和mysql数据库。

备份:

innobackupex --user=root --password=root --defaults-file=/etc/mysql/f --include="centos.*|mysql.*" /data/mysql_backup

这样就会在/data/mysql_backup生成一个带时间的目录,如果不需要带时间,可以使用选项--no-timestamp。

如果想备份成压缩文件,可以使用如下语句:

innobackupex --user=root --password=root --defaults-file=/etc/mysql/f --include="centos.*|mysql.*" --no-timestamp --stream=tar ./ | gzip - > www.centos.bz.tar.gz

还原:

假如完整备份的路径为/data/mysql_backup/full_backup,如果完整备份是压缩文件,需要先解压再还原。

innobackupex --apply-log /data/mysql_backup/centos_full_backupinnobackupex --copy-back --defaults-file=/etc/mysql/f /data/mysql_backup/centos_full_backupchown -R mysql:mysql /var/lib/mysql

增量备份及还原

增量备份是建立在完整备份的基础上的,所以首先确保已经完整备份了一次。

完整备份:

innobackupex --user=root --password=root --include="centos.*" --no-timestamp /data/mysql_backup/centos_full_backup

现在完整备份的目录为/data/mysql_backup/centos_full_backup。

增量备份:

第一次增量备份:

innobackupex --incremental /data/mysql_backup/inc/0906 --no-timestamp --incremental-basedir=/data/mysql_backup/centos_full_backup --user=root --password=root --defaults-file=/etc/mysql/f

第二次增量备份:

innobackupex --incremental /data/mysql_backup/inc/0907 --no-timestamp --incremental-basedir=/data/mysql_backup/inc/0906 --user=root --password=root --defaults-file=/etc/mysql/f

选项--incremental是指定作增量备份 --incremental-basedir选项是指定上一次增量备份的目录(如果是第一次作增量备份,则为完整备份的目录)。

还原:

增量备份的还原操作跟完整的还原有点不一样,首先必须使用--apply-log --redo-only对完整备份的目录及所有增量备份目录进行操作,然后就可以像还原完整备份时的操作了。

对每个备份目录作apply-log redo-only操作(包括完整备份)

innobackupex --apply-log --redo-only /data/mysql_backup/centos_full_backup --user=root --password=rootinnobackupex --apply-log --redo-only /data/mysql_backup/centos_full_backup --incremental-dir=/data/mysql_backup/inc/0906 --user=root --password=rootinnobackupex --apply-log --redo-only /data/mysql_backup/centos_full_backup --incremental-dir=/data/mysql_backup/inc/0907 --user=root --password=root

下面就跟还原完整备份时一样了:

innobackupex-1.5.1 --apply-log /data/mysql_backup/centos_full_backup --use-memory=1G --user=root --password=rootinnobackupex --copy-back --defaults-file=/etc/mysql/f /data/mysql_backup/centos_full_backup

转载请标明文章来源:《https://www.centos.bz//09/percona-xtrabackup-mysql-backup/》

如果觉得《Percona Xtrabackup备份mysql大数据库(完整备份与增量备份)》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。