日誌切割的意義:
在生產環境中,當我們使用tomcat服務時,如果用戶量過多,有沒有日誌切割,將會產生很大的日誌,一天的日誌都能有好幾個G大小。當我們需要查看日誌記錄時,非常麻煩。因此,日誌切割是很有必要的!
1.編寫shell腳本
vim fengelog.sh
#腳本聲明
#!/bin/bash
. /etc/profile
. ~/.bash_profile
#定義日誌文件目錄
applog_path=/usr/local/apache-tomcat-app/logs
sapplog_path=/usr/local/apache-tomcat-sapp/logs
#定義日期格式
d=`date +%Y-%m-%d-%H:%M`
d15=`date -d'15 day ago' +%Y-%m-%d` #15天的日期
#切割日誌
cd ${applog_path} && cp catalina.out $applog_path/$d.log #日誌備份
echo > catalina.out #原日誌清空
rm -rf $applog_path/${d15}*.log #保留15天的日誌
cd ${sapplog_path} && cp catalina.out $sapplog_path/$d.log #日誌備份
echo > catalina.out #原日誌清空
rm -rf $sapplog_path/${d15}*.log #保留15天的日誌
2.執行shell腳本
chmod +x fengelog.sh
sh fengelog.sh
3.添加定時任務
crontab -e
0 */3 * * * sh /root/fengelog.sh
#設置每3個小時切割一次日誌
注意:
1.腳本中開頭. /etc/profile ,. ~/.bash_profile 是爲了讓定時任務可以成功執行添加的環境變量,如果不加,定時任務不會執行!
2.日誌保留的時間和一次切割tomcat日誌的數量,多長時間切割日誌都是可以自定義的。
3.建議腳本寫好後,先自己運行一下,確定沒有問題,在加入定時任務裏面!