Tomcat 日誌分割.

1、前言

   隨着天天業務的增加,Tomcat 的catalina.out日誌 變得愈來愈大,佔用磁盤空間不說。要查看某個時候的日誌的時候,龐大的日誌讓你頓時無從下手,因此日誌的切割的變得刻不容緩。並且,切割後的日誌,還能夠按期清理掉久遠的日誌......linux

2、Tomcat 日誌分割

    咱們採用日期形式切割catalina.out 日誌,所以採用cronlog 軟件切割:apache

一、安裝 cronlog ide

yum install -y cronolog httpdspa

二、修改bin/catalina.sh文件日誌

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

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

改成:crontab

if [ -z "$CATALINA_OUT" ] ; then
CATALINA_OUT="$CATALINA_BASE"/logs/%Y-%m-%d.catalina.out
fiip

(2)  touch "$CATALINA_OUT"event

改成:

#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&

備註:這裏有兩處這個樣子的,彷佛改下面那處就能夠了,我是把兩處都改了...

三、重啓服務便可。

tips:不能再用原來的catalina.out 來輸出日誌了哦,由於剛剛不是被咱們註釋掉了...

 

3、定時清理日誌

    想要寫一個Shell腳本,按期清理掉久遠的日誌文件 ,避免磁盤不斷被佔用。

一、建立Shell 腳本:

 touch auto_del_log.sh

 chmod +x auto_del_log.sh

#!/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:強制刪除文件,包括目錄;
{} \; :固定寫法,一對大括號+空格+\+; 

二、安裝定時器 crontabs

yum install crontabs

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

三、加入定時任務

crontab -e //編輯當前用戶的crontab文件,可指定具體的用戶

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

相關文章
相關標籤/搜索