nginx日志按照天进行分割

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

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

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

 

 
 
  1. mkdir -p /opt/nginx_logs 
  2. cp rotatelogs /opt/nginx_logs/ 
  3. chmod +x /opt/nginx_logs/rotatelogs 

2.创建有名管道

 

 
 
  1. mkdir /opt/nginx_logs/abc_www/ 
  2. mkfifo /opt/nginx_logs/abc_www/access_log 

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

 

 
 
  1. access_log /opt/nginx_logs/abc_www/access_log; 

4.创建日志目录

 

 
 
  1. mkdir /opt/nginx_logs/abc_www/log/ 

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

 

 
 
  1. [root@localhost nginx_logs]# cat /opt/nginx_logs/abc_www/rotate.sh 
  2. baselogdir=/opt/nginx_logs/abc_www 
  3. rotatelogs=/opt/nginx_logs/rotatelogs 
  4. while [ 1 ] 
  5. do 
  6. echo `date +"%F %T"`" rotatelogs access start" 
  7. $rotatelogs $baselogdir/log/access_%Y%m%d.log 86400 480 < $baselogdir/access_log 
  8. echo `date +"%F %T"`" rotatelogs access stop" 
  9. sleep 1; 
  10. done 

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

 

 
 
  1. [root@localhost nginx_logs]# cat /opt/nginx_logs/abc_www/run.sh 
  2. sh /opt/nginx_logs/abc_www/rotate.sh >> /opt/nginx_logs/abc_www/log/access-rotate.log 2>&1 & 

7.最终效果

 

end

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值