每天晚上我的服务器都会为每个MySQL数据库创建备份。所有这些文件都保存在像/backup/mysql/2014-11-28这样的文件夹中。在过去的几个月里,该目录中存储了许多文件夹和文件,我想减少这种情况。
因此,我需要一个 bash 脚本来删除给定目录中的每个文件夹,除了本月创建的每个文件夹(不是过去 30 天,而是实际月份)和每周的一个备份(例如周日的备份)。由于我不知道如何参加周日聚会,因此我决定保留07日,14日,21日和28日的备份会更简单。
#!/bin/bash
in_array() {
local haystack=${1}[@]
local needle=${2}
for i in ${!haystack}; do
if [[ ${i} == ${needle} ]]; then
return 0
fi
done
return 1
}
YEAR=`date +%Y`
LASTYEAR=`date +%Y -d "1 year ago"`
MONTH=`date +%m`
DAYS="07 14 21 28"
for i in $( ls ); do
BACKUP_YEAR=$(echo "${i}" | cut -d'-' -f1)
BACKUP_MONTH=$(echo "${i}" | cut -d'-' -f2)
BACKUP_DAY=$(echo "${i}" | cut -d'-' -f3)
DELETE=false
if [[ "$BACKUP_YEAR" == "$YEAR" ]]; then
if [[ "$BACKUP_MONTH" != "$MONTH" ]]; then
if [ $(in_array $DAYS "$BACKUP_DAY") ]; then
DELETE=true
fi
fi
fi
if [[ "$BACKUP_YEAR" == "$LASTYEAR" ]]; then
if [[ "$BACKUP_DAY" != ${DAYS[0]} ]]; then
DELETE=true
fi
fi
if [ "$DELETE" = true ] ; then
#OUTPUT=`rm -v -R $i`
echo $i
fi
done
第二部分(前一年的备份)工作得很好,但第一部分(今年的备份)不起作用,我不知道为什么。我在这个网站上找到了该功能,但我想我的调用不知何故是错误的。
编辑:我现在使用的代码:
#!/bin/bash
read YEAR MONTH <<<$(date "+%Y %m")
LASTYEAR=$(( YEAR-1 ))
DAYS=" 07 14 21 28 "
for fn in $( ls )
do
if ([ "${fn:0:4}" = "$YEAR" ] &&
[ "${fn:5:2}" != "$MONTH" ] &&
[ "${DAYS/ ${fn:8:2} /}" = "$DAYS" ]) || ([ "${fn:0:4}" = "$LASTYEAR" ] &&
[ "${fn:8:2}" != ${DAYS:1:2} ])
then
#OUTPUT=`rm -v -R $fn`
echo "$fn"
fi
done
#!/bin/bash
read YEAR MONTH <<<$(date "+%Y %m")
LASTYEAR=$(( YEAR-1 ))
DAYS=" 07 14 21 28 "
for fn in $( ls )
do
DELETE=false
if [ "${fn:0:7}" = "$YEAR-$MONTH" ] &&
[ "${DAYS/ ${fn:8:2} /}" != "$DAYS" ]
then
DELETE=true
elif [ "${fn:0:4}" = "$LASTYEAR" ] &&
[ "${fn:8:2}" != ${DAYS:1:2} ]
then
DELETE=true
fi
if [ "$DELETE" = true ]
then
#OUTPUT=`rm -v -R $fn`
echo "$fn"
fi
done
假设文件名与以下日期格式匹配YYYY-MM-DD
例如2014-03-27
,表达式${fn:0:7}
将是2014-03
; ${fn:8:2}
会27
; ${fn:0:4}
会2014
.
阅读有关参数扩展的 bash 手册页。
表达式${DAYS/ ${fn:8:2} /}
从文件名(用空格括起来)检查日期,可在DAYS
列表中找到。这相当于echo "${DAYS}" | grep -q "${BACKUP_DAY}"
.
注意:可以减少for
循环中的命令(通过||
连接if
和elif
,并删除DELETE
变量检查和DELETE
变量本身),但我决定保留原始脚本的外观。