shell实例利用crontab自动清除日志
程序运行会产生很多的日志,对于无用的日志手动删除比价麻烦,写一个自动执行的命令是很有必要的。
删除文件shell命令
find 对应目录 -mtime +天数 -name "文件名" -exec rm -rf {} \;
具体的命令如下:
find /mnt/tomcat/logs/ -mtime +35 -name "*.log" -exec rm -rf {} \;
参数及说明:
整句的作用是将 /mnt/tomcat/logs/目录下所有30天前带".log"的文件删除。
find:linux的查找命令,定位文件夹;
/mnt/tomcat/logs/:需要清理的目录;
-mtime:语法结构,固定写法;
+30:天数;
"*.log":*是匹配所有,整个是匹配所有的后缀为.log的文件;
-exec:语法结构,固定写法;
rm -rf:强制循环删除文件,及文件夹;
{} \; :语法结构,固定写法;
crontab计划任务使用
创建脚本文件:
#vi del-log.sh
切换到insert模式输入:
#!/bin/sh
find /mnt/tomcat/logs/ -mtime +35 -name "*.log" -exec rm -rf {} \;
授权:
chmod +x del-log.sh
增加系统计划任务:
crontab -e
11 11 * * * /mnt/tomcat/logs/del-log.sh >/dev/null 2>&1
这样每天11点11分系统就自动执行del-log.sh文件,即执行find /mnt/tomcat/logs/ -mtime +35 -name "*.log" -exec rm -rf {} \;语句,来对日志文件进行清理。
其他自动清除日志脚本
- #!/bin/sh
- ###########################
- #delete log blog.duplicatedcode.com
- # in_day_num: like 1 2 is delete 2day ago logs
- # in_log_path like tomcat log home
- ###########################
- in_log_path=${1}
- in_day_num=${2}
- tmp_delete_log=/var/log/deletelog/"`date +%Y%m`.log"
- deleteLog()
- {
- inner_num=${1}
- #find log
- echo "[`date`] >> start delete logs---" >> $tmp_delete_log
- find ${in_log_path} -type f -mtime ${inner_num} -print0 | xargs -0 rm -rf
- echo "[`date`] >> end delete logs---" >> $tmp_delete_log
- }
- init()
- {
- mkdir -p /var/log/deletelog/
- }
- main()
- {
- init
- if [ -z ${in_log_path} ]; then
- echo "[`date`] >> error log_path not init---" >> $tmp_delete_log
- return
- fi
- inner_day_num=+7
- if [[ -n ${in_day_num} ]] && [[ ${in_day_num} -ge 1 ]] ; then
- ${inner_day_num}=${in_day_num}
- else
- ${inner_day_num}="+"${in_day_num}
- fi
- deleteLog ${inner_day_num}
- }
- #first run main
- main
该脚本可结合crontab进行自动部署清理日志,在/var/log/deltelog/ 生成按照月的清理日志记录。
Linux下自动清理/tmp文件夹的原理
Linux系统中/tmp文件夹里面的文件会被清空,至于多长时间被清空,如何清空的?在linux中tmpwatch命令的作用是删除一段时间内不使用的文件(removes files which haven’t been accessed for a period of time),在/etc/cron.daily/tmpwatc的计划任务中:
- #! /bin/sh
- flags=-umc
- /usr/sbin/tmpwatch "$flags" -x /tmp/.X11-unix -x /tmp/.XIM-unix \
- -x /tmp/.font-unix -x /tmp/.ICE-unix -x /tmp/.Test-unix \
- -X '/tmp/hsperfdata_*' 10d /tmp
- /usr/sbin/tmpwatch "$flags" 30d /var/tmp
- for d in /var/{cache/man,catman}/{cat?,X11R6/cat?,local/cat?}; do
- if [ -d "$d" ]; then
- /usr/sbin/tmpwatch "$flags" -f 30d "$d"
- fi
- done
tmpwatch参数:
-a或–all 删除任何类型的文件。
-m或–mtime 根据文件被更改时间
-c或–ctime 根据文件更改状态时间
-M或–dirtime 根据文件夹被更改时间
-f或–force 强制删除文件或目录,其效果类似rm指令的”-f”参数。
-l 不删除符号链接
-U或–exclude-user=用户名或uid 排除某用户的文件
-x 或–exclude=path 排除某路径
-X 或–exclude-pattern=pattern 排除某规则下的路径
-q或–quiet 不显示指令执行过程。
-v或–verbose 详细显示指令执行过程。
-test 仅作测试,并不真的删除文件或目录。
第一行相当于一些标记(参数),第二行就是针对/tmp目录里面排除的目录,第三行,这是对这个/tmp目录的清理。/usr/sbin/tmpwatch "$flags" 30d /var/tmp中30d是30天,系统自动清理/tmp文件夹的默认时限是30天,决定了30天清理/tmp下不访问的文件,若想一天一清理的话,把30d改成1d。
如果你设置更短的时间来清理的话,比如说是30分钟、10秒等,在这个文件中设置后,reboot后时间到了也不清理/tmp文件夹里面的内容,因为tmpwatch所在的位置是/etc/cron.daily/目录下,而这个目录是每天执行一次计划任务,所以就不起作用了。
总结
(1)crontab定时任务在文件清理方面又很大的应用,可以设置关机任务、启动脚本和一些程序的检测操作。
(2)清除日志可采用cat /dev/null > /var/lig/messages,可以防止rm -f导致的程序已经打开文件句柄无法正确释放日志文件和写入、文件显示磁盘空间未释放等问题。