11月16日任务
11.22 访问日志不记录静态文件
11.23 访问日志切割
11.24 静态元素过期时间
1. 访问日志不记录静态文件
示例一:
- 网站大多元素为静态文件,如图片、css、js等,这些元素可以不用记录
- 把虚拟主机配置文件改成如下:
- <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_log
实验:一
- 编辑添加变量,符合上面变量的要求的,都不记录日志
- 重新加载配置文件 -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_log 查看是否有记录日志
2.访问日志切割
- 日志一直记录总有一天会把整个磁盘占满,所以有必要让它自动切割,并删除老的日志文件
- 把虚拟主机配置文件改成如下:
- <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/logs
实验一:日志切割
- 原图
- 添加下面内容
- 重新加载一下
- 访问一下,让它生产日志
- 可以做个任务计划,crond ,将超过一个月的日志删除或者备份到其他地方,再删除。
3.静态元素过期时间
- 浏览器访问网站的图片时会把静态的文件缓存在本地电脑里,这样下次再访问时就不用去远程下载了
- 增加配置
- <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
- curl测试,看cache-control: max-age
实验一:
- 编辑添加
- 编辑住配置文件,查找expire,删除#号,开启该模块
- 查看是否开启该模块
- 用curl测试一下