logrotate进行nginx的日志轮转

logrotate是linux下自带的日志轮询工具。默认情况下,在/etc/cron.daily/目录下有一个logrotate脚本,我们只要把nginx的轮询脚本放在/etc/logrotate.d/下即可。

# cat /etc/logrotate.d/nginx
/usr/local/nginx/logs/*.log {
daily
missingok
rotate 7
compress
delaycompress
notifempty
sharedscripts
postrotate
   kill -USR1 `cat /usr/local/nginx/logs/nginx.pid`
endscript
}

注:同样可以发送HUP信号来达到日志轮询,即:/bin/kill -HUP `/bin/cat /usr/local/nginx/logs/nginx.pid`

具体每行的参数说明如下:

解释下每行的含义:
1. 指定nginx的日志路径,可以通过 * 通配,可以指定多个文件名
2. 每天执行一次日志轮询
3. 即使日志不存在也继续执行
4. 保留7个备份
5. 开启日志压缩
6. 在下一次轮询时再进行日志压缩
7. 文件日志为空时不进行轮询
8. 有多个日志需要轮询时,只执行一次脚本
9. 最后三行表示日志轮询之后要执行的脚本。postrotate/prerotate和endscript必须成对,缺一不可。

如果想在日志后面加上日期,可以在上面再增加dateext参数:

dateext:日志rotate后再后面加日期

例如:access.log轮转后会变为access.log-20130803

测试配置是否生效,可以使用如下命令测试:

/usr/sbin/logrotate -f /etc/logrotate.conf

看看/usr/local/nginx/logs/下面是否有类似access.log-20130804的log生成 。

后记:

据说下面的脚本也可以实现,未具体验证:

#cat /etc/logrotate.d/nginx
/logs/nginx/error.log
/logs/nginx/image.361way.access.log
/logs/nginx/www.361way.access.log
{
        daily
        missingok
        rotate 30
        start 1
        compress
        copytruncate
        notifempty
        sharedscripts
        postrotate
          /usr/bin/killall -HUP syslogd 2> /dev/null || true
          create 0640 root root
        endscript
}

还没有评论,快来抢沙发!

发表评论

  • 😉
  • 😐
  • 😡
  • 😈
  • 🙂
  • 😯
  • 🙁
  • 🙄
  • 😛
  • 😳
  • 😮
  • emoji-mrgree
  • 😆
  • 💡
  • 😀
  • 👿
  • 😥
  • 😎
  • ➡
  • 😕
  • ❓
  • ❗
  • 69 queries in 0.067 seconds