作者:JMCui 來(lái)源:https://www.cnblogs.com/jmcui/p/8000552.html
一、前言
隨著每天業(yè)務(wù)的增長(zhǎng),Tomcat 的catalina.out日志 變得越來(lái)越大,占用磁盤(pán)空間不說(shuō)。要查看某個(gè)時(shí)候的日志的時(shí)候,龐大的日志讓你頓時(shí)無(wú)從下手,所以日志的切割的變得刻不容緩。而且,切割后的日志,還可以定期清理掉久遠(yuǎn)的日志……
二、Tomcat 日志分割
我們采用日期形式切割catalina.out 日志,因此采用cronlog 軟件切割:
1、安裝 cronlog
yum install -y cronolog httpd
2、修改bin/catalina.sh文件
第一步:
改為:
第二步:
touch "$CATALINA_OUT"
改為:
#touch "$CATALINA_OUT"
第三步:
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&
備注:這里有兩處這個(gè)樣子的,似乎改下面那處就可以了,我是把兩處都改了…
3、重啟服務(wù)即可。
tips:不能再用原來(lái)的catalina.out 來(lái)輸出日志了哦,因?yàn)閯倓偛皇潜晃覀冏⑨尩袅?hellip;
三、定時(shí)清理日志
想要寫(xiě)一個(gè)Shell腳本,定期清理掉久遠(yuǎn)的日志文件 ,避免磁盤(pán)不斷被占用。
1、創(chuàng)建Shell 腳本:
touch auto_del_log.sh chmod +x auto_del_log.sh
- find:linux的查找命令,用戶查找指定條件的文件;
- /usr/local/fz_middlekey/logs/:想要進(jìn)行清理的任意目錄;
- -mtime:標(biāo)準(zhǔn)語(yǔ)句寫(xiě)法;
- +60:查找60天前的文件,這里用數(shù)字代表天數(shù);
- ".out":希望查找的數(shù)據(jù)類(lèi)型,".jpg"表示查找擴(kuò)展名為jpg的所有文件,"*"表示查找所有文件,這個(gè)可以靈活運(yùn)用,舉一反三;
- -exec:固定寫(xiě)法;
- rm -rf:強(qiáng)制刪除文件,包括目錄;
- {} ; :固定寫(xiě)法,一對(duì)大括號(hào)+空格++;
2、安裝定時(shí)器 crontabs
yum install crontabs /sbin/service crond start //啟動(dòng)服務(wù)
3、加入定時(shí)任務(wù)
crontab -e //編輯當(dāng)前用戶的crontab文件,可指定具體的用戶
加入我們的定時(shí)任務(wù)(表示每天4點(diǎn)10分跑一次腳本):
10 4 * * * /usr/local/auto_del_log.sh >/dev/null 2>&1