удаление старых файлов с помощью crontab

Я использую следующую запись crontab для ежедневного резервного копирования моей БД:

0 2 * * * MYSQL_PWD=password mysqldump -u user db_name > $HOME/db_backups/db_name-$(date +%Y-%m-%d-%H-%M).sql 2>> $HOME/db_backups/cron.log

Я хочу добавить еще одну запись crontab, которая удалит дампы БД, которые старше одного месяца.

какие мысли?

3 ответов


просто создайте еще один cron:

0 3 * * * find $HOME/db_backups -name "db_name*.sql" -mtime +30 -exec rm {} \; >> $HOME/db_backups/purge.log 2>&1

он найдет все резервные копии старше 30 дней и удалит их.


find /db_backups/ -mtime +30 -delete

эта команда удалит резервные копии БД старше 30 дней.


существует инструмент под названием tmpreaper Это безопасно удаляет файлы, соответствующие определенным критериям, таким как Дата доступа или изменения n дней в прошлом.