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

访问日志不记录静态文件

网站大多元素为静态文件,如图片、css、js等,这些元素能够不用记录
若是一个网站访问量特别大,那么访问日志就会不少,但有一些访问日志咱们实际上是能够忽略掉的,好比网站的一些图片,还有js、css等静态对象。而这些文件的访问每每是巨量的,每访问一次就记录一次,这些请求会包含不少图片,JS,CSS等,会占用磁盘空间和耗费IO,并且即便记录这些日志也没有什么用,那么如何忽略不记录这些日志呢?javascript

配置日志不记录图片的访问
• 把虚拟主机配置文件改为以下:css

<VirtualHost *:80>
    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
</VirtualHost>

• 从新加载配置文件 -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_logjava


访问日志切割

日志一直记录总有一天会把整个磁盘占满,因此有必要让它自动切割,并删除老的日志文件
apache自带日志切割功能rotatelogs
• 把虚拟主机配置文件改为以下:linux

<VirtualHost *:80>
    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
</VirtualHost>

• 从新加载配置文件 -t, graceful
• ls /usr/local/apache2.4/logsapache

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个月之前的文件删除。vim


静态元素过时时间

•浏览器访问网站的图片时会把静态的文件缓存在本地电脑里,这样下次再访问时就不用去远程下载了
常识:咱们在浏览器去访问一个网站的时候,这个网站有不少图片,浏览器会默认把这些图片缓存到本地电脑上去,这就是一个临时的缓存目录,那到底缓存多长时间呢,是在服务器上定义的。
通常公司的网站都会设置这个功能
ctrl +f5 强制刷新页面,清楚缓存浏览器

• 增长配置缓存

<IfModule mod_expires.c> 
    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"   //其余不设置时间
</IfModule>

• 须要expires_module
查看主配置文件中expires_module是否打开服务器

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

• 加载配置app

[root@linux-129 ~]# /usr/local/apache2.4/bin/apachectl -t
Syntax 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 -I
HTTP/1.1 200 OK
Date: Mon, 09 Apr 2018 05:07:44 GMT
Server: Apache/2.4.29 (Unix) PHP/7.1.6
Last-Modified: Mon, 09 Apr 2018 04:20:10 GMT
ETag: "646c7-56962b8baf9d1"
Accept-Ranges: bytes
Content-Length: 411335
Cache-Control: max-age=86400
Expires: Tue, 10 Apr 2018 05:07:44 GMT
Content-Type: image/jpeg
相关文章
相关标签/搜索