Tomcat7 catalina.out 日志分割

最近由于工作需要,tomcat 的catalina.out文件的不断扩大,导致系统磁盘空间边变小,而且管理也难于管理,所以想用一种工具来分割它。网上找了找用cronolog

安装过程如下:

下载(最新版本)

    #  wget http://cronolog.org/download/cronolog-1.6.2.tar.gz

2、解压缩

    # tar zxvf cronolog-1.6.2.tar.gz

3、进入cronolog安装文件所在目录

    # cd cronolog-1.6.2

4、运行安装

    # ./configure
    # make
    # make install

5、查看cronolog安装后所在目录(验证安装是否成功)

    # which cronolog

一般情况下显示为:/usr/local/sbin/cronolog

要想分割tomcat7的catalina.out,需作如下工作:

进入Tomcat的bin目录,打开catalina.sh文件,一般我们修改下面行中的内容(因为我们一般不会在-security条件下运行),

    372  touch "$CATALINA_OUT"                                          # 注释改行
    373   if [ "$1" = "-security" ] ; then
    374     if [ $have_tty -eq 1 ]; then
    375       echo "Using Security Manager"
    376     fi
    377     shift
    378     eval \"$_RUNJAVA\" \"$LOGGING_CONFIG\" $JAVA_OPTS $CATALINA_OPTS \
    379       -Djava.endorsed.dirs=\"$JAVA_ENDORSED_DIRS\" -classpath \"$CLASSPATH\" \
    380       -Djava.security.manager \
    381       -Djava.security.policy==\"$CATALINA_BASE/conf/catalina.policy\" \
    382       -Dcatalina.base=\"$CATALINA_BASE\" \
    383       -Dcatalina.home=\"$CATALINA_HOME\" \
    384       -Djava.io.tmpdir=\"$CATALINA_TMPDIR\" \
    385       org.apache.catalina.startup.Bootstrap "$@" start \
    386       >> "$CATALINA_OUT" 2>&1 "&"
    387   else
    388     eval \"$_RUNJAVA\" \"$LOGGING_CONFIG\" $JAVA_OPTS $CATALINA_OPTS \
    389       -Djava.endorsed.dirs=\"$JAVA_ENDORSED_DIRS\" -classpath \"$CLASSPATH\" \
    390       -Dcatalina.base=\"$CATALINA_BASE\" \
    391       -Dcatalina.home=\"$CATALINA_HOME\" \
    392       -Djava.io.tmpdir=\"$CATALINA_TMPDIR\" \      
    393      org.apache.catalina.startup.Bootstrap "$@" start \
    394           >> "$CATALINA_OUT" 2>&1 "&"                                   # 修改改行
    395   fi
    396 
    397   if [ ! -z "$CATALINA_PID" ]; then
    398     echo $! > "$CATALINA_PID"
    399   fi
  需要修改的有两处:

     1.  注释  第372行 ,结果为 # touch "$CATALINA_OUT"

     2. 修改第393,394行,更改的结果为 org.apache.catalina.startup.Bootstrap "$@" start 2>&1 | /usr/local/sbin/cronolog "$CATALINA_BASE"/logs/catalina.%Y-%m-%d        .out >> /dev/null &

    3. 重启tomcat即可以生成格式如catalina.2013-05-20.out

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
要实现按天分片分割tomcat日志catalina.out,你可以按照以下步骤进行操作: 1. 首先,在tomcat的bin目录下找到catalina.sh或catalina.bat文件(根据你的系统选择),在其中加入以下配置: ```bash CATALINA_OUT=$CATALINA_BASE/logs/catalina.`date +%Y-%m-%d`.out CATALINA_OPTS="$CATALINA_OPTS -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager \ -Djava.util.logging.config.file=$CATALINA_BASE/conf/logging.properties \ -Djava.util.logging.FileHandler.pattern=$CATALINA_BASE/logs/catalina.%g.%u.log \ -Djava.util.logging.FileHandler.limit=10000000 \ -Djava.util.logging.FileHandler.count=10 \ -Djava.util.logging.FileHandler.level=FINE \ -Djava.util.logging.FileHandler.formatter=org.apache.juli.OneLineFormatter \ -Djava.util.logging.SimpleFormatter.format=\"%4\$s: %1\$tY-%1\$tm-%1\$td %1\$tH:%1\$tM:%1\$tS %5\$s%6\$s%n\"" ``` 2. 然后,在tomcat的conf目录下找到logging.properties文件,将以下配置加入到文件中: ```bash 1catalina.org.apache.juli.FileHandler.level = FINE 1catalina.org.apache.juli.FileHandler.directory = ${catalina.base}/logs 1catalina.org.apache.juli.FileHandler.prefix = catalina. 1catalina.org.apache.juli.FileHandler.suffix = .%g.%u.log 1catalina.org.apache.juli.FileHandler.maxFileSize = 10000000 1catalina.org.apache.juli.FileHandler.maxFiles = 10 1catalina.org.apache.juli.FileHandler.formatter = org.apache.juli.OneLineFormatter ``` 3. 最后,重新启动tomcat即可按天分割catalina.out日志文件,生成的日志文件以catalina.YYYY-MM-DD.out命名,存储在logs目录下。 注意,以上配置中的日志文件分割规则为每个文件大小不超过10M,最多保留10个文件。你可以根据需要进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值