博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
11.22 访问日志不记录静态文件 11.23 访问日志切割 11.24 静态元素过期时间
阅读量:7105 次
发布时间:2019-06-28

本文共 3100 字,大约阅读时间需要 10 分钟。

hot3.png

访问日志不记录静态文件

网站大多元素为静态文件,如图片、css、js等,这些元素可以不用记录

如果一个网站访问量特别大,那么访问日志就会很多,但有一些访问日志我们其实是可以忽略掉的,比如网站的一些图片,还有js、css等静态对象。而这些文件的访问往往是巨量的,每访问一次就记录一次,这些请求会包含很多图片,JS,CSS等,会占用磁盘空间和耗费IO,而且即使记录这些日志也没有什么用,那么如何忽略不记录这些日志呢?

配置日志不记录图片的访问

• 把虚拟主机配置文件改成如下:

DocumentRoot "/data/wwwroot/www.123.com" ServerName www.123.com ServerAlias 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 CustomLog "logs/123.com-access_log" combined env=!img

• 重新加载配置文件 -t, graceful

• mkdir /data/wwwroot/www.123.com/images //创建目录,并在这目录下上传一个图片
• curl -x127.0.0.1:80 -I 123.com/images/123.jpg
• tail /usr/local/apache2.4/logs/123.com-access_log


访问日志切割

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

apache自带日志切割功能rotatelogs
• 把虚拟主机配置文件改成如下:

DocumentRoot "/data/wwwroot/www.123.com" ServerName www.123.com ServerAlias 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 CustomLog "|/usr/local/apache2.4/bin/rotatelogs -l logs/123.com-access_%Y%m%d.log 86400" combined env=!img

• 重新加载配置文件 -t, graceful

• ls /usr/local/apache2.4/logs

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

解释:
-l 以当前系统时间为准,如果不加-l utc的格式去切割,中国的是ctu格式。
%Y%m%d :年月日
86400秒,一天的时间
这样设置后,每天就会生成一个日志,我们可以做一个计划任务,将1个月以前的文件删除。


静态元素过期时间

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

常识:我们在浏览器去访问一个网站的时候,这个网站有很多图片,浏览器会默认把这些图片缓存到本地电脑上去,这就是一个临时的缓存目录,那到底缓存多长时间呢,是在服务器上定义的。
一般公司的网站都会设置这个功能
ctrl +f5 强制刷新页面,清楚缓存

• 增加配置

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 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" //其他不设置时间

• 需要expires_module

查看主配置文件中expires_module是否打开

[root@linux-129 ~]# vim /usr/local/apache2.4/conf/httpd.confLoadModule expires_module modules/mod_expires.so

• 加载配置

[root@linux-129 ~]# /usr/local/apache2.4/bin/apachectl -tSyntax OK[root@linux-129 ~]# /usr/local/apache2.4/bin/apachectl graceful

• curl测试,看cache-control: max-age

[root@linux-129 ~]# curl -x192.168.88.129:80 111.com/1.jpg -IHTTP/1.1 200 OKDate: Mon, 09 Apr 2018 05:07:44 GMTServer: Apache/2.4.29 (Unix) PHP/7.1.6Last-Modified: Mon, 09 Apr 2018 04:20:10 GMTETag: "646c7-56962b8baf9d1"Accept-Ranges: bytesContent-Length: 411335Cache-Control: max-age=86400Expires: Tue, 10 Apr 2018 05:07:44 GMTContent-Type: image/jpeg

转载于:https://my.oschina.net/u/3866516/blog/1922986

你可能感兴趣的文章
系统中纹波大
查看>>
GPS经纬度转换为百度坐标
查看>>
3班6组第一次迭代博客
查看>>
J2EE (三) Filter详解
查看>>
Oracle 常用函数(Decode,sign,lpad)
查看>>
【算法设计与数据结构】为何程序员喜欢将INF设置为0x3f3f3f3f?
查看>>
单例模式(think in java中的设计模式)
查看>>
什么是驱动?
查看>>
AOP
查看>>
Github的建立及心得体会
查看>>
1. Docker基础命令
查看>>
46. 47. Permutations and Permutations II 都适用(Java,字典序 + 非字典序排列)
查看>>
listen函数
查看>>
c语言编程之二叉树
查看>>
Git-实战篇-创建本地仓库和关联远程仓库-命令行
查看>>
Ubuntu启动时直接进入命令行模式
查看>>
JavaScript中基本数据类型和引用数据类型的区别
查看>>
Juery实现选项卡
查看>>
PHP汉字转换拼音
查看>>
(转)阿里云出现身份验证错误,要求的函数不受支持的解决办法
查看>>