問題:nginx會憑據nginx.conf的設置生成access.log和error.log,跟著會見量的增長,日志文件會越來越大,既會影響會見的速度(寫入日志時間耽誤),也會增加查找日志的難度,nginx沒有這種按天或更細粒度生成日志的機制,所以需要本身添加按時任務,英國服務器 俄羅斯主機,支解日志文件。
1.新建支解日志文件的劇本,譬喻存放路徑:/usr/local/nginx/sbin/cut_nginx_logs.sh,按天支解詳細內容:
#!/bin/bash
#function:cut nginx log files for lnmp v0.5 and v0.6
#author: http://lnmp.org
#set the path to nginx log files
log_files_path="/data/nginxlog/"
log_files_dir=${log_files_path}
#set nginx log files you want to cut
log_files_name=(access )
#set the path to nginx.
nginx_sbin="/usr/local/nginx/sbin/nginx"
#Set how long you want to save
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]}.log_$(date -d "yesterday" +"%Y-%m-%d")
done
#delete 30 days ago nginx log files
find $log_files_path -mtime +$save_days -exec rm -rf {} ;
$nginx_sbin -s reload
2.將劇本添加到按時任務中,我指定天天0點執行
//打開按時任務
crontab -e
//進入編輯模式
i
//添加按時任務
00 00 * * * /bin/sh /usr/local/nginx/sbin/cut_nginx_logs.sh
//生存退出
:wq
//查察按時任務,就會看到你添加的內容了
crontab -l
3.查察實際結果