Linux centos7 VMware Apache访问日志不记录静态文件访问日志切割静态元素过期时间
Posted Stripling悟
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Linux centos7 VMware Apache访问日志不记录静态文件访问日志切割静态元素过期时间相关的知识,希望对你有一定的参考价值。
一、Apache访问日志不记录静态文件
网站大多元素为静态文件,如图片、css、js等,这些元素可以不用记录
vim /usr/local/apache2.4/conf/extra/httpd-vhosts.conf //改为如下
把虚拟主机配置文件改成如下:
重新加载
/usr/local/apache2.4/bin/apachectl -t
/usr/local/apache2.4/bin/apachectl graceful
mkdir /data/wwwroot/www.111.com/images //创建目录,并在这目录下上传一个图片
curl -x127.0.0.1:80 -I www.111.com/images/123.jpg
把配置文件env=!img 去掉就有日志生成了
tail /usr/local/apache2.4/logs/www.111.com-access_log
把配置文件env=!img 加上就没有日志生成了
二、访问日志切割
日志一直记录总有一天会把整个磁盘占满,所以有必要让它自动切割,并删除老的日志文件
把虚拟主机配置文件改成如下:
vim /usr/local/apache2.4/conf/extra/httpd-vhosts.conf
<VirtualHost *:80>
DocumentRoot "/data/wwwroot/www.111.com"
ServerName www.111.com
ServerAlias 111.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/111.com-access_%Y%m%d.log 86400" combined env=!img
</VirtualHost>
img 可以变化,可以是image-request
/usr/local/apache2.4/bin/apachectl -t
/usr/local/apache2.4/bin/apachectl graceful
ls /usr/local/apache2.4/logs 还没有以日期为单位的日志文件
访问一个网页
查看就可以生成日志文件了
ls /usr/local/apache2.4/logs
更改权限使它可以可读可写可执行
访问一个网页
再查看日志,就可以看到访问记录了
[root@davery ~]# cat /usr/local/apache2.4/logs/123.com-access_20180603.log
[root@davery ~]# tail /usr/local/apache2.4/logs/123.com-access_20180603.log
访问图片就没有日志生成
访问网页就有日志生成
三、静态元素过期时间
浏览器访问网站的图片时会把静态的文件缓存在本地电脑里,这样下次再访问时就不用去远程下载了
增加配置
vim /usr/local/apache2.4/conf/extra/httpd-vhosts.conf
<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>
/usr/local/apache2.4/bin/apachectl -t
/usr/local/apache2.4/bin/apachectl graceful
查看expier模块有没有打开
没有打开,则需编辑主配置文件
vim /usr/local/apache2.4/conf/httpd.conf
搜索expires
把注释去掉
expires_module就打开了、
curl测试,看cache-control: max-age
以上是关于Linux centos7 VMware Apache访问日志不记录静态文件访问日志切割静态元素过期时间的主要内容,如果未能解决你的问题,请参考以下文章
VMware 下,windows7与linux7/CentOS7 共享设置