Linux centos7 VMware Apache访问日志不记录静态文件、访问日志切割、静态元素过期时间

时间:2022-06-13 06:56:37

一、Apache访问日志不记录静态文件

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

vim /usr/local/apache2.4/conf/extra/httpd-vhosts.conf //改为如下

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

Linux centos7 VMware Apache访问日志不记录静态文件、访问日志切割、静态元素过期时间

重新加载

/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

Linux centos7 VMware Apache访问日志不记录静态文件、访问日志切割、静态元素过期时间

把配置文件env=!img 去掉就有日志生成了

Linux centos7 VMware Apache访问日志不记录静态文件、访问日志切割、静态元素过期时间

tail /usr/local/apache2.4/logs/www.111.com-access_log

Linux centos7 VMware Apache访问日志不记录静态文件、访问日志切割、静态元素过期时间

把配置文件env=!img 加上就没有日志生成了

Linux centos7 VMware Apache访问日志不记录静态文件、访问日志切割、静态元素过期时间

Linux centos7 VMware Apache访问日志不记录静态文件、访问日志切割、静态元素过期时间

Linux centos7 VMware Apache访问日志不记录静态文件、访问日志切割、静态元素过期时间

二、访问日志切割

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

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

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>

Linux centos7 VMware Apache访问日志不记录静态文件、访问日志切割、静态元素过期时间

img 可以变化,可以是image-request

/usr/local/apache2.4/bin/apachectl -t

/usr/local/apache2.4/bin/apachectl graceful

ls /usr/local/apache2.4/logs  还没有以日期为单位的日志文件

Linux centos7 VMware Apache访问日志不记录静态文件、访问日志切割、静态元素过期时间

访问一个网页

Linux centos7 VMware Apache访问日志不记录静态文件、访问日志切割、静态元素过期时间

查看就可以生成日志文件了

ls /usr/local/apache2.4/logs

Linux centos7 VMware Apache访问日志不记录静态文件、访问日志切割、静态元素过期时间

更改权限使它可以可读可写可执行

Linux centos7 VMware Apache访问日志不记录静态文件、访问日志切割、静态元素过期时间

访问一个网页

Linux centos7 VMware Apache访问日志不记录静态文件、访问日志切割、静态元素过期时间

再查看日志,就可以看到访问记录了

[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

Linux centos7 VMware Apache访问日志不记录静态文件、访问日志切割、静态元素过期时间

访问图片就没有日志生成

Linux centos7 VMware Apache访问日志不记录静态文件、访问日志切割、静态元素过期时间

访问网页就有日志生成

Linux centos7 VMware Apache访问日志不记录静态文件、访问日志切割、静态元素过期时间

三、静态元素过期时间

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

增加配置

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>

Linux centos7 VMware Apache访问日志不记录静态文件、访问日志切割、静态元素过期时间

/usr/local/apache2.4/bin/apachectl -t

/usr/local/apache2.4/bin/apachectl graceful

Linux centos7 VMware Apache访问日志不记录静态文件、访问日志切割、静态元素过期时间

查看expier模块有没有打开

Linux centos7 VMware Apache访问日志不记录静态文件、访问日志切割、静态元素过期时间

没有打开,则需编辑主配置文件

vim /usr/local/apache2.4/conf/httpd.conf

搜索expires

Linux centos7 VMware Apache访问日志不记录静态文件、访问日志切割、静态元素过期时间

把注释去掉

Linux centos7 VMware Apache访问日志不记录静态文件、访问日志切割、静态元素过期时间

expires_module就打开了、

Linux centos7 VMware Apache访问日志不记录静态文件、访问日志切割、静态元素过期时间

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

Linux centos7 VMware Apache访问日志不记录静态文件、访问日志切割、静态元素过期时间