shell脚本实战之mysql-物理备份实现周内备份策略

一.shell脚本要求

复制代码
# 数据库备份脚本方式: 物理备份

# 工具:xtrabackup过程

# 需求1:不允许有任何的安在脚本中,

# 需求2:在脚本中,不允许有任何的交互式代码容,使用日志记录

# 需求3:在脚本中,不允许有任何输出

# 需求4:每周为一个循环周期,1全备、2增量、3增量、4差异、5增量、6增量、7差异,

# 自动检测执行报错,邮件告敬

#下载工具yum -y install percona-xtrabackup-24.x86_64

二.环境

1.备份的主机上需要自己手动安装xtrabackup工具

安装xtrabackup

复制代码
#下载xtrabackup的yum源
wget http://www.percona.com/downloads/percona-release/redhat/0.1-4/percona-release-0.1-4.noarch.rpm

  rpm -ivh percona-release-0.1-4.noarch.rpm

#打开xtrabackup的yum源 
vim percona-release.repo
复制代码
#2.下载xtrabackup 工具
yum -y install percona-xtrabackup-24.x86_64

三.脚本实施

复制代码
vim mysqlbaup.sh

#/bin/bash
#时间同步
ntpdate ntp.aliyun.com >>/dev/null

user=root

password="Qianfeng@123"

timestamp=$(date +"%Y-%m-%d_%H-%M-%S")  

#从放备份日志 /xtrabackup/xtrabackup-timestamp.log

#备份目录
mkdir -p  /xtrabackup/z{1..7} &>>/dev/null

#周一完全 #

z1() {

    # touch /xtrabackup/xtrabackup.log >>/dev/null

    innobackupex --user=$user --password=$password /xtrabackup/z1 &>> /xtrabackup/xtrabackup-$timestamp.log

    z1=`ls -t /xtrabackup/z1/ | awk  'NR==1 {print $1}'` &>>/dev/null

}

#周二 增量

z2() {

    innobackupex --user=$user --password=$password --incremental /xtrabackup/z2 --incremental-basedir=/xtrabackup/z1/$z1 &>> /xtrabackup/xtrabackup--$timestamp.log

    z2=`ls -t /xtrabackup/z2/ | awk  'NR==1 {print $1}'` &>>/dev/null

}

#周三 增量

z3() {

    innobackupex --user=$user --password=$password --incremental /xtrabackup/z3 --incremental-basedir=/xtrabackup/z2/$z2 &>> /xtrabackup/xtrabackup-$timestamp.log

    z3=`ls -t /xtrabackup/z3/ | awk  'NR==1 {print $1}'` &>>/dev/null

}

#周四 差异

z4() {

    innobackupex --user=$user --password=$password --incremental /xtrabackup/z4 --incremental-basedir=/xtrabackup/z1/$z1 &>> /xtrabackup/xtrabackup-$timestamp.log

    z4=`ls -t /xtrabackup/z4/ | awk  'NR==1 {print $1}'` &>>/dev/null

}

#周五 增量

z5() {

    innobackupex --user=$user --password=$password --incremental /xtrabackup/z5 --incremental-basedir=/xtrabackup/z4/$z4 &>> /xtrabackup/xtrabackup-$timestamp.log

    z5=`ls -t /xtrabackup/z5/ | awk  'NR==1 {print $1}'` &>>/dev/null

}

#周六 增量

z6() {

    innobackupex --user=$user --password=$password --incremental /xtrabackup/z6 --incremental-basedir=/xtrabackup/z5/$z5 &>> /xtrabackup/xtrabackup-$timestamp.log

    z6=`ls -t /xtrabackup/z6/ | awk  'NR==1 {print $1}'` &>>/dev/null

}

#周天 差异

z7() {

    innobackupex --user=$user --password=$password --incremental /xtrabackup/z7 --incremental-basedir=/xtrabackup/z1/$z1 &>> /xtrabackup/xtrabackup-$timestamp.log

}

#星期判断 #星期一...

function show_date() {  

    date +"%A"  >>/dev/null

}  

show_date

time=`date +"%A"`  

if [ $time == "星期一" ];then

    z1

elif [ $time == "星期二" ];then

    z2

elif [ $time == "星期三" ];then

    z3

elif [ $time == "星期四" ];then

    z4

elif [ $time == "星期五" ];then

    z5

elif [ $time == "星期六" ];then

    z6

else z7

fi



#报警发邮箱

warn() {  

    grep "successful" /xtrabackup/xtrabackup-$timestamp.log > /dev/null  

    #当日志文件里没有successful时,也就是说它失败了
    if [ $? -ne 0 ]; then  

        cat "/xtrabackup/xtrabackup-$timestamp.log" | mailx -s "报警出错。及时排错" 22001399@qq.com

    fi  

}  

warn

注意:脚本里的星期取值是基于,终端里的取得中文状态,也就是说,你在终端里的返回值是中文的。

四.结果输出

#与君共勉,共同进步

相关推荐
LZZ and MYY6 分钟前
RTS 在windows和Linux之间ShareMem
linux·运维·服务器
aningx7 分钟前
openSUSE Leap 16.0 运行 sunshine 报错的解决方法
linux
爱学习的徐徐8 分钟前
Linux 基础IO
linux·服务器
zt1985q13 分钟前
本地部署源代码管理解决方案 Bitbucket Data Center 并实现外部访问
运维·服务器·数据库·网络协议·postgresql·源代码管理
xiaobobo333025 分钟前
面向对象:linux内核中函数转数据的用法
linux·面向对象·隔离·函数指针绑定
极客先躯29 分钟前
高级java每日一道面试题-2026年01月18日-实战篇[Docker]-如何清理仓库中的旧镜像?
java·运维·docker·容器
姓刘的哦29 分钟前
C++软件架构设计思路
linux
ModestCoder_34 分钟前
windows/ubuntu解决挂梯子但是codex reconnecting五次的问题
linux·windows·ubuntu
禹凕35 分钟前
Linux基础——环境
linux·运维·服务器·ubuntu
好好风格1 小时前
【一行代码】查看本机公网 IP
linux·命令行