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 {} \;语句,来对日志文件进行清理。

其他自动清除日志脚本

  1. #!/bin/sh
  2. ###########################
  3. #delete log blog.duplicatedcode.com
  4. # in_day_num: like 1 2 is delete 2day ago logs
  5. # in_log_path like tomcat log home
  6. ###########################
  7. in_log_path=${1}
  8. in_day_num=${2}
  9. tmp_delete_log=/var/log/deletelog/"`date +%Y%m`.log"
  10. deleteLog()
  11. {
  12. inner_num=${1}
  13.    #find log
  14.    echo "[`date`] >> start delete logs---" >> $tmp_delete_log
  15.    find ${in_log_path} -type f -mtime ${inner_num} -print0 | xargs -0 rm -rf
  16.    echo "[`date`] >> end delete logs---" >> $tmp_delete_log
  17. }
  18. init()
  19. {
  20.    mkdir -p /var/log/deletelog/
  21. }
  22. main()
  23. {
  24.    init
  25.    if [ -z ${in_log_path} ]; then
  26.        echo "[`date`] >> error log_path not init---" >> $tmp_delete_log
  27.        return
  28.    fi
  29.    inner_day_num=+7
  30.    if [[ -n ${in_day_num} ]] && [[ ${in_day_num} -ge 1 ]] ; then
  31.        ${inner_day_num}=${in_day_num}
  32. else
  33. ${inner_day_num}="+"${in_day_num}
  34.    fi
  35.    deleteLog ${inner_day_num}
  36. }
  37. #first run main
  38. main

其中可输入日志所在目录和删除时间(如数字1代表1天前),find -type f -print 时会根据换行或者空格来输出查找的文件,在不同的sh下有不同的反应,如果不做处理结合xargs 进行删除操作,会有影响,所以需要增加-print0用 null来作为边界符号,才敢结合 xargs -0来格式化输入。使用find 的时候 遵循最小结果集原则,find解析式从左到右,所有确保你在最左边的过滤符号能够过滤最大数据。
       该脚本可结合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的计划任务中:

  1. #! /bin/sh
  2. flags=-umc
  3. /usr/sbin/tmpwatch "$flags" -x /tmp/.X11-unix -x /tmp/.XIM-unix \
  4. -x /tmp/.font-unix -x /tmp/.ICE-unix -x /tmp/.Test-unix \
  5. -X '/tmp/hsperfdata_*' 10d /tmp
  6. /usr/sbin/tmpwatch "$flags" 30d /var/tmp
  7. for d in /var/{cache/man,catman}/{cat?,X11R6/cat?,local/cat?}; do
  8. if [ -d "$d" ]; then
  9. /usr/sbin/tmpwatch "$flags" -f 30d "$d"
  10. fi
  11. 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导致的程序已经打开文件句柄无法正确释放日志文件和写入、文件显示磁盘空间未释放等问题。

shell实例利用crontab自动清除日志的更多相关文章

  1. 利用python自动清除Android工程中的多余资源

    我们直接在公司项目中使用,效果良好! 分享出脚本代码,希望对Android研发的同学有帮助. 提示,初学python,开发环境是Sublime Text 2,直接Ctrl+B的,其他环境下没调试过.应 ...

  2. Rails -- 自动清除日志

    在开发模式中,开发环境日志会越来越大,所以需要设置自动清理,省内存. 在 config/initializers中新建一个文件 clear_blog.rb 编写如下代码 if Rails.env.de ...

  3. 利用crontab自动更新SVN代码

    shell.sh#!/bin/sh source ~/.bash_profile LANG=en_US.UTF- cd /opt/web/hzcms/ svn up >> /opt/web ...

  4. 利用shell脚本实现nginx 的logs日志分割

    Nginx 是一个非常轻量的 Web 服务器,体积小.性能高.速度快等诸多优点.但不足的是也存在缺点,比如其产生的访问日志文件一直就是一个,不会自动地进行切割,如果访问量很大的话,将 导致日志文件容量 ...

  5. SQL2005自动备份,定期删除的维护计划及自动定期清除日志

    作为一名DBA,他们最常见的日常任务是: 1)定期完成数据库的完全备份或差异备份.2)定期清理备份文件,因为存储空间有限,可能只需要保存一个时期段内的文件(比如一周内或一月内). 而如何做到这两点呢? ...

  6. Linux下自动清除MySQL日志文件

    MySQL运行过程中会生成大量的日志文件,占用不少空间,修改my.cnf文件配置bin-log过期时间,在Linux下自动清除MySQL日志文件 [mysqld] expire-logs-days= ...

  7. shell清除日志小脚本

    #!/bin/bash #清除日志脚本 LOG_DIR=/var/log ROOT_UID=0 #用户id为0的 ,即为root if [ "$UID" -ne "$RO ...

  8. (转)shell实例手册

    原文地址:http://hi.baidu.com/quanzhou722/item/f4a4f3c9eb37f02d46d5c0d9 实在是太好的资料了,不得不转 shell实例手册 0说明{ 手册制 ...

  9. shell 实例

    转载自:https://github.com/liquanzhou/ops_doc    这里只作为笔记使用,不做他用 shell实例手册 0 说明{ 手册制作: 雪松 更新日期: 2018-09-1 ...

随机推荐

  1. Locust 学习一 :初识

    之前就听过Locust是基于python的一款很好用的开源性能测试框架,一直没机会实践,正好这次项目上有个接口压测的小任务,就拿来练练手 安装:py -3 -m pip install locusti ...

  2. sqlserver 收缩数据库/文件

    /******************************/ 1.右键-属性-选项-简单模式 2.右键-任务-收缩-文件 3.右键-任务-收缩-数据库 /********************* ...

  3. Trie树详解(转)

    特别声明 本文只是一篇笔记类的文章,所以不存在什么抄袭之类的. 以下为我研究时参考过的链接(有很多,这里我只列出我记得的): Trie(字典树)的应用——查找联系人 trie树 Trie树:应用于统计 ...

  4. Python开发【初始篇】:Linux下安装Python3

    Linux系统默认自带python2.6的版本,这个版本被系统很多程序所依赖,所以建议不要轻易删除,除非你能解决其他程序的依赖问题.如果使用最新的Python3需要进行编译安装源码包,这样就对系统默认 ...

  5. jdk1.7/1.8 HashMap、ConcurrentHashMap详解

    摘要: 本文主要参考网上Blog(详见Reference)总结ConcurrentHashMap的各方面知识,方便复习 转自:https://my.oschina.net/hosee/blog/675 ...

  6. springmvc接收ajax传递的数组

    之前的方法我用字符串拼接.req.getParameter("参数名[]");或json方式.虽然都能用,但是都不太令我满意. 今天参考这个贴子,ajax添加 traditiona ...

  7. Windows网络发现无法启动

    解决方法: 运行services.msc命令,打开服务界面.分别将Function Discovery Resource Publication.SSDP Discovery.UPnP Device ...

  8. VS2015一新建项目就出现未将对象引用设置到对象的实例怎么办?[z]

    https://blog.csdn.net/tiandyoin/article/details/79722800 在控制面板-卸载或修复程序太麻烦,而且不一定保证解决,可以这样------打开--C: ...

  9. 将EditPad Lite 加入鼠标右键

    > 开始 > regedit 如图新建shell及command

  10. 使用tcpreply对DPDK进行压力测试(一台主机,2张网卡压测)

    使用tcpreply对DPDK进行压力测试 过往风萤 关注 2018.05.18 14:35* 字数 273 阅读 2评论 0喜欢 0 小公司没有testcenter之类的打流工具,并且内网流量比较小 ...