Mysql

关注公众号 jb51net

关闭
首页 > 数据库 > Mysql > Mysql xtrabackup备份

Mysql中xtrabackup备份的实现

作者:一个小宏混

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备份内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家! 

您可能感兴趣的文章:
阅读全文