apache日志工具rotatelogs使用笔记

发布时间:2020-10-06编辑:脚本学堂
本文介绍下,有关apache的日志工具rotatelogs的使用方法,有需要的朋友参考下吧。

想使用apache的rotatelogs来分割apache日志
 

复制代码 代码示例:
CustomLog “|bin/rotatelogs /var/logs/logfile 86400″ common
 

需要两个小时生成一个apache日志,并以时间命名,于是修改httpd.conf
 

复制代码 代码示例:
CustomLog “|bin/rotatelogs /var/logs/%Y%m%d%H.logfile 7200″ common
 

重启apache失败。

修改为如下:
 

复制代码 代码示例:
CustomLog “|/usr/local/httpd/bin/rotatelogs /var/logs/%Y%m%d%H.logfile 7200″ common
 

修改后apache成功启动,但生成的日志文件名(以小时命名)有些问题,与服务器时间相差8小时。

原因在于:rotatelogs有个offset参数,单位是分钟:
CustomLog “|/usr/local/httpd/bin/rotatelogs /var/logs/%Y%m%d%H.logfile 7200 480″ common
重启后,就恢复正常了。

附,rotatelogs说明
rotatelogs logfile [ rotationtime [ offset ]] | [ filesizeM ]
选项
logfile
它加上基准名就是日志文件名。如果logfile中包含’%',则它会被视为用于的strftime(3)的格式字串;否则,它会被自动加上以秒为单位的.nnnnnnnnnn后缀。这两种格式都
表示新的日志开始使用的时间。

rotationtime
日志文件回卷的以秒为单位的间隔时间

offset
相对于UTC的时差的分钟数。如果省略,则假定为0,并使用UTC时间。比如,要指定UTC时差为-5小时的地区的当地时间,则此参数应为-300。

filesizeM
指定回卷时以兆字节为单位的后缀字母M的文件大小,而不是指定回卷时间或时差。