我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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

本文主要给大家简单讲讲MySQL数据库如何实现Percona全量增量备份与恢复,相关专业术语大家可以上网查查或者找一些相关书籍补充一下,这里就不涉猎了,我们就直奔主题吧,希望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、全量备份脚本

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

    2、增量备份脚本

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

 

MySQL数据库如何实现Percona全量增量备份与恢复就先给大家讲到这里,对于其它相关问题大家想要了解的可以持续关注我们的行业资讯。我们的板块内容每天都会捕捉一些行业新闻及专业知识分享给大家的。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MySQL数据库全量、增量备份与恢复

造成数据丢失的原因 程序错误 人为商店 计算机失败 磁盘失败 灾难(如火山、地震)和偷窃 数据库备份的分类 从物理与逻辑的角度,备份可分为: 物理备份:对数据库操作系统的物理文件(如数据文件、日志文件等)的备份 物理备份又可以分为脱机备份(冷
MySQL数据库全量、增量备份与恢复
2015-05-05

mysql数据库的全量与增量的备份以及恢复方式

目录一、全量备份与恢复二、增量备份与恢复三、全量、增量的数据库恢复总结一、全量备份与恢复1.全量备份mysqldump -uroot -proot --databases -default-character-set=utf8mb4 >
mysql数据库的全量与增量的备份以及恢复方式
2024-09-14

MyBatis视图设计如何支持数据备份恢复的增量与全量备份

MyBatis 是一个优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。但在视图设计中,MyBatis 本身并不直接提供数据备份恢复的功能。要实现数据的增量与全量备份,通常需要在数据库层面或者应用程序层面进行相应的处理。以下是
MyBatis视图设计如何支持数据备份恢复的增量与全量备份
2024-10-14

MySQL数据库完全备份与增量备份详解

目录定义完全备份与恢复演示定义完全备份就是将数据库中的数据及所有对象全部备份。由于 mysql 服务器中的数据文件是基于磁盘的文本文件,所以完全备份就是复制数据库文件,是最简单也是最快速的方式。但 MySQL 服务器的数据文件在服务器
2022-08-10

编程热搜

目录