一、原因

     写这篇的原因是项目中log没有定时清除,服务器上项目是用脚本启动,log文件只会在启动时生成一次,这时,由于项目在不断运行中,导致log越来越大。如果删除log文件,还得把项目停掉在启动,这样显然是不行的,而如果直接删掉log文件的话,后续的操作不会输出,也没有日志文件生成,这时就只能通过写个脚本定时去清除日志(每日一清)。     

二、方法

 

    这时我想的肯定是希望能写一个脚本把这些日志清除掉,但不是删除掉。那么现在需要实现3步:

         1.找到项目的log的位置

         2.清除log内容

         3.定时执行脚本

 

   有了思路,查找了资料后,找到了几个相关的命令: 

 

     find . -name 'p.*.log'

     .:具体目录下,建议最好写出查询的具体的目录,类似,/var/local/  

      'p*.log':模糊查询p开头.log结尾的文件

 

    find /var/local/ -name 'p*.log' -type f -print :将符合的文件打印出来:

   

linux java的程序清日志 linux日志清除_定时任务

 

   找到了log文件后这时我们只需要清除就好了:

   find -name -exec  command:find的常用命令结构中有这样一条,具体的可以自行去百度。

   清除文件的命令:

   truncate -s 0 aa.txt {} \;        : 切记,这里的“;”号不能省略, 意思是将aa.txt的大小变成0M,即把aa.txt的内容清空了。百度truncate的用法。

   rm -rf/-r  xxx   :这个是删除文件或文件夹,不能达到我的要求

 

   结合上面的命令,就有了如下这样一条:

    find /var/local/ -name 'p*.log' -type f -print -exec truncate -s 0 {} \;            : 将符合这样一个条件的文件查到出来并赋予它0M的大小。

 

  下面我们就可以清除日志的脚本了,如何写就不讲了:

                                                                                                   



1 #!/bin/bash 2 3 status(){ 4 date 5 find /var/local/ -name 'p*.log' -type f -print -exec truncate -s 0 {} \; 6 echo "清空log成功" 7 return 8 } 9 10 case "$1" in 11 status) 12 status;;*) 13 echo "清除失败" 14 esac



四、定时任务

    常用命令:

   crontab -l    :查看定时任务

   crontab -e    :添加任务

   crontab -r   :删除任务

   cat  /etc/crontab    :查看crontab文件

   

    现在我们来添加一条任务:

     59 23 * * * /var/local/clearlog.sh status >>/var/local/clear.txt        :每天23:59执行脚本并输出到clear.txt文件 ,定时任务的写法:*(分)  *(时) *(日) *(月) *(周)  command

 

     添加好后查看(crontab -l ),会发现有一条任务(为方便测试,这里可自行替换周期,如:*/1 * * * *   :每分钟执行一次 ):

    

linux java的程序清日志 linux日志清除_定时任务_02

   

     这是可能出现clear.txt生成了。但是没有内容,日志也没清除,这个原因可能是你没给这个脚本赋权限

     chmod 755 clearlog.sh


 

      PS:再解决这个问题过程中,碰到了一个问题,那就是在编辑一个文件时,写完后习惯性的CTRL+S,然后窗口就不能编辑了,退也退不了,后来查了,发现:

             Ctrl s    暂停该终端  (解决办法:Ctrl q)

             Ctrl c   中止当前正在执行的程序。
             Ctrl d   相当于exit命令

     OK。