logrotate测试_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

}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值