本文共 1959 字,大约阅读时间需要 6 分钟。
4月16日任务
11.22 访问日志不记录静态文件11.23 访问日志切割11.24 静态元素过期时间扩展 apache日志记录代理IP以及真实客户端IP apache只记录指定URI的日志 apache日志记录客户端请求的域名 apache 日志切割问题访问日志不记录静态文件
网站大多元素为静态文件,如图片、css、js等,这些元素可以不用记录 把虚拟主机配置文件改成如下: <VirtualHost :80>DocumentRoot "/data/wwwroot/www.123.com"ServerName www.123.comServerAlias 123.comSetEnvIf Request_URI "..gif$" imgSetEnvIf Request_URI "..jpg$" imgSetEnvIf Request_URI "..png$" imgSetEnvIf Request_URI "..bmp$" imgSetEnvIf Request_URI "..swf$" imgSetEnvIf Request_URI "..js$" imgSetEnvIf Request_URI "..css$" img CustomLog "logs/123.com-access_log" combined env=!img</VirtualHost>重新加载配置文件 -t, gracefulmkdir /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 访问日志切割日志一直记录总有一天会把整个磁盘占满,所以有必要让它自动切割,并删除老的日志文件 把虚拟主机配置文件改成如下: <VirtualHost :80>DocumentRoot "/data/wwwroot/www.123.com"ServerName www.123.comServerAlias 123.comSetEnvIf Request_URI "..gif$" imgSetEnvIf Request_URI "..jpg$" imgSetEnvIf Request_URI "..png$" imgSetEnvIf Request_URI "..bmp$" imgSetEnvIf Request_URI "..swf$" imgSetEnvIf Request_URI "..js$" imgSetEnvIf 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, gracefulls /usr/local/apache2.4/logs 静态元素过期时间浏览器访问网站的图片时会把静态的文件缓存在本地电脑里,这样下次再访问时就不用去远程下载了增加配置<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_modulecurl测试,看cache-control: max-age转载于:https://blog.51cto.com/13583139/2104180