我们平时用到的中间件有apache,nginx,tomcat等等,性能都非常不错,不同的语言使用不同的环境。每个中间件都有对应的日志分割工具,目的是为了更好的管理查看日志。分析系统的性能和瓶颈。今天这篇文章主要介绍了Tomcat 日志切割(logrotate)详细介绍的相关资料,需要的朋友可以参考下
logrotate是个强大的系统软件,它对日志文件有着一套完整的操作模式,譬如:转储、邮件和压缩等,并且默认logrotate加到cron(/etc/cron.daily/logrotate)作为每日任务执行。自动有了logrotate,我想不用再自己写日志切割脚本。
如下对Tomcat日志catalina.out日志切割
# ls -lh /usr/local/tomcat/logs/catalina.out -rw-r--r-- 1 www www 14M Aug 28 15:55 /usr/local/tomcat/logs/catalina.out
配置logrotate对catalina.out日志切割
# cat /etc/logrotate.d/tomcat /usr/local/tomcat/logs/catalina.out { daily rotate 5 missingok dateext compress notifempty copytruncate }
daily 指定转储周期为每天 rotate 5 指定日志文件删除之前转储的次数,0指没有备份,5指保留5个备份 missingok 如果日志不存在则忽略该警告信息 dateext 文件后缀是日期格式,也就是切割后文件是:xxx.log-20150828.gz compress 通过gzip压缩转储以后的日志(gzip -d xxx.gz解压) notifempty 如果是空文件的话,不转储 copytruncate 用于还在打开中的日志文件,把当前日志备份并截断
立即截断日志:
# logrotate --force /etc/logrotate.d/tomcat
效果如下:
# ls -lh /usr/local/tomcat/logs/catalina.out* -rw-r--r-- 1 www www 0 Aug 28 16:00 /usr/local/tomcat/logs/catalina.out -rw-r--r-- 1 www www 1.1M Aug 28 16:00 /usr/local/tomcat/logs/catalina.out-20150828.gz