Ubuntu下使用cronolog对tomcat 8.5进行日志切割, 并设置定时清理日志

一、安装

    下载cronolog-1.6.2.tar.gz 并解压

        tar zxvf cronolog-1.6.2.tar.gz

    进入安装目录

        cd cronolog-1.6.2

    运行安装 (这一步可能会遇到权限问题,有些用sudo的方式,我自己装的直接切换中root去安装啦)

        ./configure && make && make install

    查看cronolog安装后所在目录(验证安装是否成功)     

        # which cronolog

    一般情况下显示为:/usr/local/sbin/cronolog,则表示安装成功。

二、修改配置

2.1 修改Tomcat

    修改/bin目录下的catalina.sh文件。

    使用vim编辑catalina.sh文件,搜索关键字:       

        if [ -z "$CATALINA_OUT" ] ; then

          CATALINA_OUT=日志路径/catalina.out

        fi 

    修改为       

        if [ -z "$CATALINA_OUT" ] ; then

            CATALINA_OUT=日志路径/catalina.%Y-%m-%d.out

        fi

    查找   touch "$CATALINA_OUT",后将其注释掉   

        #touch "$CATALINA_OUT"
    查找         
           org.apache.catalina.startup.Bootstrap "$@" start \
           >> "$CATALINA_OUT"   2>&1 &

    修改为                  

           org.apache.catalina.startup.Bootstrap "$@" start 2>&1 \
           | /usr/local/sbin/cronolog "$CATALINA_OUT" >> /dev/null &

    这个有两处地方,都要改,改完后重启tomcat即可完成配置(注意这个方式适用于tomcat8以上,如果Tomcat7请看下面)

2.2 Tomcat7以前的版本:

  (1)注释掉(#)     

            touch “$CATALINA_BASE”/logs/catalina.out

  (2)tomcat bin目录下的catalina.sh文件中的两处     

            org.apache.catalina.startup.Bootstrap “$@” start  \ 
            >> “$CATALINA_BASE”/logs/catalina.out 2>&1 &

      修改为   

            org.apache.catalina.startup.Bootstrap "$@" start  2>&1 \
            | /usr/local/sbin/cronolog "$CATALINA_BASE"/logs/catalina.%Y-%m-%d.out >> /dev/null &

      完成之后重起Tomcat就可以了。


三、使用crontab定时任务设置定时清除日志

    首先新建一个xxx.sh文件在其中录入,并保存。

#!/bin/sh
find /usr/local/apache-tomcat-8.5.15/logs/ -mtime +1 -name "*.out" -exec rm -rf {} \;
find /usr/local/apache-tomcat-8.5.15/logs/ -mtime +1 -name "*.log" -exec rm -rf {} \; 
find /usr/local/apache-tomcat-8.5.15/logs/ -mtime +1 -name "*.txt" -exec rm -rf {} \;

    随后使用crontab -e命令打开定时任务配置文件,在里面录入 10 0 * * *  sh 目录/xxx.sh > /dev/null 2>&1   即可完成配置,即删除1天之前的后缀名为out, log和txt的文件。

    查看日志cron

            ubuntu默认没有开启cron日志记录 
            1. 修改rsyslog 
                sudo vim /etc/rsyslog.d/50-default.conf 文件中
                cron.* /var/log/cron.log #将cron前面的注释符去掉 
            2.重启rsyslog 
                sudo service rsyslog restart 
            3.查看crontab日志 
                tail -f /var/log/cron.log

稍微解释下crontab中每行的含义。crontab中的每一行代表一个定期执行的任务,分为6个部分。前5个部分表示何时执行命令,最后一个部分表示执行的命令。每个部分以空格分隔,除了最后一个部分(命令)可以在内部使用空格之外,其他部分都不能使用空格。前5个部分分别代表:分钟,小时,天,月,星期,每个部分的取值范围如下: 

分钟          0 - 59

小时          0 - 23

天              1 - 31

月              1 - 12

星期          0 - 6       0表示星期天

除了这些固定值外,还可以配合星号(*),逗号(,),和斜线(/)来表示一些其他的含义:

星号          表示任意值,比如在小时部分填写 * 代表任意小时(每小时)

逗号          可以允许在一个部分中填写多个值,比如在分钟部分填写 1,3 表示一分钟或三分钟

斜线          一般配合 * 使用,代表每隔多长时间,比如在小时部分填写 */2 代表每隔两分钟。所以 */1 和 * 没有区别

                  */2 可以看成是能被2整除的任意值。

以下是一些例子(省略了命令部分):

* * * * *                  # 每隔一分钟执行一次任务  
0 * * * *                  # 每小时的0点执行一次任务,比如6:00,10:00  
6,10 * 2 * *            # 每个月2号,每小时的6分和10分执行一次任务  
*/3,*/5 * * * *          # 每隔3分钟或5分钟执行一次任务,比如10:03,10:05,10:06  

猜你喜欢

转载自blog.csdn.net/wy8227754/article/details/80320816