一、访问日志不记录静态文件

网站大多元素为静态文件,如图片、css、js等,这些元素可以不用记录

把虚拟主机配置文件改成如下:
vim /usr/local/apache2.4/conf/extra/httpd-vhosts.conf

   SetEnvIf Request_URI ".*\.gif$" img
   SetEnvIf Request_URI ".*\.jpg$" img
   SetEnvIf Request_URI ".*\.png$" img
   SetEnvIf Request_URI ".*\.bmp$" img
   SetEnvIf Request_URI ".*\.swf$" img
   SetEnvIf Request_URI ".*\.js$" img
   SetEnvIf Request_URI ".*\.css$" img

   CustomLog "logs/111.com-access_log" combined env=!img

【LAMP环境搭建】访问日志不记录静态、访问日志切割和静态元素过期时间


重新加载配置文件:
/usr/local/apache2.4/bin/apachectl -t
/usr/local/apache2.4/bin/apachectl graceful
【LAMP环境搭建】访问日志不记录静态、访问日志切割和静态元素过期时间


进入对应的目录并上传一张图片:

cd /data/wwwroot/111.com/
【LAMP环境搭建】访问日志不记录静态、访问日志切割和静态元素过期时间

再查看一下日志,就可以看到并没有png的日志:

curl -x127.0.0.1:80 111.com/baidu.png  -I
cat /usr/local/apache2.4/logs/111.com-access_log

【LAMP环境搭建】访问日志不记录静态、访问日志切割和静态元素过期时间


二、访问日志切割

 日志一直记录总有一天会把整个磁盘占满,所以有必要让它自动切割,并删除老的日志文件 


 把虚拟主机配置文件改成如下: 

vim /usr/local/apache2.4/conf/extra/httpd-vhosts.conf


CustomLog "|/usr/local/apache2.4/bin/rotatelogs -l logs/111.com-access_%Y%m%d.log 86400"  combined env=!img

【LAMP环境搭建】访问日志不记录静态、访问日志切割和静态元素过期时间


 

重新加载配置文件:
/usr/local/apache2.4/bin/apachectl -t
/usr/local/apache2.4/bin/apachectl graceful

访问一下:

curl -x127.0.0.1:80 111.com/123.php


再查看一下路径生成了对应的带日期的日志:
 ls /usr/local/apache2.4/logs/

【LAMP环境搭建】访问日志不记录静态、访问日志切割和静态元素过期时间


测试:

【LAMP环境搭建】访问日志不记录静态、访问日志切割和静态元素过期时间


三、静态元素过期时间

 浏览器访问网站的图片时会把静态的文件缓存在本地电脑里,这样下次再访问时就不用去远程下载了
 增加配置。

例子:我们先把/data/wwwroot/111.com下的baidu.png改名成qq.png,再按一下浏览器F12,可以看到状态是200,然后再刷新一下页面,状态变成304,这个304就是缓存下来的图片

【LAMP环境搭建】访问日志不记录静态、访问日志切割和静态元素过期时间



vim /usr/local/apache2.4/conf/extra/httpd-vhosts.conf:


<IfModule mod_expires.c>       //expires.c 定义过期时间
    ExpiresActive on                     //打开该功能的开关
    ExpiresByType image/gif  "access plus 1 days"
    ExpiresByType image/jpeg "access plus 24 hours"
    ExpiresByType image/png "access plus 24 hours"
    ExpiresByType text/css "now plus 2 hour"
    ExpiresByType application/x-javascript "now plus 2 hours"
    ExpiresByType application/javascript "now plus 2 hours"
    ExpiresByType application/x-shockwave-flash "now plus 2 hours"
    ExpiresDefault "now plus 0 min"
</IfModule> 

【LAMP环境搭建】访问日志不记录静态、访问日志切割和静态元素过期时间


查看expires_module模块有没有打开:

/usr/local/apache2.4/bin/apachectl -M |grep expire


如果没有再去主配置文件修改,将#去掉:

vim /usr/local/apache2.4/conf/httpd.conf

【LAMP环境搭建】访问日志不记录静态、访问日志切割和静态元素过期时间


再重新检测和加载:

/usr/local/apache2.4/bin/apachectl -t

/usr/local/apache2.4/bin/apachectl graceful


然后重新查看模块:

【LAMP环境搭建】访问日志不记录静态、访问日志切割和静态元素过期时间 


测试:curl -x127.0.0.1:80 111.com/qq.png -I 

【LAMP环境搭建】访问日志不记录静态、访问日志切割和静态元素过期时间


(也可以直接浏览器访问111.com/qq.png,按F12来查看)


 扩展 :

apache日志记录代理IP以及真实客户端IP :
http://ask.apelearn.com/question/960 

apache只记录指定URI的日志 :
http://ask.apelearn.com/question/981 

apache日志记录客户端请求的域名 :
http://ask.apelearn.com/question/1037 

apache 日志切割问题 :
http://ask.apelearn.com/question/566 

相关文章: