知识屋:更实用的电脑技术知识网站
所在位置:首页 > 操作系统 > linux

nginx日志按照天进行分割

发布时间:2014-09-05 15:44:30作者:知识屋


nginx日志按照天进行分割
 
由于nginx的日志本身只是支持按照server_name或者大小进行划分,对于习惯了apache的按照一个网站每天一个日志的我来说是不可以接受的,于是从网上找了几个nginx按天分割的方法发现都是互相抄袭的,特别是里面有一个命令是kill -9 `cat nginx.pid`,需要杀掉nginx子进程,我觉得不靠谱。
  www.zhishiwu.com  
我忽然想到我以前在做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.创建有名管道
   www.zhishiwu.com  
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 
  www.zhishiwu.com  
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
 
(免责声明:文章内容如涉及作品内容、版权和其它问题,请及时与我们联系,我们将在第一时间删除内容,文章内容仅供参考)
收藏
  • 人气文章
  • 最新文章
  • 下载排行榜
  • 热门排行榜