percona mysql 备份_MySQL数据库之Percona全量增量备份与恢复

一、概述:

mysqldump是由MySQL-Commiunity提供的MySQL数据库备份的工具,但是只能用于全量备份,如果要实现增量备份需要基于binlog日志实现。

本文介绍使用第三方软件Percona提供的命令innobackupex做全量备份、增量备份以及恢复的方法。percona-xtrabackup主要是有两个工具,其中一个是xtrabackup,专门用于备份InnoDB表,另一个是innobackupex,是前者封装后的一个perl脚本,同时支持备份InnoDB和MyISAM。在针对MySQL的物理备份工具中,Percona大概是最流行也是最强大的工具。

Percona的innobackupex具有如下特点:

(1)备份过程快速、可靠;

(2)备份过程不会打断正在执行的事务;

(3)能够基于压缩等功能节约磁盘空间和流量;

(4)自动实现备份检验;

(5)还原速度快。

本文结合计划任务和脚本,使用Percona的innobackupex命令实现如下备份策略:

(1)每周一23点对数据库做完全备份,脚本名称为allbbsdbbak.sh。

(2)每周的周二至周日23:30对数据库做增量备份,脚本名称为newbbsdbdata.sh。

二、命令介绍:

1、原理:备份开始时首先会开启一个后台检测进程,实时检测mysql redo的变化,一旦发现有新的日志写入,立刻将日志记入后台日志文件xtraback_log中,之后复制InnoDB的数据文件(系统表空间文件ibdatax),复制结束后执行flush tables with readlock,然后复制.fri、.MYI、.MYD等文件,最后执行unlock tables并停止xtrabackup_log.

2、依赖软件:

使用percona软件的innobackupex命令,需要安装perl-DBD-mysql、perl-Digest-MD5、libev、percona-xtrabackup四个软件包。

3、命令格式:

innobackupex命令的参数非常多,用于数据备份的常用参数格式如下(具体参数可参考帮助信息或者这篇文章:https://www.cnblogs.com/waynechou/p/xtrabackup_backup.html):

# innobackupex [--user=NAME] [--password=WORD] [--port=PORT] [--no-timestamp] [--databases=LIST] /backupdir

--user            备份使用的用户名

--password        备份用户的密码

--port            如果是3306可以不用写

--no-timestamp    不用日期命名备份文件存储的子目录名

--database        "库名"-单个库,"库1 库2"-多个库,"库.表"-单个表

4、恢复:

(1)rm -rf /var/lib/mysql

mkdir /var/lib/mysql

(2)恢复日志

# innobackupex --user root --password 123456 --databases "mysql sys performance_schema db1" --apply-log /allback

(3)恢复数据

# innobackupex --user root --password 123456 --databases "mysql sys performance_schema db1" --copy-back /allback

(4)chown -R mysql:mysql /var/lib/mysql

(5)重起数据库服务

systemctl restart mysqld

(6)登录恢复后的数据库

# mysql -uroot -p123456

5、增量备份:

#innobackupex --user root --password 123456 --databases="系统库列表 储存数据库" --incremental 目录名 --incremental-basedir=目录名 --no-timestamp

--incremental 目录名             //增量备份的目录,在备份的时候自动创建,如果提前创建好则需要该目录下面为空

--incremental-basedir=目录名        //上一次备份的目录

6、增量恢复:

#innobackupex --user root --password 123456 --databases="系统库列表 储存数据库" --incremental-dir=目录名 --no-timestamp

--incremental-dir=目录名        //用于增量恢复的备份数据目录

--redo-only                //

(1)rm -rf /var/lib/mysql

mkdir /var/lib/mysql

(2)恢复日志文件

# innobackupex --user root --password 123456 --apply-log --redo-only /allback

# innobackupex --user root --password 123456 --apply-log --redo-only /allback --incremental-dir=/new1

# innobackupex --user root --password 123456 --apply-log --redo-only /allback --incremental-dir=/new2

(3)恢复数据

# innobackupex --user root --password 123456 --copy-back /allback

(4)chown -R mysql:mysql /var/lib/mysql

(5)重起数据库服务

systemctl restart mysqld

(6)登录恢复后的数据库

# mysql -uroot -p123456

注意:(1)innobackupex恢复数据的时候要求/var/lib/mysql目录下面为空的,因此一般要把三个系统库(mysql、sys、perfomance_schema)都要备份上。

(2)/allbak目录可以在备份的时候自动创建,如果提前创建好则需要该目录下面为空

(3)此命令只能实现使用InnoDB引擎库的增量备份,其他的存储引擎的只能全量备份

三、备份脚本

1、全量备份脚本

7bcc06e030450c16235998e9ca4a395e.png

2、增量备份脚本

d971deacf164f39cd1d390395fa7de92.png

3、计划任务

17d2d198104aece98312cfb37d8f2fd2.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值