在實際生產環境中,tomcat的 catalina.out日誌預設是不切割的,由於看起來很不方便,以及在備份等方面都比較麻煩。是時候切割該文件了。 環境說明 centos 7.3 tomcat 8.5 1 安裝軟體 配置好epel 源 並安裝 配置epel源 wget O /etc/yum.repo ...
在實際生產環境中,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