每日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
相关推荐
NineData7 小时前
NineData智能数据管理平台新功能发布|2026年1-2月
数据库·sql·数据分析
IvorySQL8 小时前
双星闪耀温哥华:IvorySQL 社区两项议题入选 PGConf.dev 2026
数据库·postgresql·开源
ma_king10 小时前
入门 java 和 数据库
java·数据库·后端
甲鱼92911 小时前
MySQL 实战手记:日志管理与主从复制搭建全指南
运维
jiayou6414 小时前
KingbaseES 实战:审计追踪配置与运维实践
数据库
Johny_Zhao1 天前
OpenClaw安装部署教程
linux·人工智能·ai·云计算·系统运维·openclaw
NineData1 天前
NineData 迁移评估功能正式上线
数据库·dba
NineData1 天前
数据库迁移总踩坑?用 NineData 迁移评估,提前识别所有兼容性风险
数据库·程序员·云计算
赵渝强老师1 天前
【赵渝强老师】PostgreSQL中表的碎片
数据库·postgresql
全栈老石2 天前
拆解低代码引擎核心:元数据驱动的"万能表"架构
数据库·低代码