Cronolog日志分割、定时清理

阿里云发送短信提示服务器磁盘占用到80%警报短信
经过排查发现tomcat日志文件达到10个多G,手动删除过久的日志文件后恢复到50%
但是catalina.out文件还有6个G
解决方法

一、安装Cronolog

1.下载(最新版本)
cronolog-1.6.2.tar.gz
2. 解压缩
tar zxvf cronolog-1.6.2.tar.gz
3. 进入安装目录
cd cronolog-1.6.2
4. 运行安装
./configure
make
make install
5. 查看是否安装成功
which cronolog
结果:/usr/local/sbin/cronolog (这个是cronolog的安装路径,后面会用到)
 

二、修改Tomcat下bin/catalina.sh文件

修改要分隔的Tomcat的日志下bin/catalina.sh文件,要修改的在417行。修改前先拷贝一份。
 
1. cp catalina.sh catalina.sh.bak
2. vim catalina.sh -c 417  或者  vim catalina.sh之后:417    (进入到catalina.sh的第417行。)
下面为修改后的内容:
 
上面的touch "$CATALINA_OUT"注释掉
后面2段修改为:
      org.apache.catalina.startup.Bootstrap "$@" start 2>&1 \
      | /usr/local/sbin/cronolog "$CATALINA_OUT" >> /dev/null &
 
 修改后,重启Tomcat。可以看到更改已经生效。(看到catalina.out出现了catalina.out.2018-11-26等按照日期分类的输出文件说明配置成功)。
 
注意:之后再查看日志则是 tail -f -n 100 ./logs/catalina.out.2018-11-26
将其写作shell文件show_log.sh放入服务器中
DATE=`date +%Y-%m-%d`
echo $DATE
outFile_1=./logs/catalina.out.
outFile=${outFile_1}${DATE}
echo $outFile
tail -f -n 100 $outFile
 
 
三、加上定时任务自动清理日志文件
每5分钟执行一次
*/5 * * * * /bin/sh /yourendailv/yourendai/logs/clean.sh >/dev/null 2>&1
每5天的凌晨一点执行一次
0 1 */5 * * /bin/sh /yourendai/server/yourendai/log/clean.sh >/dev/null 2>&1
 
执行定时任务时,如果是执行脚本,尽量在脚本前面带上/bin/sh命名,否则有可能因为忘了为脚本设定执行权限,从而无法完成任务。
 
crontab -e 编辑定时任务
crontab -l 查看当前的定时任务
/sbin/service crond restart  定时任务重启
tail -f /var/log/cron 定时任务日志查看
 
 

猜你喜欢

转载自www.cnblogs.com/tristralin/p/10185521.html
今日推荐