Apache服务器的日志(LOG)定制

  • 时间:2011-7-6 23:6:58  评论:10  浏览:   引用:0

我们在很多情况下需要定制Apache服务器(HTTPD)的日志(LOG)。比如为了防止Apache LOG文件过大需要定制apache服务器的LOG文件名,对于某些特定的URL比如图片等的访问不记录LOG等。

1,apache服务器LOG文件名的定制(按时间自动命名)

apache自带了名为一个rotatelogs的组件,可以通过配置达到LOG文件定制的目的。打开httpd.conf文件:例:

TransferLog "|/usr/local/apache2/bin/rotatelogs /usr/local/apache2/logs/access_log 86400" TransferLog "|/usr/local/apache2/bin/rotatelogs /usr/local/apache2/logs/error_log 86400"

参数1:rotatelogs的路径/文件名。以 | 接头。参数2:LOG文件的路径/文件名参数3:LOG文件创建的滚动时间(単位:秒)。上面86400为每24小时重新写入新的LOG文件。

2,apache服务器不记录图片文件的访问LOG

很多情况,我们没必要让apache服务器记录图片/Javascript/CSS等文件的访问LOG,同样可以通过设置httpd.conf来达到目的。打开httpd.conf文件:例(Addmodule的以下任意位置):

LoadModule setenvif_module modules/mod_setenvif.so AddModule mod_setenvif.c SetEnvIf Request_URI "/.(gif)|(jpg)|(jpeg)|(js)|(css)|(png)$" no_access_log

将默认设置

CustomLog /var/log/httpd/access_log combined

修改为:

CustomLog /usr/local/apache2/logs/access_log combined env=!no_access_log

重新启动apache

#httpd restart

如此,Apache便会按时自动在新的LOG文件记录日志,也不会记录对图片/Javascript/css文件的访问日志。

apache2 设置

apache2的情况下,如果只有rotatelogs2,可以做类似如下设置:

LoadModule setenvif_module modules/mod_setenvif.so SetEnvIf Request_Method "(GET)|(POST)|(PUT)|(DELETE)|(HEAD)" log SetEnvIf Request_URI "(/.gif|/.jpe?g|/.png|/.css|/.js|/.ico|/image_thumb)$" !log NameVirtualHost * <VirtualHost *> ServerName www.your-domain.com ServerAlias your-domain.com *.your-domain.com CustomLog "|/usr/sbin/rotatelogs2 /var/log/apache2/your-domain-access_log.%Y%m%d 86400 +540" combined env=log </VirtualHost>
Tags: Apache  log  
 
  •  3.美女
    看到博主的三无 我来了 你信不信 反正我信
    • JockChen1 于 2011-8-8 12:04:11 回复
      Stop
  • 2011-8-4 23:19:34 回复该留言
  •  10.兼职会计
    第一次到访你的博客,文章写的很不错,希望博主也到我网站回访。
  • 2011-9-11 16:00:19 回复该留言

发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。