zoukankan      html  css  js  c++  java
  • tomcat日志切割方案

    方案一:使用Linux自带得日志切割工具logrotate按天切割

    /etc/logrotate.d下,新建tomcatrotate,编辑tomatrotate,写入如下内容:

    /usr/local/tomcat7.0.79/logs/catalina.out {
        daily
        rotate 15
        missingok
        dateext
        compress
        notifempty
        copytruncate
    }

        daily                指定转储周期为每天
        rotate 15         指定日志文件删除之前转储的次数,0指没有备份,5指保留5个备份
        missingok        如果日志不存在则忽略该警告信息
        dateext            文件后缀是日期格式,也就是切割后文件是:xxx.log-20150828.gz
        compress         通过gzip压缩转储以后的日志(gzip -d xxx.gz解压)
        notifempty       如果是空文件的话,不转储

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

     /usr/local/tomcat7.0.79/logs/catalina.out   指定catalina.out的路径

    方案二:使用脚本指定日志文件大小切割

    #!/bin/bash
    log_path=/app/userapp/devops/tomcat/logs
    date=`date +%Y-%m-%d`
    time=`date +%H%M%S`
    log_file=${log_path}/catalina.out
    log_size=`ls -l $log_file |awk '{print $5}'`
    maxsize=$((1024*1024*1024))
    L=`wc -l $log_file |awk '{print $1}'`
    if [ $log_size -ge $maxsize ]
    then
        head -$L $log_file > $log_path/catalina.$date-$time.out
        sed -i '1,'$L'd' $log_file
        gzip $log_path/catalina.$date-$time.out
    fi

    将脚本添加定时任务即可,对比下方案一可能会出现部分日志丢失情况,方案二则不会

  • 相关阅读:
    MySQL 安装
    MySQL简介
    图解十大经典的机器学习算法
    基于Python预测股价
    10_通过httprequest获取跟请求相关的信息
    07_参数提交时action的写法
    08_ServletConfig介绍
    05_servlet生命周期介绍
    06_url_pattern三种写法
    03_servletHello完成
  • 原文地址:https://www.cnblogs.com/goujinyang/p/13893922.html
Copyright © 2011-2022 走看看