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

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

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

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

<VirtualHost *:80> ServerAdmin [email protected] 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>

重新加载配置文件:

[root@lgs-02 ~]# /usr/local/apache2.4/bin/apachectl -t Syntax OK [root@lgs-02 ~]# /usr/local/apache2.4/bin/apachectl graceful 再访问网站下的图片文件,查看日志已不在记录图片的访问日志了。

11.23 访问日志切割

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

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

<VirtualHost *:80> ServerAdmin [email protected] 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> 可以根据自己的需求对每种静态元素类型单独设置。

猜你喜欢

转载自my.oschina.net/u/3803405/blog/1822664