nginx日志分割 for linux
更新時間:2013年11月25日 11:31:16 作者:
默認情況下,nginx是不分割訪問日志的,久而久之,網站的日志文件將會越來越大,占用空間不說,如果有問題要查看網站的日志的話,龐大的文件也將很難打開,于是便有了下面的腳本
使用方法,先將以下腳本保存為 cutlog.sh,放在/root 目錄下,然后給予此腳本執(zhí)行的權限
復制代碼 代碼如下:
chmod +x cutlog.sh
然后使用crontab -e 將此腳本加入到計劃任務中,
復制代碼 代碼如下:
00 00 * * * /bin/bash /root/cutlog.sh
讓此腳本每天凌晨0點0分執(zhí)行。
復制代碼 代碼如下:
#!/bin/bash
#function:cut nginx log files shell
#設置您的網站訪問日志保存的目錄,我的統(tǒng)一放在了/home/wwwlogs目錄下
log_files_path="/home/wwwlogs/"
log_files_dir=${log_files_path}$(date -d "yesterday" +"%Y")/$(date -d "yesterday" +"%m")
#設置你想切割的nginx日志文件名稱,比如設置的日志文件名是52listen.com.log 的話,那這里直接填寫 52listen.com 即可
log_files_name=(52listen.com access)
#設置nginx執(zhí)行文件的路徑。
nginx_sbin="/usr/local/nginx/sbin/nginx"
#設置你想保存的日志天數,我這里設置的是保存30天之前的日志
save_days=30
############################################
#Please do not modify the following script #
############################################
mkdir -p $log_files_dir
log_files_num=${#log_files_name[@]}
#cut nginx log files
for((i=0;i<$log_files_num;i++));do
mv ${log_files_path}${log_files_name[i]}.log ${log_files_dir}/${log_files_name[i]}_$(date -d "yesterday" +"%Y%m%d").log
done
#delete 30 days ago nginx log files
find $log_files_path -mtime +$save_days -exec rm -rf {} \;
$nginx_sbin -s reload
相關文章
nginx+apache+mysql+php+memcached+squid搭建集群web環(huán)境
當前,LAMP開發(fā)模式是WEB開發(fā)的首選,如何搭建一個高效、可靠、穩(wěn)定的WEB服務器一直是個熱門主題,本文就是這個主題的一次嘗試。2011-03-03
如何實現(xiàn)Nginx同一端口同時支持http與https協(xié)議
最近有一個需求,需要讓一個端口的http服務支持https訪問,本文就來介紹一下如何實現(xiàn)Nginx同一端口同時支持http與https協(xié)議,感興趣的可以了解一下2023-11-11
詳解Nginx 13: Permission denied 解決方案
這篇文章主要介紹了詳解Nginx 13: Permission denied 解決方案,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-07-07

