每日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
相关推荐
cly1几秒前
SaltStack自动化(一): 原理与安装
运维·自动化·saltstack
RisunJan2 分钟前
Linux命令-ipcrm命令(删除Linux系统中的进程间通信(IPC)资源)
linux·运维·服务器
f***24113 分钟前
高效管理临时文件:自动化方案全解析
运维·自动化
超人小子3 分钟前
自动化报表系统实战:用Python让报表工作智能化
运维·python·自动化
Joren的学习记录3 分钟前
【Linux运维大神系列】Kubernetes详解2(kubeadm部署k8s1.27单节点集群)
linux·运维·kubernetes
lbb 小魔仙8 分钟前
【Linux】K8s 集群搭建避坑指南:基于 Linux 内核参数调优的生产级部署方案
linux·运维·kubernetes
且去填词8 分钟前
构建基于 DeepEval 的 LLM 自动化评估流水线
运维·人工智能·python·自动化·llm·deepseek·deepeval
wangbing112512 分钟前
平台介绍-开放API后台微服务
数据库·微服务·架构
techzhi12 分钟前
docker compose和docker-compose的区别
运维·docker·容器
老兵发新帖13 分钟前
ubuntu服务器配置私钥登录
linux·服务器·ubuntu