Mysql数据库定时备份脚本

#!/bin/bash
 
#指定连接数据库信息(用户名、密码、连接地址、端口、安装目录)
DB_USER=""
DB_PWD=""
DB_IP=""
DB_PORT=""
#是指mysqldump命令所在目录
DB_DIR="/usr"
 
#获取系统当前时间并格式化为:20210729
BAK_DATE=`date + %Y-%m-%d`
 
#指定备份文件保存的天数
BAK_DAY=7
#指定备份的数据库,可以指定多个中间用空格隔开,或者不指定则默认全部备份
BAK_DATABASES=("community_lvjin")
#指定备份路径
BAK_PATH=""
 
#创建备份目录
mkdir ${BAK_PATH}/$BAK_DATE
 
#开始执行备份
echo "------- $(date +%F_%T) Start MySQL database backup-------- " >>${BAK_PATH}/back.log
#循环遍历
for database in "${BAK_DATABASES[@]}"
do  
    ${DB_DIR}/bin/mysqldump -u${DB_USER} -p${DB_PWD} --host=${DB_IP} --port=${DB_PORT} --databases $database > ${BAK_PATH}/${BAK_DATE}/${database}.sql
done
 
#创建压缩文件
cd ${BAK_PATH}
tar -zcPf db_backup_${BAK_DATE}.tar.gz $BAK_DATE
 
#删除备份目录
#mv ${BAK_PATH}/$BAK_DATE /tmp1
 
#遍历备份目录下的文件
LIST=$(ls ${BAK_PATH}/db_backup_*)
 
#获取截止时间,将早于改时间的文件删除
 
SECONDS=$(date -d "$(date +%F) - ${BAK_DAY} days" +%s)
 
for index in ${LIST}
do 
  #获取文件名并格式化,获取时间,如20210729
 timeString=$(echo ${index} | egrep -o "?[0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9]")
 if [ -n "$timeString" ]
 then
     indexDate=${timeString//./-}
     indexSecond=$( date -d ${indexDate} +%s )
     #与当前时间做比较,把早于7天的文件删除
     if [ $(( $SECOND - $indexDate )) -gt 0 ]
     then 
        rm -f $index
        echo "-------deleted old file $index -------" >> ${BAK_PATH}/back.log
     fi
 fi
done
 
echo "-------$(date +%F_%T) Stop MySQL database backup-------- " >>${BAK_PATH}/back.log

  • 4
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值