标签:
logrotate是个强大的系统软件,它对日志文件有着一套完整的操作模式,譬如:转储、邮件和压缩等,并且默认logrotate加到cron(/etc/cron.daily/logrotate)作为每日任务执行(腾云科技ty300.com)。自动有了logrotate,我想不用再自己写日志切割脚本。
如下对Tomcat日志catalina.out日志切割
$ ls -lh /usr/local/tomcat/logs/catalina.out
-rw-r--r-- 1 www www 14M Sep 13 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 Sep 13 16:00 /usr/local/tomcat/logs/catalina.out
-rw-r--r-- 1 www www 1.1M Sep 13 16:00 /usr/local/tomcat/logs/catalina.out-20160913.gz
欢迎关注运维自研堂订阅号,运维自研堂是一个技术分享平台,主要是运维自动化开发:linux、python、django、saltstack、tornado、bootstrap、redis、golang、docker、etcd等经验分享。
稿源:勤快学QKXue.NET
标签:
原文地址:http://www.cnblogs.com/qkxue/p/5880336.html