Mysql中xtrabackup备份的实现

 更新时间:2023年12月12日 09:22:28   作者:一个小宏混  
Xtrabackup是Percona团队开发的用于MySQL数据库物理热备份的开源备份工具,本文就来介绍一下Mysql中xtrabackup备份的实现,就有一定的参考价值,感兴趣的可以了解一下

1.准备环境

安装数据库

[root@localhost ~]# yum-y install mysql mysql-server
[root@localhost ~]# systemctl start mysqld
[root@localhost ~]# grep pass /var/log/mysql.log
[root@localhost ~]# mysqladmin -uroot -p'old-passwd' password "new-passwd"

email配置

[root@localhost ~]# yum -y install mailx
[root@localhost ~]# vi /etc/mail.rc #将下面信息填入到文件中
set from=********@qq.com
set smtp=smtp.qq.com
set smtp-auth-user=**********@qq.com
set smtp-auth-password=************ #第三方登录码
set smtp-auth=login

2.脚本解析

#!/bin/bash
#校验时间
ntpdate ntp.aliyun.com >> /dev/null
#检查是否创建目录
find /xtrabackup/ -name '*' >> /dev/null
if [[ $? -ne 0 ]];then 
    mkdir /xtrabackup/
fi

find /xtrabackup/log/ -name '*' >> /dev/null
if [[ $? -ne 0 ]];then 
    mkdir -p /xtrabackup/log
fi
#定义变量
User=root
Password=QianFeng@123
Email_num=2756375538@qq.com
#完全备份
backup_full(){
    innobackupex --user=$User --password=$Password /xtrabackup/ >> /xtrabackup/log/backup.log 2>&1
}
#增量备份
backup_incremental(){
    #获取前一天时间
    before=$(date -d "yesterday" +%Y-%m-%d_%H) 
    Before_path=`find /xtrabackup/ -name "${before}*"`
    innobackupex --user=$User --password=$Password --incremental /xtrabackup/ --incremental-basedir=$Before_path >> /xtrabackup/log/backup.log 2>&1
}
#差异备份
backup_differential(){
    date_times=$(date +%u)
    if [[ $date_times -eq 4 ]];then
        before_3_days=$(date -d "3 days ago" +%Y-%m-%d_%H)
        Full_path=`find /xtrabackup/ -name "${before_3_days}*"`
        innobackupex --user=$User --password=$Password --incremental /xtrabackup --incremental-basedir=$Full_path >> /xtrabackup/log/backup.log 2>&1
    else
        before_6_days=$(date -d "6 days ago" +%Y-%m-%d_%H)
        Full_path=`find /xtrabackup/ -name "${before_3_days}*"`
        innobackupex --user=$User --password=$Password --incremental /xtrabackup --incremental-basedir=$Full_path >> /xtrabackup/log/backup.log 2>&1
    fi 
}
#定义邮件
email_worker(){
    echo "数据备份失败" | mail -s "数据库备份失败" $Email_num
}

#主函数

date_time=$(date +%u)
case $date_time in 
    1)
    backup_full
    ;;
    2|3|5|6)
    backup_incremental
    ;;
    4|7)
    backup_differential
    ;;
esac
if [[ $? -ne 0 ]];then 
    email_worker
fi 

到此这篇关于Mysql中xtrabackup备份的实现的文章就介绍到这了,更多相关Mysql xtrabackup备份内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家! 

相关文章

  • MySQL读取my.cnf的顺序问题详情

    MySQL读取my.cnf的顺序问题详情

    这篇文章主要介绍MySQL读取my.cnf的顺序问题,以mysql.server、mysqld_safe及mysqld和my_print_defaults读取my.cnf顺序展开文章介绍主题,感兴趣的话大家一起来学习吧
    2021-09-09
  • dmysql自己封装的mysql库

    dmysql自己封装的mysql库

    dmysql自己封装的mysql库...
    2007-07-07
  • Mysql数据库索引面试题(程序员基础技能)

    Mysql数据库索引面试题(程序员基础技能)

    索引是Mysql的一块硬骨头,但是对于程序猿来说又是十分重要的基础技能。本文将从索引原理、索引设计原则方面阐述Mysql索引,相信通过本文的学习你将完美征服阿里面试官
    2021-05-05
  • 阿里云 Centos7.3安装mysql5.7.18 rpm安装教程

    阿里云 Centos7.3安装mysql5.7.18 rpm安装教程

    这篇文章主要介绍了阿里云 Centos7.3安装mysql5.7.18 rpm安装教程,需要的朋友可以参考下
    2017-06-06
  • MySQL内存使用之线程独享介绍

    MySQL内存使用之线程独享介绍

    这篇文章主要介绍了MySQL内存使用之线程独享介绍,线程独享内存主要用于各客户端连接线程存储各种操作的独享数据,如线程栈信息,分组排序操作,数据读写缓冲,结果集暂存等等,而且大多数可以通过相关参数来控制内存的使用量,需要的朋友可以参考下
    2014-12-12
  • 解决Java程序使用MySQL时返回参数为乱码的示例教程

    解决Java程序使用MySQL时返回参数为乱码的示例教程

    这篇文章主要介绍了解决Java程序使用MySQL返回参数为乱码的问题的教程,通过示例来讲解utf-8编码在MySQL中的相关配置,示例需要的朋友可以参考下
    2015-12-12
  • MySQL全文索引实现简单版搜索引擎实例代码

    MySQL全文索引实现简单版搜索引擎实例代码

    这篇文章主要给大家介绍了关于MySQL全文索引实现简单版搜索引擎的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用MySQL具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-07-07
  • 彻底卸载MySQL的方法分享

    彻底卸载MySQL的方法分享

    由于安装MySQL的时候,疏忽没有选择底层编码方式,采用默认的ASCII的编码格式,于是接二连三的中文转换问题随之而来,就想卸载了重新安装MYSQL,这一卸载倒是出了问题,导致安装的时候安装不上,在网上找了一个多小时也没解决。
    2011-08-08
  • mysql下为数据库设置交叉权限的方法

    mysql下为数据库设置交叉权限的方法

    由于 SupeSite 需要调用 Discuz! 和 UCHome 的数据,所以如果它们不安装在同一个数据库,SupeSite 的数据库用户必须要对 Discuz! 和 UCHome 的数据库有读取、修改、删除等权限。
    2011-07-07
  • mysql定时删除过期数据记录的简单方法

    mysql定时删除过期数据记录的简单方法

    今天小编就为大家分享一篇mysql定时删除过期数据记录的简单方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-08-08

最新评论