Tomcat日志切割(logrotate)

2016-09-04 08:26:22 1750

logrotate是个强大的系统软件,它对日志文件有着一套完整的操作模式,譬如:转储、邮件和压缩等,并且默认logrotate加到cron(/etc/cron.daily/logrotate)作为每日任务执行。自动有了logrotate,我想不用再自己写日志切割脚本。
如下对Tomcat日志catalina.out日志切割

  1. # ls -lh /usr/local/tomcat/logs/catalina.out

  2. -rw-r--r-- 1 www www 14M Aug 28 15:55 /usr/local/tomcat/logs/catalina.out

配置logrotate对catalina.out日志切割

  1. # cat /etc/logrotate.d/tomcat

  2. /usr/local/tomcat/logs/catalina.out {

  3. daily

  4. rotate 5

  5. missingok

  6. dateext

  7. compress

  8. notifempty

  9. copytruncate

  10. }

参数详解:

  • daily    指定转储周期为每天

  • rotate 5    指定日志文件删除之前转储的次数,0指没有备份,5指保留5个备份

  • missingok    如果日志不存在则忽略该警告信息

  • dateext    文件后缀是日期格式,也就是切割后文件是:xxx.log-20150828.gz

  • compress    通过gzip压缩转储以后的日志(gzip -d xxx.gz解压)

  • notifempty    如果是空文件的话,不转储

  • copytruncate    用?还在打开中的日志文件,把当前日志备份并截断

立即截断日志:

  1. # logrotate --force /etc/logrotate.d/tomcat

效果如下:

  1. # ls -lh /usr/local/tomcat/logs/catalina.out*  

  2. -rw-r--r-- 1 www www    0 Aug 28 16:00 /usr/local/tomcat/logs/catalina.out  

  3. -rw-r--r-- 1 www www 1.1M Aug 28 16:00 /usr/local/tomcat/logs/catalina.out-20150828.gz  


提交成功!非常感谢您的反馈,我们会继续努力做到更好!

这条文档是否有帮助解决问题?

非常抱歉未能帮助到您。为了给您提供更好的服务,我们很需要您进一步的反馈信息:

在文档使用中是否遇到以下问题: