可以在apache的httpd.conf配置文件中配置apache自带的程序rotatelogs的功能。
rotatelogs是一个配合Apache管道日志功能使用的简单程序,
参考资料:http://httpd.apache.org/docs/current/mod/mod_log_config.html
https://www.howtoforge.com/setenvif_apache2/
1 每天生成新日志
CustomLog "|/usr/sbin/rotatelogs /etc/httpd/logs/access_log_%Y-%m-%d 86400 480" combined
2 日志超过一定大小生成新日志
CustomLog "|/usr/sbin/rotatelogs /etc/httpd/logs/access_log_%Y-%m-%d 5M" combined
3 rotatelogs语法
rotatelogs [ -l ] logfile [ rotationtime [ offset ]] | [ filesizeM ]
-
它加上基准名就是日志文件名。如果
logfile中包含"%",则它会被视为用于
strftime()
的格式字符串;否则它会被自动加上以秒为单位的" .nnnnnnnnnn"后缀。这两种格式都表示新的日志开始使用的时间。 - 日志文件滚动的以秒为单位的间隔时间。
-
相对于UTC的时差的分钟数。如果省略,则假定为"0"并使用UTC时间。比如,要指定UTC时差为"-5小时"的地区的当地时间,则此参数应为"
-300
"。 -
指定以
filesizeM
文件大小滚动,而不是按照时间或时差滚动。
logfile
rotationtime
offset
filesizeM
4、设置只记录htm、html、php的访问记录
apache下两种方式:
1.只记录html,htm,php等文件
SetEnvIfNoCase Request_URI "(\.htm|\/|\.html|\.php)$" htm
CustomLog logs/9enjoy.com-access_log combined env=htm
2.排除法:
<FilesMatch “\.(ico|gif|jpg|png|bmp|swf|js|css)”>
SetEnv IMAGE 1
</FilesMatch>
CustomLog logs/9enjoy.com-access_log combined env=!IMAGE
推荐一篇比较全的文章:
http://wenku.baidu.com/link?url=gVPt1ga1H7w7AZ4hXwA97h36B5_yF6V3fB2KSm0zSS-2yuZTDpdYFPiiUbxhD6TP3CVNAnxL9yEGh7-E6I7pYTyY1-iT3rZgOrraJvpk9m7