自动删除oracle下的过期文件命令
2015-01-23 17:11
405 查看
linux下自动删除过期文件命令[@more@]
语句写法:
find 对应目录 -mtime +天数 -name "文件名" -exec rm -rf {} ;
例1:
find /home/oracle/app/oracle/diag/rdbms/orcl/orcl/trace -mtime +8 -name "orcl*" -exec rm -rf {} ;
将/home/oracle/app/oracle/diag/rdbms/orcl/orcl/trace目录下所有8天前带"orcl"的文件删除
find:linux的查找命令,用户查找指定条件的文件
/home/oracle/app/oracle/diag/rdbms/orcl/orcl/trace:想要进行清理的任意目录
-mtime:标准语句写法
+8:查找10天前的文件,这里用数字代表天数,+30表示查找30天前的文件
"orcl":希望查找的数据类型,"*.jpg"表示查找扩展名为jpg的所有文件,"*"表示查找所有文件,这个可以灵活运用,举一反三
-exec:固定写法
rm -rf:强制删除文件,包括目录
{} ; :固定写法,一对大括号+空格++;
若嫌每次手动执行语句太麻烦,可以将这小语句写到一个可执行文件中,再设置cron调度执行,那就可以让系统自动去清理相关文件。
例2:
1).#touch /usr/local/bin/clear
#chmod 777 clear
新建一个可执行文件clear
2).vi clear
编辑clear文件如下:
#!/bin/sh
find /home/oracle/app/oracle/diag/rdbms/orcl/orcl/trace -mtime +8 -name "orcl*" -exec rm -rf {} ;
ok,保存退出
3).#crontab -e
将clear文件加入到系统计划任务,到点自动执行
输入:
* 2 * * */usr/local/bin/clear
这里的设置是每天凌晨2点执行clear文件进行数据清理,可以研究一下cron,制定自己需要的计划任务
示例:
#!/bin/sh
find /home/oracle/app/oracle/diag/rdbms/orcl/orcl/trace -mtime +8 -name "orcl*" -exec rm -rf {} ;
exit
其他实例
把当前目录下面的file(不包括目录),移动到/opt/shell
find . -type f -exec mv {} /opt/shell \;
find . -type f | xargs -I '{}' mv {} /opt/shell
下面from http://weiruoyu.blog.51cto.com/951650/832497
find多少天以前的文件,按时间移动,并分批打包
显示前十个文件
[root@localhost smgpbi]# ls -1 | sort -u | head -10
1.首先查看文件个数,进入所在的文件
# find . -name "*" | wc -l
或者
# ll |grep "^-" |wc -l
2.查看文件个数
查看120天钱的文件个数
# find . -mtime +120 | wc -l
一般如果是小文件,控制在10-20万左右。
解释:-mtime +30 --设置时间为30天前;
-exec mv --查找完毕后执行移动操作;
3.按照时间移动到指定目录里
# find . -mtime +90 -exec mv {} /var/tmp/date_90 \;
4.计算大小
# du -sh [b]date_90[/b]
大小一般控制在10-15G最好
5.压缩并打包
#tar -zcvf date_90.tar.gz date_90/
语句写法:
find 对应目录 -mtime +天数 -name "文件名" -exec rm -rf {} ;
例1:
find /home/oracle/app/oracle/diag/rdbms/orcl/orcl/trace -mtime +8 -name "orcl*" -exec rm -rf {} ;
将/home/oracle/app/oracle/diag/rdbms/orcl/orcl/trace目录下所有8天前带"orcl"的文件删除
find:linux的查找命令,用户查找指定条件的文件
/home/oracle/app/oracle/diag/rdbms/orcl/orcl/trace:想要进行清理的任意目录
-mtime:标准语句写法
+8:查找10天前的文件,这里用数字代表天数,+30表示查找30天前的文件
"orcl":希望查找的数据类型,"*.jpg"表示查找扩展名为jpg的所有文件,"*"表示查找所有文件,这个可以灵活运用,举一反三
-exec:固定写法
rm -rf:强制删除文件,包括目录
{} ; :固定写法,一对大括号+空格++;
若嫌每次手动执行语句太麻烦,可以将这小语句写到一个可执行文件中,再设置cron调度执行,那就可以让系统自动去清理相关文件。
例2:
1).#touch /usr/local/bin/clear
#chmod 777 clear
新建一个可执行文件clear
2).vi clear
编辑clear文件如下:
#!/bin/sh
find /home/oracle/app/oracle/diag/rdbms/orcl/orcl/trace -mtime +8 -name "orcl*" -exec rm -rf {} ;
ok,保存退出
3).#crontab -e
将clear文件加入到系统计划任务,到点自动执行
输入:
* 2 * * */usr/local/bin/clear
这里的设置是每天凌晨2点执行clear文件进行数据清理,可以研究一下cron,制定自己需要的计划任务
示例:
#!/bin/sh
find /home/oracle/app/oracle/diag/rdbms/orcl/orcl/trace -mtime +8 -name "orcl*" -exec rm -rf {} ;
exit
其他实例
把当前目录下面的file(不包括目录),移动到/opt/shell
find . -type f -exec mv {} /opt/shell \;
find . -type f | xargs -I '{}' mv {} /opt/shell
下面from http://weiruoyu.blog.51cto.com/951650/832497
find多少天以前的文件,按时间移动,并分批打包
显示前十个文件
[root@localhost smgpbi]# ls -1 | sort -u | head -10
1.首先查看文件个数,进入所在的文件
# find . -name "*" | wc -l
或者
# ll |grep "^-" |wc -l
2.查看文件个数
查看120天钱的文件个数
# find . -mtime +120 | wc -l
一般如果是小文件,控制在10-20万左右。
解释:-mtime +30 --设置时间为30天前;
-exec mv --查找完毕后执行移动操作;
3.按照时间移动到指定目录里
# find . -mtime +90 -exec mv {} /var/tmp/date_90 \;
4.计算大小
# du -sh [b]date_90[/b]
大小一般控制在10-15G最好
5.压缩并打包
#tar -zcvf date_90.tar.gz date_90/
相关文章推荐
- Windows平台使用RMAN命令自动删除Oracle过期归档日志的方法
- Windows平台使用RMAN命令自动删除Oracle过期归档日志的方法
- CMD批处理——forfiles命令使用,自动删除过期备份文件
- 批处理实现自动删除过期文件的定期操作
- RMAN不会自动删除过期文件
- sql server2008 自动备份和自动删除过期bak文件
- Sql Server 备份文件管理(自动删除、过期)
- ORACLE 运用RMAN删除过期备份和日志文件 释放空间
- sql server2008R2自动备份和自动删除过期bak文件
- oracle导入dmp文件命令、sql文件命令, Oracle用户的新增、修改、删除及授权
- Sql Server 备份文件管理(自动删除、过期)
- centos6.5下oracle自动备份删除指定天数的文件
- Oracle学习笔记[1] - 自动逻辑备份并删除过期备份
- sql server2008R2自动备份和自动删除过期bak文件
- (windows)python脚本:自动备份并压缩文件,同时删除过期文件
- Oracle Rman备份脚本与自动删除重复备份文件
- windows下自动删除过期文件的脚本
- 批处理实现自动删除过期文件的定期操作
- 批处理实现自动删除过期文件的定期操作
- Centos自动删除过期备份或者文件