Tomcat 日志切割 catalina.out

在实际生产环境中,tomcat的 catalina.out日志认是不切割的,由于看起来很不方便,以及在备份等方面都比较麻烦。是时候切割该文件了。

环境说明

centos 7.3

tomcat 8.5

1 安装软件

配置好epel 源 并安装

yum install cronolog -y

配置epel源
wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo
详情请参考 https://mirrors.aliyun.com/help/epel
不嫌麻烦的话那就可以编译安装吧,此处不做介绍

2 修改catalina.sh文件

一共修改四处

vim catalina.sh
199 # Add on extra jar files to CLAsspATH
200 if [ ! -z "$CLAsspATH" ] ; then
201   CLAsspATH="$CLAsspATH":
202 fi
203 CLAsspATH="$CLAsspATH""$CATALINA_HOME"/bin/bootstrap.jar
204 
205 if [ -z "$CATALINA_OUT" ] ; then
第一处 大约在206行
206   CATALINA_OUT="$CATALINA_BASE"/logs/catalina.out
	改为
		CATALINA_OUT="$CATALINA_BASE"/logs/catalina.%Y-%m-%d.out
        修改Catalina.out认的输出格式,此处加上时间,方便识别,也可以把.out 改为其他类型,如log,txt等
207 fi
416   shift
第二处  大约在417 行
417   touch "$CATALINA_OUT"
		改为 #touch "$CATALINA_OUT" (即注释掉)
418   if [ "$1" = "-security" ] ; then
419     if [ $have_tty -eq 1 ]; then
420       echo "Using Security Manager"
421     fi
422     shift
423     eval $_NOHUP "\"$_RUNJAVA\"" "\"$LOGGING_CONfig\"" $LOGGING_MANAGER $JAVA_OPTS $CATALINA_OPTS \
424       -classpath "\"$CLAsspATH\"" \
425       -Djava.security.manager \
426       -Djava.security.policy=="\"$CATALINA_BASE/conf/catalina.policy\"" \
427       -Dcatalina.base="\"$CATALINA_BASE\"" \
428       -Dcatalina.home="\"$CATALINA_HOME\"" \
429       -Djava.io.tmpdir="\"$CATALINA_TMPDIR\"" \
第三处 	大约在430行
430       org.apache.catalina.startup.Bootstrap "$@" start \
431       >> "$CATALINA_OUT" 2>&1 "&"
		改为
		     org.apache.catalina.startup.Bootstrap "$@" start 2>&1 \
			|/usr/sbin/cronolog "$CATALINA_OUT"  &
           说明: /usr/sbin/cronolog 为cronolog认安装目录,如果编译安装,此处写编译安装的目录。下同
433   else
434     eval $_NOHUP "\"$_RUNJAVA\"" "\"$LOGGING_CONfig\"" $LOGGING_MANAGER $JAVA_OPTS $CATALINA_OPTS \
435       -classpath "\"$CLAsspATH\"" \
436       -Dcatalina.base="\"$CATALINA_BASE\"" \
437       -Dcatalina.home="\"$CATALINA_HOME\"" \
438       -Djava.io.tmpdir="\"$CATALINA_TMPDIR\"" \
第四处 大约在439行
439       org.apache.catalina.startup.Bootstrap "$@" start \
440       >> "$CATALINA_OUT" 2>&1 "&"
		改为
		     org.apache.catalina.startup.Bootstrap "$@" start 2>&1 \
			|/usr/sbin/cronolog "$CATALINA_OUT" &
441 
442   fi

3 重启tomcat

到此 切割 catalina.out 的工作就完成了

可以看到日志文件 catalina.out 已经按日期显示

相关文章

一 、安装solr 环境说明:centos 7.3,solr 6.6,zookeeper3...
tomcat 日志说明 配置文件server.xml 默认日志格式为 推荐使...
在实际生产环境中,tomcat的 catalina.out日志默认是不切割的...
简介: SSL 协议的3个特性: 保密:通过SSL链接传输的数据是...
遵循Java Servlet 规范第4节中的建议 ,Apache Tomcat实现了...