每日shell脚本之自动化备份数据库周期性灾备

每日shell脚本之自动化备份数据库周期性灾备

使用本脚本前在服务器安装 物理备份工具-xtrabackup

bash 复制代码
#!/usr/bin/bash                
#CSDN :M乔木 
#Email:2776617348@qq.com 
#解释器:这是一个shell脚本    

#数据库用户密码
user=数据库用户
passwd=数据库密码

#检查备份情况
bm(){
	if [ $? -ne "0" ];then
	mail
	fi
}

#检查数据库
md=$(systemctl status mysqld  &>/dev/null)
if [ $? -ne "0" ];then
echo "备份失败! 原因没安装mysql" &>>/xtdata/xt_log/elog.log
mail
ecit 9
fi
#备份失败邮件
mail(){
sm=$(rpm -qa mailx | awk -F'-' '{print $1}')
if [ -z "${sm}" ];then
yum -y install mailx
fi
echo "备份异常! 请到xtdata目录下查看日志"   | mail -s "数据备份异常" -S smtp="smtp服务器域名" -S smtp-auth=login -S smtp-auth-user="发件人邮箱" -S smtp-auth-password="你的授权码"  收件人邮箱
}

#获取当前时间
XQ=$(date +%u)

#日志收集
xt_log(){
xtlog=`ls . | grep /xtdata`
if [ ! -d "${xtlog}" ];then
echo "you"
mkdir -p  /xtdata/{星期天,星期一,星期二,星期三,星期四,星期五,星期六,xt_log}
touch /xtdata/xt_log/elog.log
fi
}

#主界面
	xt_log
	case ${XQ} in
7)
	innobackupex --user=${user} -password="${passwd}" /xtdata/星期天/ &>/xtdata/xt_log/elog.log
	bm
	;;
1)
	xqy=`ls /xtdata/星期天/ | sort -nr | head -1`	
	innobackupex --user=${user} --password="${passwd}" --incremental /xtdata/星期一/ --incremental-basedir=/xtdata/星期天/${xqy} &>/xtdata/xt_log/elog.log
	bm
	;;
2)
	xqy=`ls /xtdata/星期一/ | sort -nr | head -1`      
        innobackupex --user=${user} --password="${passwd}" --incremental /xtdata/星期二/ --incremental-basedir=/xtdata/星期一/${xqy}	&>/xtdata/xt_log/elog.log
	bm
	;;
3)
	xqy=`ls /xtdata/星期天/ | sort -nr | head -1`      
        innobackupex --user=${user} --password="${passwd}" --incremental /xtdata/星期三/ --incremental-basedir=/xtdata/星期天/${xqy}    &>/xtdata/xt_log/elog.log
	bm
	;;
4)
	xqy=`ls /xtdata/星期三/ | sort -nr | head -1`
        innobackupex --user=${user} --password="${passwd}" --incremental /xtdata/星期四/ --incremental-basedir=/xtdata/星期三/${xqy}	&>/xtdata/xt_log/elog.log
	bm
	;;
5)
	xqy=`ls /xtdata/星期四/ | sort -nr | head -1`
        innobackupex --user=${user} --password="${passwd}" --incremental /xtdata/星期五/ --incremental-basedir=/xtdata/星期四/${xqy}	&>/xtdata/xt_log/elog.log
	bm
	;;
6)
	xqy=`ls /xtdata/星期三/ | sort -nr | head -1`
        innobackupex --user=${user} --password="${passwd}" --incremental /xtdata/星期六/ --incremental-basedir=/xtdata/星期三/${xqy}    &>/xtdata/xt_log/elog.log
	bm
	;;
*)
	echo "执行备份任务失败 原因是日期异常" >>/xtdata/xt_log/elog.log 
	mail
	esac
相关推荐
Two_brushes.8 分钟前
【linux 网络】网络基础
linux·网络
Code Warrior8 分钟前
【Linux】基础开发工具(3)
linux·服务器
智海观潮29 分钟前
Flink CDC支持Oracle RAC架构CDB+PDB模式的实时数据同步吗,可以上生产环境吗
大数据·oracle·flink·flink cdc·数据同步
鬼才血脉43 分钟前
Linux(centos)安装 MySQL 8
linux·mysql·centos
guygg881 小时前
ubuntu手动编译VTK9.3 Generating qmltypes file 失败
linux·运维·ubuntu
JeffersonZU1 小时前
Linux/Unix 套接字Socket编程(socket基本概念,流程,流式/数据报socket,Unix domain socket示例)
linux·c语言·tcp/ip·udp·unix·gnu
扫地僧9851 小时前
用于构建多模态情绪识别与推理(MERR)数据集的自动化工具
自动化·多模态·情绪识别
先做个垃圾出来………2 小时前
自动化一次通过率
运维·自动化
float_六七2 小时前
SQL六大核心类别全解析
数据库·sql·oracle
Two_brushes.2 小时前
【linux网络】网络编程全流程详解:从套接字基础到 UDP/TCP 通信实战
linux·开发语言·网络·tcp/udp