每日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
相关推荐
丘大梨10 分钟前
QT 基础聊天应用项目文档
运维·数据库·系统架构
HMBBLOVEPDX28 分钟前
MySQL的多版本并发控制(MVCC):
数据库·mysql·mvcc
怀刃28 分钟前
C# 内存监控怎么定位问题
运维
TPBoreas29 分钟前
Jenkins启动端口修改失败查找日志
运维·服务器·jenkins
.用户昵称已存在.1 小时前
MongoDB 从入门到精通:安装配置与基础操作指令详解
数据库·mongodb
许泽宇的技术分享1 小时前
Windows桌面自动化的革命性突破:深度解析Windows-MCP.Net Desktop模块的技术奥秘
windows·自动化·.net
ClouGence2 小时前
CloudDM 新增支持 GaussDB 与 openGauss:国产数据库管理更高效
数据库·sql·ci/cd
sukalot2 小时前
window显示驱动开发—在混合系统中使用跨适配器资源
数据库·驱动开发·音视频
洛卡卡了2 小时前
数据库加密方案实践:我们选的不是最完美,但是真的够用了。
数据库·后端·面试
幽络源小助理2 小时前
MySQL实战优化高手教程 – 从架构原理到生产调优
数据库·mysql·架构