Nginx日志按照天进行分割

由于Nginx的日志本身只是支持按照server_name或者大小进行划分,对于习惯了apache的按照一个网站每天一个日志的我来说是不可以接受的,于是从网上找了几个Nginx按天分割的方法发现都是互相抄袭的,特别是里面有一个命令是kill -9 `cat Nginx.pid`,需要杀掉Nginx子进程,我觉得不靠谱。

我忽然想到我以前在做openstack的云存储开发时,对rsyslog的日志进行分割的方法,一用果然好用

原理是:

1.从一台已经安装好apache的机器上的apache bin目录下把rotatelogs拷贝到本机的/opt/nginx_logs下

mkdir -p /opt/nginx_logs 

cp rotatelogs /opt/nginx_logs/ 

chmod +x /opt/nginx_logs/rotatelogs 

2.创建有名管道

mkdir /opt/nginx_logs/abc_www/ 

mkfifo /opt/nginx_logs/abc_www/access_log 

3.在nginx配置文件server中加上

access_log /opt/nginx_logs/abc_www/access_log;

4.创建日志目录

mkdir /opt/nginx_logs/abc_www/log/

5.创建日志分割脚本,防止rotatelogs被kille掉

[root@localhost nginx_logs]# cat /opt/nginx_logs/abc_www/rotate.sh 

baselogdir=/opt/nginx_logs/abc_www 

rotatelogs=/opt/nginx_logs/rotatelogs 

while [ 1 ] 

do 

echo `date +"%F %T"`" rotatelogs access start" 

$rotatelogs $baselogdir/log/access_%Y%m%d.log 86400 480 < $baselogdir/access_log 

echo `date +"%F %T"`" rotatelogs access stop" 

sleep 1; 

done 

6.创建启动日志分割脚本

[root@localhost nginx_logs]# cat /opt/nginx_logs/abc_www/run.sh 

sh /opt/nginx_logs/abc_www/rotate.sh >> /opt/nginx_logs/abc_www/log/access-rotate.log 2>&1 & 

7.最终效果

end

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://www.heiqu.com/0b954d8b6498020668a41b38bb9edfc4.html