cronolog分割Tomcat catalina.out日誌

分類:IT技術 時間:2016-10-12
linux上tomcat的日誌輸出在catalina.out裏面,隨著時間的推移,產生的日誌文件會越來越大,其主要是調試中打印的一些信息占空間,比如說system.out和log等等。tomcat 的catalina.out文件的不斷擴大,導致系統磁盤空間邊變小,也不方便查看,所以使用cronolog按日期分割日誌(例子裏面以天為分割單位)。
  • cronolog安裝

  1. # tar zxvf cronolog-1.6.2.tar.gz
    # cd cronolog-1.6.2
    # ./configure
    # make
    # make install
  • 查看cronolog安裝後所在目錄(驗證安裝是否成功)

    # which cronolog

    正常情況下顯示:

    /usr/local/sbin/cronolog

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

    Tomcat7以前的版本:

    (1)註釋掉(#)

    touch “$CATALINA_BASE”/logs/catalina.out

    (2)修改tomcat bin目錄下的catalina.sh文件中的兩處

    org.apache.catalina.startup.Bootstrap “$@” start  \

    >> “$CATALINA_BASE”/logs/catalina.out 2>&1 &

    org.apache.catalina.startup.Bootstrap "$@" start  2>&1 \

    | /usr/local/sbin/cronolog "$CATALINA_BASE"/logs/catalina.%Y-%m-%d.out >> /dev/null &

  • 完成之後重起Tomcat就可以看到logs文件中存在catalina.out.2015-09-13樣式的日誌。
  • Tomcat7以後的版本:
    1  第一步

    if [ -z "$CATALINA_OUT" ] ; then

    CATALINA_OUT="$CATALINA_BASE"/logs/catalina.out

    fi

    修改為

    if [ -z "$CATALINA_OUT" ] ; then


    CATALINA_OUT="$CATALINA_BASE"/logs/catalina.%Y-%m-%d.out

    fi

  • 2  第二步

    touch "$CATALINA_OUT"

    改為

    #touch "$CATALINA_OUT"

  • 3  第三步

    org.apache.catalina.startup.Bootstrap "$@" start \

    >> "$CATALINA_OUT"  2>&1 &

    修改為

    org.apache.catalina.startup.Bootstrap "$@" start 2>&1 \

    | /usr/local/sbin/cronolog "$CATALINA_OUT" >> /dev/null &
  • 或者進行下面的操作步驟效果一樣(推薦):

# vi bin/catalina.sh

找到下面這行

      org.apache.catalina.startup.Bootstrap "$@" start \
      >> "$CATALINA_OUT" 2>&1 &

類似這樣的行有2處,第一處是tomcat時帶“-security”參數的啟動,第二處是默認tomcat啟動方式,也就是else下面的那部分,我們只修改這裏。

另外還要把touch “$CATALINA_OUT"這行註釋掉。

完整的修改如下:   #touch "$CATALINA_OUT"   if [ "$1" = "-security" ] ; then      ........   else eval "\"$_RUNJava\"" "\"$LOGGING_CONFIG\"" $LOGGING_MANAGER $JAVA_OPTS $CATALINA_OPTS \ -Djava.endorsed.dirs="\"$JAVA_ENDORSED_DIRS\"" -classpath "\"$CLASSPATH\"" \ -Dcatalina.base="\"$CATALINA_BASE\"" \ -Dcatalina.home="\"$CATALINA_HOME\""  -Djava.io.tmpdir="\"$CATALINA_TMPDIR\"" \   org.apache.catalina.startup.Bootstrap "$@" start 2>&1 \ | /usr/local/sbin/cronolog "$CATALINA_BASE"/logs/catalina.%Y-%m-%d.out >>/dev/null & fi

完成之後重起Tomcat就可以看到logs文件中存在catalina.out.2015-09-13樣式的日誌。

更多Tomcat相關教程見以下內容

CentOS 6.6下安裝配置Tomcat環境 

RedHat Linux 5.5安裝JDK+Tomcat並部署Java項目   

Tomcat權威指南(第二版)(中英高清PDF版+帶書簽)   

Tomcat 安全配置與性能優化  

Linux下使用Xshell查看Tomcat實時日誌中文亂碼解決方案  

CentOS 64-bit下安裝JDK和Tomcat並設置Tomcat開機啟動操作步驟  

CentOS 6.5下安裝Tomcat   

本文永久更新鏈接地址


Tags: touch local Linux start null

文章來源:


ads
ads

相關文章
ads

相關文章

ad