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>
能够根据本身的需求对每种静态元素类型单独设置。