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

一、访问日志不记录指定文件类型(静态文件)

1、网站大多元素为静态文件,如图片、css、js等,这些元素可以不用记录 ,我们浏览器上按f12就会出现一个工具,我们可以在里面看到很多的元素。里面的文件很多很大,我们没有必要让日志记录它。不然它会特别大。
2、把虚拟主机配置文件改成如下:
<VirtualHost :80>
DocumentRoot "/data/wwwroot/11.com"
ServerName 11.com
ServerAlias www.123.com
ErrorLog "logs/riven.work-error_log"
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/11.com-access_log" combined env=!img

</VirtualHost>
访问日志不记录静态文件、访问日志切割及配置静态元素过期时间

3、重新加载配置文件
/usr/local/apache/bin/apachectl -t
/usr/local/apache/bin/apachectl graceful
4、mkdir /data/wwwroot//images //创建目录,并在这目录下上传一个图片,
5、测试:
访问图片: curl -x192.168.1.31/images/1.jpg
查看日志: tail -n5 /usr/local/apache/logs/11.com-access_log

二、访问日志切割

1、日志一直记录总有一天会把整个磁盘占满,所以有必要让它自动切割,并删除老的日志文件 ,节省磁盘空间
2、把虚拟主机配置文件改成如下:
<VirtualHost :80>
DocumentRoot "/data/wwwroot/11.com"
ServerName 11.com
ServerAlias www.11.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/apache/bin/rotatelogs -l logs/11.com-access_%Y%m%d.log 86400" combined env=!img
//系统自带的日起切割工具: rotatelogs ,然后加上变量,
%Y%m%d 表示年月日
86400 一天的时间86400s,表示每天凌晨0都会生成一个新的日志,
</VirtualHost>
3、重新加载配置文件
/usr/local/apache/bin/apachectl -t
/usr/local/apache/bin/apachectl graceful
4、查看切割日志
1、ls /usr/local/apache/logs

三、配置静态元素过期时间

1、浏览器访问网站的图片时会把静态的文件缓存在本地电脑里,这样下次再访问时就不用去远程下载了,
2、增加配制
<IfModule mod_expires.c>
ExpiresActive on //打开该功能的开关
ExpiresByType image/gif "access plus 1 days" //绶存gif一天
ExpiresByType image/jpeg "access plus 24 hours" //绶存jpeg 24小时
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>
3、 需要expires_module
/usr/local/apache2/bin/apachectl -M|grep -i expires //若无该模块,需要编辑配置文件httpd.conf,删除expires_module (shared) 前面的#

curl测试,看cache-control: max-age参数,如果有表示配置成功了。

转载于:https://blog.51cto.com/10690709/2122287

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值