42.访问日志不记录静态文件访问日志切割静态元素过期时间
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了42.访问日志不记录静态文件访问日志切割静态元素过期时间相关的知识,希望对你有一定的参考价值。
一、apache静态元素过期时间
- 网站大多元素为静态文件,如图片、css、js等,这些元素可以不用记录
mkdir /data/wwwroot/123.com/images //创建目录,并在这目录下上传一个图片
curl -x127.0.0.1:80 -I 123.com/images/123.jpg
然后查看日志
tail /usr/local/apache2.4/logs/123.com-access_log
这时候日志是有记录的
vim /usr/local/apache2.4/conf/extra/httpd-vhosts.conf
把虚拟主机配置文件改成如下:
<VirtualHost *:80>
DocumentRoot "/data/wwwroot/www.123.com"
ServerName www.123.com
ServerAlias 123.com
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/123.com-access_log" combined env=!img
</VirtualHost>
重新加载配置文件
/usr/local/apache2.4/bin/apachectl -t
/usr/local/apache2.4/bin/apachectl graceful
再次测试,日志文件已经不记录jpg文件的访问记录
二、访问日志切割
日志一直记录总有一天会把整个磁盘占满,所以有必要让它自动切割,并删除老的日志文件
- 把虚拟主机配置文件改成如下:
<VirtualHost *:80> DocumentRoot "/data/wwwroot/www.123.com" ServerName www.123.com ServerAlias 123.com 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 "|/usr/local/apache2.4/bin/rotatelogs -l logs/123.com-access_%Y%m%d.log 86400" (-l是指定当前系统时间分隔,86400是指一天之后重新生成另一个,以每天0点开始) combined env=!img </VirtualHost>
- 重新加载配置文件
/usr/local/apache2.4/bin/apachectl -t /usr/local/apache2.4/bin/apachectl graceful
- 随便访问一下网站,可以看到llogs目录下生成了日期前缀的log文件
三、静态元素过期时间
浏览器访问网站的图片时会把静态的文件缓存在本地电脑里,这样下次再访问时就不用去远程下载了
这里我们设置各类元素缓存的到期时间
- 增加配置
<IfModule mod_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 expires
如果不存在则打开apache配置文件加载插件
vim /usr/local/apache2.4/conf/httpd.conf
- 重新加载配置文件
/usr/local/apache2.4/bin/apachectl -t /usr/local/apache2.4/bin/apachectl graceful
- 修改前后测试数据的返回结果不同,修改后Cache-Control: max-age=0就是缓存生效时间,现在是每次都需要重新加载
Expires:需要再次加载的时间
- 修改前后测试数据的返回结果不同,修改后Cache-Control: max-age=0就是缓存生效时间,现在是每次都需要重新加载
以上是关于42.访问日志不记录静态文件访问日志切割静态元素过期时间的主要内容,如果未能解决你的问题,请参考以下文章