如果使用LNMP网站环境的话,默认nginx只会生成一个访问日志,并且是在每天的积累,日志文件会变的非常大,如果需要做一下日志的分析,无论是使用脚本分析,还是把日志下载本地分析,都不太方便。每天分割Nginx的访问日志,有利于分析日志。 脚本内容: #!/bin/bash # a nginx access log segmentation shell script # www. cd /data/wslogs log_dir="/data/wslogs" time=`date +%Y%m%d` nginx_dir="/usr/local/webserver/nginx" #日志分割,按天分类 website=`ls $log_dir/access* | xargs -n 1 | cut -f 2 -d "."` for i in $website do mkdir -p $log_dir/backup/$time/$i mv $log_dir/access.$i.log $log_dir/backup/$time/$i/$time.log done $nginx_dir/sbin/nginx -s reload #删除所有超过7天日志。 if [ "`date +%a`" = "Sun" ]; then all_list=`ls $log_dir/backup | xargs -n 1` for del in $all_list do let results=$time-$del if [ $results -gt 7 ]; then rm -fr $log_dir/backup/$del fi done fi 需要注意的是:因为个人需要,Nginx访问日志命名格式必须是 代码中的一些位置参数可以根据自己需要修改,修改 |
|