mysql 7天后自动删除_Linux下设置自动删除N天前备份

find /data1/mysqldata/mysqlbackup/  -name gongwuyuan*.gz -mtime +30 -type f -exec rm {} \;

#!/bin/sh

/usr/local/services/mysql5.1.57/bin/mysqldump -uroot --opt --default-character-set=utf8 gongwuyuan | gzip > /data1/mysqldata/mysqlbackup/gongwuyuan.`date +%Y%m%d`.sql.gz

find /data1/mysqldata/mysqlbackup/ -name gongwuyuan*.gz -mtime +30 -type f -exec rm {} \;

语句写法:

find 对应目录 -mtime +天数 -name "文件名" -exec rm -rf {} \;

例1:

find /usr/local/backups -mtime +10 -name "*.*" -exec rm -rf {}

\;

将/usr/local/backups目录下所有10天前带"."的文件删除

find:Linux的查找命令,用户查找指定条件的文件

/usr/local/backups:想要进行清理的任意目录

-mtime:标准语句写法

+10:查找10天前的文件,这里用数字代表天数,+30表示查找30天前的文件

"*.*":

希望

查找的数据类型,"*.jpg"表示查找扩展名为jpg的所有文件,"*"表示查找所有文件,这个可以灵活运用,举一反三

-exec:固定写法

rm -rf:强制删除文件,包括目录

{} \; :固定写法,一对大括号+空格+\+;

若嫌每次手动执行语句太麻烦,可以将这小语句写到一个可执行文件中,再设置cron调度执行,那就可以让系统自动去清理相关文件。

例2:

1.#touch /usr/local/bin/clear

#chmod 777 clear

新建一个可执行文件clear

2.vi clear

编辑clear文件如下:

#!/bin/sh

find /usr/local/backups -mtime +10 -name "*.*" -exec rm -rf {}

\;

ok,保存退出

3.#crontab -e

将clear文件加入到系统计划任务,到点自动执行

输入:

* 2 * * */usr/local/bin/clear

这里的设置是每天凌晨2点执行clear文件进行数据清理,可以研究一下cron,制定自己需要的计划任务

示例:

#!/bin/sh

find /usr/local/jboss-4.2.3.GA/server/default/log -mtime +6

-name "server.log.*" -exec rm -rf {} \;

exit

[root@web3 ~]# crontab -l

* 2 * * * sh /root/AutoDelLog.sh

这样每天晚上2点执行这个脚本,脚本是删除6天前的文件

find /etc/rc.d -name '*crond' -exec file {}

\;

查找/etc/rc.d目录下面所有以crond结束的文件,并使用file指令查看其属性,注意:exec和file间是一个空格,file和{}间是一个空格,{}和\;之间是一个空格,\;是一个整体。

分享到:

18e900b8666ce6f233d25ec02f95ee59.png

72dd548719f0ace4d5f9bca64e1d7715.png

2011-07-06 21:00

浏览 1395

评论

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值