当前位置: > Linux服务器 > apache >

apache日志工具rotatelogs使用笔记

时间:2014-08-12 22:13来源:linux.it.net.cn 作者:it

想使用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的文件大小,而不是指定回卷时间或时差。

 
(责任编辑:IT)
------分隔线----------------------------