当前位置: > Linux服务器 > nginx >

Nginx日志按天分割的方法分享(图文)

时间:2014-09-26 08:52来源:jbxue.com 作者:it

Nginx日志仅支持按照server_name或文件大小进行划分,有时需要实现类似apache服务器中按天生成日志的功能。

对于网上的一些文章,甚至用到命令kill -9 `cat Nginx.pid`,杀掉Nginx子进程,有点太疯狂。

以前在做openstack的云存储开发时,对rsyslog的日志进行分割的方法,参考其实现了nginx日志的分割。

原理:
 

日志原理分析

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被kill掉
 

复制代码代码示例:
[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,最终效果
 

<a  data-cke-saved-href=http://www.jbxue.com/article/11077.html href=http://www.jbxue.com/article/11077.html target=_blank class=infotextkey>nginx日志分割</a>效果

如此,便实现了nginx日志的按天分割,与apache中的一样了,也满足了需求,欢呼一下吧。

(责任编辑:IT)
------分隔线----------------------------
栏目列表
推荐内容