11.22 访问日志不记录静态文件
- 网站大多元素为静态文件,如图片、css、js等,这些元素能够不用记录
- 把虚拟主机配置文件改为以下:在custom上边进行配置
<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
11.23 访问日志切割
- 日志一直记录总有一天会把整个磁盘占满,因此有必要让它自动切割,并删除老的日志文件
- 把虚拟主机配置文件改为以下:
<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>
- rotatelogs为一个工具,apache自带的一个日志切割工具,-l表明时区CST,%Y%m%d表示年月日,86400秒即为一天
- 从新加载配置文件 -t, graceful
- ls /usr/local/apache2.4/logs
11.24 静态元素过时时间
- 浏览器访问网站的图片时会把静态的文件缓存在本地电脑里,这样下次再访问时就不用去远程下载了
- 增长配置
<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模块,在配置文件中打开此模块
扩展
- apache日志记录代理IP以及真实客户端IP http://www.lishiming.net/thread-960-1-1.html
- apache只记录指定URI的日志 http://www.lishiming.net/thread-981-1-1.html
- apache日志记录客户端请求的域名 http://www.lishiming.net/thread-1037-1-1.html
- apache 日志切割问题 http://www.lishiming.net/thread-566-1-1.html