一:建立指令檔
vim cut_nginx_log.sh
#!/bin/bash
#nginx access log segmentation shell script
#www.webyang.net
#日誌目錄
log_dir="/usr/local/nginx/logs/"
cd $log_dir
time=`date +%Y%m%d --date="-1 day"`
#nginx啟動目錄
nginx_dir="/etc/init.d/nginx"
#日誌儲存天數
save_days=15
#記錄檔名所處'/'分割的位置,key('/'數+1)
num=6;
#此處待最佳化(取得檔案不帶尾碼的檔案名稱)
website=`ls $log_dir*.log | xargs -n 1 | cut -f 1 -d "." | cut -f $num -d "/"`
#日誌目錄下所有的記錄檔為檔案夾,迴圈建立對應的時間檔案
for i in $website
do
#判斷目錄是否存在
if [ ! -d $log_dir$i ];then
mkdir "$i"
fi
mv $log_dir$i.log $log_dir$i/$i-$time.log
done
#刪除設定天數前的資料
find $log_dir/ -mtime +$save_days -exec rm -rf {} \;
#平滑啟動nginx
$nginx_dir reload
二、設定crontab,每天定時切割
如果沒有安裝,運行yum -y install crontabs 安裝。
輸入crontab -e命令,
輸入下面的內容:
00 00 * * * /bin/bash /usr/local/nginx/cut_nginx_log.sh
1、00 00意思為00分00點,也就是淩晨0點,後面“ * * * ”為“ 日 月 年 ”無需定義
2、"/usr/local/nginx/cut_nginx_log.sh" 為你的shell的路徑。
OK ! 大功告成,每天的0時就會自動完成日誌的切割並存在相應的以網站記錄檔命名的目錄中。
三、展示
web1.log => web1/web1-20160322.log web1/web1-20160323.log
web2.log => web2/web2-20160322.log web2/web2-20160323.log