Chinaunix首页 | 论坛 | 博客
  • 博客访问: 4212822
  • 博文数量: 291
  • 博客积分: 8003
  • 博客等级: 大校
  • 技术积分: 4275
  • 用 户 组: 普通用户
  • 注册时间: 2010-10-30 18:28
文章分类

全部博文(291)

文章存档

2017年(1)

2013年(47)

2012年(115)

2011年(121)

2010年(7)

分类: LINUX

2012-04-14 22:13:02

由于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.创建日志分割脚本

点击(此处)折叠或打开

  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.最终效果
阅读(30047) | 评论(7) | 转发(2) |
给主人留下些什么吧!~~

Joker_ora2015-07-21 12:56:55

你好   能问几个问题吗,1.如果我进程重启管道文件怎么办   2.如果我想查看当天的访问日志怎么办,导出吗,如果导出那我今天进行日志切割时,这部分导出的不就不全了?

神谕丶2015-01-16 17:56:38

如果在生产环境中用kill的方法有什么问题么

yxs02012014-09-17 11:04:49

楼主方法可用,但是没有用nginx中定义的log_format

yxs02012014-09-17 09:58:08

shangguan86:您好,按照您的方法配置好,nginx无法启动了,启动是检测语法ok但就是一直过不去。请问是什么问题!

这个配置过程就只动过nginx.conf  你把access_log 修改成access.log 就可以了

回复 | 举报

shangguan862014-06-11 12:34:01

您好,按照您的方法配置好,nginx无法启动了,启动是检测语法ok但就是一直过不去。请问是什么问题!