码迷,mamicode.com
首页 > 其他好文 > 详细

42.访问日志不记录静态文件、访问日志切割、静态元素过期时间

时间:2018-04-17 11:46:58      阅读:112      评论:0      收藏:0      [点我收藏+]

标签:访问日志不记录静态文件   访问日志切割   静态元素过期时间   

一、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:需要再次加载的时间

42.访问日志不记录静态文件、访问日志切割、静态元素过期时间

标签:访问日志不记录静态文件   访问日志切割   静态元素过期时间   

原文地址:http://blog.51cto.com/13569831/2104222

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