Tomcat日志切割(logrotate)

    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  
    Tue Sep 1 09:44:01 CST 2015
    • 本文由 发表于 2015-09-01
    • 转载请务必保留本文链接:https://linuxeye.com/428.html
    Tomcat启动脚本 脚本

    Tomcat启动脚本

    记录一个比较好的tomcat启动脚本,截取《OneinStack》,修改如下两个参数即可用。 使用之前修改下面2个参数: #Location of JAVA_HOME (bin files) expo...
    tomcat配置及优化 Linux

    tomcat配置及优化

    jdk安装 su - root mkdir jdk cd jdk wget https://mirror.its.sfu.ca/mirror/CentOS-Third-Party/NSG/common...
    logrotate轮询nginx日志 Linux

    logrotate轮询nginx日志

    Linux日志文件如果不定期清理,会填满整个磁盘。这样会很危险,因此日志管理是系统管理员日常工作之一。我们可以使用”logrotate”来管理linux日志文件,它可以实现日志的自动滚动,日志归档等功...
    匿名

    发表评论

    匿名网友

      • 深蓝 深蓝

        表示关注,目前catalina.out动不动就50G朝上,头疼。