一、访问日志不记录静态文件
把虚拟主机配置文件改成如下:
SetEnvIf Request_URI ".*\.gif$" 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
重新加载配置文件:
cd /data/wwwroot/111.com/
curl -x127.0.0.1:80 111.com/baidu.png -I
二、访问日志切割
日志一直记录总有一天会把整个磁盘占满,所以有必要让它自动切割,并删除老的日志文件
把虚拟主机配置文件改成如下:
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
访问一下:
curl -x127.0.0.1:80 111.com/123.php
ls /usr/local/apache2.4/logs/
测试:
三、静态元素过期时间
浏览器访问网站的图片时会把静态的文件缓存在本地电脑里,这样下次再访问时就不用去远程下载了
增加配置。
例子:我们先把/data/wwwroot/111.com下的baidu.png改名成qq.png,再按一下浏览器F12,可以看到状态是200,然后再刷新一下页面,状态变成304,这个304就是缓存下来的图片
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>
查看expires_module模块有没有打开:
/usr/local/apache2.4/bin/apachectl -M |grep expire
如果没有再去主配置文件修改,将#去掉:
vim /usr/local/apache2.4/conf/httpd.conf
再重新检测和加载:
/usr/local/apache2.4/bin/apachectl -t
/usr/local/apache2.4/bin/apachectl graceful
然后重新查看模块:
测试:curl -x127.0.0.1:80 111.com/qq.png -I
(也可以直接浏览器访问111.com/qq.png,按F12来查看)
apache只记录指定URI的日志
apache日志记录客户端请求的域名
apache 日志切割问题