首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > Web前端 >

nginx日记按照天进行分割

2013-02-15 
nginx日志按照天进行分割由于nginx的日志本身只是支持按照server_name或者大小进行划分,对于习惯了apache

nginx日志按照天进行分割

由于nginx的日志本身只是支持按照server_name或者大小进行划分,对于习惯了apache的按照一个网站每天一个日志的我来说是不可以接受的,于是从网上找了几个nginx按天分割的方法发现都是互相抄袭的,特别是里面有一个命令是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/rotatelogs2.创建有名管道?
  • mkdir /opt/nginx_logs/abc_www/
  • mkfifo /opt/nginx_logs/abc_www/access_log3.在nginx配置文件server中加上
  • access_log /opt/nginx_logs/abc_www/access_log;4.创建日志目录
  • mkdir /opt/nginx_logs/abc_www/log/5.创建日志分割脚本
  • [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;
  • done6.创建启动日志分割脚本
  • [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.最终效果nginx日记按照天进行分割?转自:http://blog.chinaunix.net/uid-11121450-id-3177198.html

  • 热点排行