一、安装
下载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