天天看點

Tomcat 日志分割.

一、前言

   随着每天業務的增長,Tomcat 的catalina.out日志 變得越來越大,占用磁盤空間不說。要檢視某個時候的日志的時候,龐大的日志讓你頓時無從下手,是以日志的切割的變得刻不容緩。而且,切割後的日志,還可以定期清理掉久遠的日志......

二、Tomcat 日志分割

    我們采用日期形式切割catalina.out 日志,是以采用cronlog 軟體切割:

1、安裝 cronlog 

yum install -y cronolog httpd

2、修改bin/catalina.sh檔案

(1)   if [ -z "$CATALINA_OUT" ] ; then

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

fi

改為:

if [ -z "$CATALINA_OUT" ] ; then

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

(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/sbin/cronolog "$CATALINA_OUT" >> /dev/null&

備注:這裡有兩處這個樣子的,似乎改下面那處就可以了,我是把兩處都改了...

Tomcat 日志分割.

3、重新開機服務即可。

Tomcat 日志分割.

tips:不能再用原來的catalina.out 來輸出日志了哦,因為剛剛不是被我們注釋掉了...

Tomcat 日志分割.

三、定時清理日志

    想要寫一個Shell腳本,定期清理掉久遠的日志檔案 ,避免磁盤不斷被占用。

1、建立Shell 腳本:

 touch auto_del_log.sh

 chmod +x auto_del_log.sh

Tomcat 日志分割.
Tomcat 日志分割.
#!/bin/sh
find /usr/local/fz_regulator/logs/ -mtime +60 -name "*.out" -exec rm -rf {} \;
find /usr/local/fz_middlekey/logs/ -mtime +60 -name "*.out" -exec rm -rf {} \;      

View Code 

find:linux的查找指令,使用者查找指定條件的檔案;

/usr/local/fz_middlekey/logs/:想要進行清理的任意目錄;

-mtime:标準語句寫法;

+60:查找60天前的檔案,這裡用數字代表天數;

"*.out":希望查找的資料類型,"*.jpg"表示查找擴充名為jpg的所有檔案,"*"表示查找所有檔案,這個可以靈活運用,舉一反三;

-exec:固定寫法;

rm -rf:強制删除檔案,包括目錄;

{} \; :固定寫法,一對大括号+空格+\+; 

2、安裝定時器 crontabs

yum install crontabs

/sbin/service crond start //啟動服務

3、加入定時任務

crontab -e //編輯目前使用者的crontab檔案,可指定具體的使用者

加入我們的定時任務(表示每天4點10分跑一次腳本):10 4 * * * /usr/local/auto_del_log.sh >/dev/null 2>&1