1,访问日志不记录静态文件。

    网站大多元素为静态文件,如图片、css、js等,这些元素可以不用记录,这样会消耗磁盘空间。

    修改虚拟主机配置文件如下:

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

    测试访问jpg。

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

   重新加载配置文件-t graceful。再测试访问符合条件的请求,发现没有记录。

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

    上传一张图片到/data/wwwroot/www.123.com/,然后curl。

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

 用浏览器打开。 

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

再tail  /usr/local/apache2.4/logs/www.123.com-access_log 发现没有记录到日志里面。

去掉combined 后面的env=!img后重新加载配置文件再tail。

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

2,访问日志切割。

   日志一直记录的话总有一天会把磁盘占满,所以有必要让它自动切割并删除旧的日志文件。

   更改虚拟主机的配置文件CustomLog那行为:

CustomLog "|/usr/local/apache2.4/bin/rotatelogs -l logs/www.123.com-access_%Y%m%d.log 86400" -combined env=!img

 rotatelogs是apache/http自带的日志切割工具,-l表示以当前系统的时区来切割工具,如果不带-l则以默认的UTC(美国时区)来切割。中国时区是CST。%Y%m%d以年月日自定义日志名称,86400秒表示每天切割一次。

    重新加载配置后查看未切割之前的日志目录文件,发现没有生产新的日志。

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

  随便访问一个文件后再看日志目录文件,发现生产了新的以年月日命令的日志文件。

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

3,静态元素过期时间。

    浏览器访问网站的图片时会把镜头的文件缓存都在本地电脑里,这样下次访问时就不用去远程下载了。

    增加配置。

        <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 hours"
        ExpiresByType application/x-javacript "now plus 2 hours"
        ExpiresByType application/javacript  "now plus 2 hours"
        ExpiresByType application/x-shockwave-flash  "now plus 2 hours"
        ExpiresDefault "now plus 0 min"
        </IfModule>

    expaire没有打开,编辑httpd配置文件。

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

去掉expires这行前面的#号。

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

重新加载配置后查看。

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

查看Cache-Control参数,当前时间和过期时间。

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


    

相关文章: