11.22 访问日志不记录静态文件、11.23 访问日志切割、11.24 静态元素过时时间

11.22 访问日志不记录静态文件javascript

apache的访问日志会记录网站每一个文件被获取的信息,这样日志信息量会很大,咱们排查日志的时候不容易筛选有用的记录。咱们能够把静态文件的日志设置为不记录,提升咱们排查日志信息的效率css

在conf/extra/httpd-vhosts.conf/ 配置文件下进行设定:java

<VirtualHost *:80>
    ServerAdmin lgs@111.com
    DocumentRoot "/data/wwwroot/111.com"
    ServerName www.111.com
    ServerAlias 111.com 123.com
  
    SetEnvIf Request_URI ".*\.gif$" img // 定义元素为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
     ErrorLog "logs/111.com-error_log"
    CustomLog "logs/111.com-access_log" common env=!img //指定非img的文件才记录日志。
</VirtualHost>

从新加载配置文件:apache

[root@localhost ~]# /usr/local/apache2.4/bin/apachectl -t
Syntax OK
[root@localhost ~]# /usr/local/apache2.4/bin/apachectl graceful

再访问网站下的图片文件,查看日志已不在记录图片的访问日志了。浏览器

11.23 访问日志切割缓存

随着网站访问量的增大,咱们网站的访问日志文件也会变得很大,为了保持磁盘空间,方便访问日志的管理(备份、删除历史日志等。),咱们能够进行日志切割,天天的访问日志独立切割出来。服务器

在conf/extra/httpd-vhosts.conf/ 配置文件下进行设定:app

<VirtualHost *:80>
    ServerAdmin lgs@111.com
    DocumentRoot "/data/wwwroot/111.com"
    ServerName www.111.com
    ServerAlias 111.com 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
 
    ErrorLog "logs/111.com-error_log"
CustomLog "|/usr/local/apache2.4/bin/rotatelogs -l logs/111.com-access_%y%m%d.log 86400" common env=!img  //%y%m%d以年月日命名,86400秒即1天切割一次。rotatelogs使用apache的切割日志工具。
</VirtualHost>

11.24 静态元素过时时间工具

浏览器访问网站,获取的图片、css等静态元素会保存在本地电脑缓存文件夹里,方便下次再此访问的时候提升访问速度。咱们也能够在服务器端设置这些静态元素的过时时间,能够减网站的带宽压力。网站

在conf/extra/httpd-vhosts.conf配置文件里设定:是经过expires模块实现的。在编译apache的时候指定了参数mods=most,就会编译这个模块进来。(确保在apache的httpd.conf中打开这个so模块。)

<IfModule mod_expires.c>
ExpiresActive on  // 打开该功能的开关
ExpiresByType image/gif "access plus 1 days"   //gif类型文件的失效时间是1天
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>

能够根据本身的需求对每种静态元素类型单独设置。

相关文章
相关标签/搜索