MySQL数据库如何实现Percona全量增量备份与恢复


本文主要给大家简单讲讲MySQL数据库如何实现Percona全量增量备份与恢复,相关专业术语大家可以上网查查或者找一些相关书籍补充一下,这里就不涉猎了,我们就直奔主题吧,希望MySQL数据库如何实现Percona全量增量备份与恢复这篇文章可以给大家带来一些实际帮助。Percona的innobackupex具有如下特点:(1)备份过程快速、可靠; (2)备份过程不会打断正在执行的事务; (3)能够基于压缩等功能节约磁盘空间和流量; (4)自动实现备份检验; (5)还原速度快。本文结合计划任务和脚本,使用Percona的innobackupex命令实现如下备份策略:(1)每周一23点对数据库做完全备份,脚本名称为allbbsdbbak.sh。
(2)每周的周二至周日23:30对数据库做增量备份,脚本名称为ne开发云主机域名wbbsdbdata.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、全量备份脚本
2、增量备份脚本MySQL数据库如何实现Percona全量增量备份与恢复就先给大家讲到这里,对于其它相关问题大家想要了解的可以持续关注我们的行业资讯。我们的板块内容每天都会捕捉一些行业新闻及专业知识分享给大家的。

相关推荐: MySQL表与表之间有哪些关系

不知道大家之前对类似MySQL表与表之间有哪些关系的文章有无了解,今开发云主机域名天我在这里给大家再简单的讲讲。感兴趣的话就一起来看看正文部分吧,相信看完MySQL表与表之间有哪些关系你一定会有所收获的。 表与表之间的关系1、先确定关系2、找到多的一方,把关联…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 06/09 10:29
下一篇 06/09 10:30

相关推荐