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

访问日志:可以记录网站的访问情况,还可以在网站有异常发生时帮助我们定位问题,比如当有攻击时,是可以通过查看日志看到一些规律的。

静态元素:一个网站有很多元素,比如图片、js、css等静态文件,这些就是静态元素。QQ浏览器,按F12可以查看它的静态元素,Network。

要配置httpd访问日志,首先需要虚拟主机配置文件中定义访问日志的格式,打开虚拟主机配置文件:

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

</IFModule>

   ErrorLog "logs/111.com-error_log"

   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

格式定义在访问日志customlog的上面。

img:标签,标记。img除外的都记录进来。这些以gif、jpg等结尾的做个标记叫img。这个标签名字随意,叫abc也行。

解析:SetEnvIf Request_URI ".*\.gif$" img

          如果访问的Request_URI,除gif结尾的img的都记录进来。

解析:env=!img

        上面的以img都不会记录到日志里,排除这些img。

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

# curl -x192.168.93.130:80 111.com/lsjdlf.jpg1 -I

# curl -x192.168.93.130:80 111.com/lsjdlf.jpg -I

# tail -3 /usr/local/apache2.4/logs/111.com-access_log

192.168.93.130 - - [14/Apr/2018:17:33:04 +0800] "HEAD HTTP://111.com/lsjdlf.jpg1 HTTP/1.1" 404 - "-" "curl/7.29.0"  只记录了jpg1。

  平时我们看日志看的是请求过哪个页面,而不是这些图片,所有有必要做一个限制。


二、访问日志切割

每天有必要把日志做切割。

切割作用:防止磁盘写满,日后查看数据也方便查看。

# 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

rotatelogs:Apache自带的一个日志切割工具。

-l:让它以当前系统的时间为基准,如果不指定-l,就会以UTC格式,中国是CST,美国是UTC。

%Y%m%d:年月日。时间段是一天,换算成秒是86400秒。

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

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

此时再访问这个虚拟主机就会生成对应日期的访问日志。

# ls

111.com-access_20180414.log  111.com-error_log   abc.com-error_log  error_log

111.com-access_log           abc.com-access_log  access_log         httpd.pid


三、配置静态元素过期时间

304状态码:代表你所下载的东西已经缓存到本地了,不用再到服务器去下载,可以节省带宽,但是没有规定什么时候把缓存清理掉。

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

<IfModUle mod_expires.c>  //模块名:expires

   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>

定义它们的过期时间。

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

LoadModule expires_module modules/mod_expires.so打开这个模块

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

Ctrl+F5:强制刷新,把本地的缓存清空。

# curl -x 127.0.0.1:80 111.com/lb.jpg -I

HTTP/1.1 200 OK

Date: Sat, 14 Apr 2018 15:42:58 GMT  当前时间

Server: Apache/2.4.33 (Unix) PHP/7.1.6

Last-Modified: Tue, 20 Feb 2018 04:04:27 GMT

ETag: "5607b-5659ce81be8c0"

Accept-Ranges: bytes

Content-Length: 352379

Cache-Control: max-age=86400

Expires: Sun, 15 Apr 2018 15:42:58 GMT 过期时间和当前时间差24小时

Content-Type: image/jpe

如果不设置加载这个模块就不会有过期时间这一行,一般都会设置这个。


扩展 

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