Tomcat的⽇志分割三种⽅法
⼀、Tomcat的⽇志分割三种⽅法
⼀、⽅法⼀:⽤cronolog分割tomcat的catalina.out⽂件
  Linux ⽇志切割⼯具cronolog详解:
  1、编译安装cronolog
wget /download/cronolog-1.6.
tar zxvf cronolog-1.6.
cd cronolog-1.6.2
./configure
make && make install
  2、查看cronolog安装后所在⽬录(验证安装是否成功)log4j2 appender
which cronolog
⼀般情况下显⽰为:/usr/local/sbin/cronolog
  3、编辑tomcat⽬录bin下的catalina.sh⽂件
  到下⾯这⾏,类似这样的⾏有2处:
org.apache.catalina.startup.Bootstrap "$@" start \
>> "$CATALINA_OUT"2>&1 &
1.   第⼀处:tomcat是带“-security”参数的启动,
2.   第⼆处:默认tomcat启动⽅式,也就是else下⾯的那部分,我们只修改这⾥。
3.   另外还要把touch “$CATALINA_OUT"这⾏注释掉。
#  touch "$CATALINA_OUT"
if [ "$1" = "-security" ] ; then
if [ $have_tty -eq 1 ]; then
echo"Using Security Manager"
fi
shift
"$_RUNJAVA""$LOGGING_CONFIG" $LOGGING_MANAGER $JAVA_OPTS $CATALINA_OPTS \
-dorsed.dirs="$JAVA_ENDORSED_DIRS" -classpath "$CLASSPATH" \
-Djava.security.manager \
-Djava.security.policy=="$CATALINA_BASE"/conf/catalina.policy \
-Dcatalina.base="$CATALINA_BASE" \
-Dcatalina.home="$CATALINA_HOME" \
-pdir="$CATALINA_TMPDIR" \
org.apache.catalina.startup.Bootstrap "$@" start \
>> "$CATALINA_OUT"2>&1 &
else
"$_RUNJAVA""$LOGGING_CONFIG" $LOGGING_MANAGER $JAVA_OPTS $CATALINA_OPTS \
-dorsed.dirs="$JAVA_ENDORSED_DIRS" -classpath "$CLASSPATH" \
-Dcatalina.base="$CATALINA_BASE" \
-Dcatalina.home="$CATALINA_HOME" \
-pdir="$CATALINA_TMPDIR" \
org.apache.catalina.startup.Bootstrap "$@" start 2>&1 | /usr/local/sbin/cronolog /usr/local/tomcat/logs/catalina.%Y%m%d.out >> /dev/null & #      >> "$CATALINA_OUT" 2>&1 &
fi
  4、重启tomcat
  查看⽇志⽬录是否⽣成dd.out的⽇志⽂件
  -rw-r--r-- 1 root root 10537 Jul 30 10:50 catalina.20140730.out
  配置cronolog完成了,观察每天是否有⼀个新的dd.out的⽇志⽂件⽣成,定期删除⽇期较旧的⽇志⽂件。⼆、⽅法⼆:使⽤log4j成功使catalina.out⽂件实现分割
  1、在tomcat根⽬录下建⽴common/classes/log4j.properties,内容如下
log4j.appender.R=org.apache.log4j.RollingFileAppender
log4j.appender.R.File=${catalina.home}/wlog  #设定⽇志⽂件名
log4j.appender.R.MaxFileSize=100KB  #设定⽂件到100kb即分割
log4j.appender.R.MaxBackupIndex=10  #设定⽇志⽂件保留的序号数
log4j.appender.R.layout=org.apache.log4j.PatternLayout
log4j.appender.R.layout.ConversionPattern=%p %t %c - %m%n
  2、在tomcat根⽬录下的common/lib下加⼊log4j.jar和commons-logging.jar
  3、重新启动tomcat即可。
三、编写⼀个.sh⽂件,并放到tomcat下的bin⽬录,在cron中⾃动执⾏,shell脚本如下:
#!/bin/bash
cd  `dirname $0`
d=`date +%Y%m%d`
d7=`date -d'7 day ago' +%Y%m%d`
cd  ../logs/
cp catalina.out catalina.out.${d}
echo"" > catalina.out
rm -rf catalina.out.${d7}