码迷,mamicode.com
首页 > 系统相关 > 详细

Linux学习总结(三十五)lamp之访问日志配置

时间:2018-04-16 22:47:51      阅读:239      评论:0      收藏:0      [点我收藏+]

标签:lamp   访问日志   静态元素过期时间   日志切割   日志瘦身   

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

网站大多元素为静态文件,如图片、css、js等,记录这些访问信息对我们运维工作没有多大意义,如果一个站点访问量很大,那么一天就可以达到几GB。影响我们磁盘的工作效率,那么我们就可以配置虚拟主机限制记录这些信息。
把虚拟主机配置文件改成如下:

 <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>

重新加载配置文件 -t, graceful
mkdir /data/wwwroot/www.123.com/images //创建目录,并在这目录下上传一个图片
curl -x127.0.0.1:80 -I 123.com/images/123.jpg
curl -x127.0.0.1:80 -I 123.com/345..php
我们分别访问一个图片和一个php网页,然后 tail /usr/local/apache2.4/logs/123.com-access_log 查看日志,会发现只记录了访问345.php的信息,而没有记录访问图片的信息。这里直接起作用的语句为env=!img 其中!为取反的意思,指除过我们定义的request ,其他的都记录。

二 访问日志切割

日志一直记录总有一天会把整个磁盘占满,而且单个日志文件也不利于我们定位故障,所以有必要让它自动切割,并删除老的日志文件
把虚拟主机配置文件改成如下:

 <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" combined env=!img
</VirtualHost>

重新加载配置文件 -t, graceful
ls /usr/local/apache2.4/logs
技术分享图片
这里我们发现多了一个带日期的日志文件,该文件就是我们上面配置后对访问日志切割的结果,其中rotatelos为httpd自带的日志切割工具,它会把访问日志按照我们定义的格式进行切割,其中86400单位是秒,相当于一天。

三 配置静态元素访问过期时间

浏览器访问网站的图片时会把静态的文件缓存在本地电脑里,这样下次再访问时就不用去远程下载了。但是到底能缓存多久呢,如果服务器上的图片更改了,那么应该访问新的图片才对。这就涉及到静态文件缓存时长的问题,也叫做缓存过期时间。这个时间我们可以在虚拟主机配置文件中配置。
我们在刚才的访问日志配置语句下面增加如下配置模块

<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,需要在httpd住配置文件中打开该功能。也就是在/usr/lcoal/apache2.4/conf/httpd.conf 中搜索 expires_module,删除前面的#号
curl测试,看cache-control: max-age
技术分享图片

Linux学习总结(三十五)lamp之访问日志配置

标签:lamp   访问日志   静态元素过期时间   日志切割   日志瘦身   

原文地址:http://blog.51cto.com/12606610/2104173

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!