zoukankan      html  css  js  c++  java
  • Xtrabackup 物理备份

    Xtrabackup 安装

    # 上传文件包
    [root@db03 ~]#  rz percona-xtrabackup-24-2.4.4-1.el6.x86_64.rpm
    
    # 下载epel源
    wget -O /etc/yum.repos.d/epel.repo  https://mirrors.aliyun.com/repo/epel-6.repo
    # 安装依赖
    yum -y install perl perl-devel libaio libaio-devel perl-Time-HiRes perl-DBD-MySQL
    # 下载Xtrabackup
    wget httpss://www.percona.com/downloads/XtraBackup/Percona-XtraBackup-2.4.4/binary/redhat/6/x86_64/percona-xtrabackup-24-2.4.4-1.el6.x86_64.rpm
    
    # 安装
    [root@db03 ~]#  yum localinstall -y percona-xtrabackup-24-2.4.4-1.el6.x86_64.rpm
    # 安装好后的命令
    [root@db03 ~]#  xtrabackup
    [root@db03 ~]#  innobackupex
    

    Xtrabackup 备份介绍

    对于非 innodb 表(比如 myisam)是直接锁表 Copy 数据文件,属于一种温备;

    对于 innodb 表(支持事务),不锁表,cp数据页最终以数据文件方式保存下来,并且把 redo 和 undo 一并备走,属于热备方式 。

    注意:备份时读取配置文件/etc/my.cnf(如果使用 Xtrabackup 备份,必须要配置 datadir)

    Xtrabackup全量备份

    准备备份目录

    [root@db03 ~]#  mkdir /backup
    

    全量备份

    [root@db03 ~]#  innobackupex --user=root --password=123 /backup/full
    
    # 去掉时间戳进行备份
    [root@db03 ~]#  innobackupex --user=root --password=123 --no-timestamp /backup/full
    

    查看全量备份内容

    [root@db03 ~]#  ll /backup/full/
    backup-my.cnf
    dump
    ibdata1
    ibdata2
    mysql
    performance_schema
    row
    test
    xtrabackup_binlog_info		# bin-log 信息
    xtrabackup_checkpoints		# 本次备份的数据的 起始日志序列号(LSN)-结束日志序列号(LSN)
    xtrabackup_info				# 工具或数据的信息
    xtrabackup_logfile			# redo-log 信息
    
    [root@db03 full]#  cat xtrabackup_checkpoints
    backup_type = full-backuped
    from_lsn = 0
    to_lsn = 8417759
    

    Xtrabackup 全量备份恢复数据

    删除所有数据库

    # 删库
    mysql> drop database dump;
    mysql> drop database performance_schema;
    mysql> drop database row;
    mysql> drop database test;
    

    停止数据库服务

    [root@db03 ~]#  systemctl stop mysqld.service
    

    模拟 CSR 的过程

    # 将 redo 进行重做,已提交的写到数据文件,未提交的使用 undo 回滚,模拟 CSR 的过程
    [root@db03 ~]#  innobackupex --user=root --password=123 --apply-log /backup/full
    

    恢复数据

    方法一(不推荐)

    # 移走原数据目录
    [root@db03 mysql]#  mv data data.back
    
    # 将全备的数据目录迁移回来
    [root@db03 mysql]#  cp -r /backup/full ./data
    
    [root@db03 mysql]#  chown -R mysql.mysql data
    

    方法二(推荐)

    # 使用 innobackupex 恢复数据
    [root@db03 mysql]#  innobackupex --copy-back /backup/full/
    [root@db03 mysql]#  chown -R mysql.mysql data
    

    检验结果

    # 启动数据库
    [root@db03 data]#  systemctl start mysqld
    # 查看是否恢复
    [root@db03 data]#  mysql -uroot -p123
    mysql> show databases;
    

    Xtrabackup 增量备份

    Xtrabackup 每次基于上一次备份进行增量;

    增量备份无法单独恢复,必须基于全备进行恢复;

    所有增量必须要按顺序合并到全备当中 。

    全量备份

    [root@db03 ~]#  innobackupex --user=root --password=123 --no-timestamp /backup/full_$(date +%F)
    

    插入新数据

    [root@db03 ~]#  mysql -uroot -p123
    mysql> use dump
    mysql> insert dump values(10000),(20000),(30000);
    

    第一次增量备份

    [root@db01 ~]#  innobackupex --user=root --password=123 --no-timestamp --incremental --incremental-basedir=/backup/full_2020-07-23 /backup/inc1
    
    参数说明:
    --incremental:开启增量备份功能
    --incremental-basedir:上一次备份的路径
    
    # 验证
    [root@db03 ~]#  cat /backup/full/xtrabackup_checkpoints 
    backup_type = full-prepared
    from_lsn = 0
    to_lsn = 8417759
    [root@db03 ~]#  cat /backup/inc1/xtrabackup_checkpoints 
    backup_type = incremental
    from_lsn = 8417759
    to_lsn = 8419281
    

    插入新数据

    [root@db03 ~]#  mysql -uroot -p123
    mysql> use dump
    mysql> insert dump values(100000),(200000),(300000);
    

    第二次增量备份

    [root@db03 ~]#  innobackupex --user=root --password=123 --no-timestamp --incremental --incremental-basedir=/backup/inc1/ /backup/inc2
    
    # 验证
    [root@db03 backup]#  cat /backup/full_2020-07-23/xtrabackup_checkpoints 
    backup_type = full-backuped
    from_lsn = 0
    to_lsn = 1636167
    
    [root@db03 backup]#  cat /backup/inc1/xtrabackup_checkpoints 
    backup_type = incremental
    from_lsn = 1636167
    to_lsn = 1640828
    
    [root@db03 backup]#  cat /backup/inc2/xtrabackup_checkpoints 
    backup_type = incremental
    from_lsn = 1640828
    to_lsn = 1645877
    

    Xtrabackup 增量备份恢复数据

    将全备执行 Redo

    [root@db03 backup]#  innobackupex --apply-log --redo-only /backup/full_2020-07-23
    

    将第一次增备只执行 redo,合并到第一次全备

    [root@db03 backup]#  innobackupex --apply-log --redo-only --incremental-dir=/backup/inc1/ /backup/full_2020-07-23
    
    # 验证
    [root@db03 backup]#  cat /backup/full_2020-07-23/xtrabackup_checkpoints 
    backup_type = log-applied
    from_lsn = 0
    to_lsn = 1640828			# 该值本来是inc1的位置点
    

    将最后一次增备执行 redo 和 undo,合并到第一次全备

    [root@db03 backup]#  innobackupex --apply-log --incremental-dir=/backup/inc2/ /backup/full_2020-07-23
    
    # 验证
    [root@db03 backup]#  cat /backup/full_2020-07-23/xtrabackup_checkpoints 
    backup_type = log-applied
    from_lsn = 0
    to_lsn = 1645877			# 该值本来是inc2的位置点
    

    将整体数据进行一次 CSR

    [root@db03 backup]#  innobackupex --apply-log /backup/full_2020-07-23/
    

    恢复数据

    [root@db03 mysql]#  mv data data.bak
    [root@db03 mysql]#  innobackupex --copy-back /backup/full_2020-07-23/
    [root@db03 mysql]#  chown -R mysql.mysql ./data
    [root@db03 mysql]#  systemctl start mysqld
    

    全量备份 & 增量备份 对比

    增备:
    优点:占用磁盘空间小,没有重复数据
    缺点:恢复麻烦

    全备:
    优点:恢复容易,只需一次
    缺点:占用磁盘空间,每次全备都有重复数据

  • 相关阅读:
    JS 保存表单默认值 为空时自动填充默认值
    .net 防盗链
    Subversion安装和使用
    (转) MFC的入口点与消息循环,消息映射
    ASP.NET树形控件TreeView的递归绑定
    SQL Server中的分页
    C# 调用WebService的方法
    从零开始定义自己的JavaScript框架(一)
    JS中的call和apply
    JS中的自执行函数
  • 原文地址:https://www.cnblogs.com/zzzwqh/p/13366753.html
Copyright © 2011-2022 走看看