【LAMP环境搭建】访问日志不记录静态、访问日志切割和静态元素过期时间

本文介绍如何通过Apache配置实现不记录静态文件访问日志、自动切割日志文件以及设置静态资源缓存时间,有效减轻服务器负担。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

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

把虚拟主机配置文件改成如下:
vim /usr/local/apache2.4/conf/extra/httpd-vhosts.conf

   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/111.com-access_log" combined env=!img




重新加载配置文件:
/usr/local/apache2.4/bin/apachectl -t
/usr/local/apache2.4/bin/apachectl graceful



进入对应的目录并上传一张图片:

cd /data/wwwroot/111.com/


再查看一下日志,就可以看到并没有png的日志:

curl -x127.0.0.1:80 111.com/baidu.png  -I
cat /usr/local/apache2.4/logs/111.com-access_log




二、访问日志切割

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


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

vim /usr/local/apache2.4/conf/extra/httpd-vhosts.conf


CustomLog "|/usr/local/apache2.4/bin/rotatelogs -l logs/111.com-access_%Y%m%d.log 86400"  combined env=!img



 

重新加载配置文件:
/usr/local/apache2.4/bin/apachectl -t
/usr/local/apache2.4/bin/apachectl graceful

访问一下:

curl -x127.0.0.1:80 111.com/123.php


再查看一下路径生成了对应的带日期的日志:
 ls /usr/local/apache2.4/logs/



测试:



三、静态元素过期时间

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

例子:我们先把/data/wwwroot/111.com下的baidu.png改名成qq.png,再按一下浏览器F12,可以看到状态是200,然后再刷新一下页面,状态变成304,这个304就是缓存下来的图片




vim /usr/local/apache2.4/conf/extra/httpd-vhosts.conf:


<IfModule mod_expires.c>       //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模块有没有打开:

/usr/local/apache2.4/bin/apachectl -M |grep expire


如果没有再去主配置文件修改,将#去掉:

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



再重新检测和加载:

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

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


然后重新查看模块:

 


测试:curl -x127.0.0.1:80 111.com/qq.png -I 



(也可以直接浏览器访问111.com/qq.png,按F12来查看)


 扩展 :

apache日志记录代理IP以及真实客户端IP 
http://ask.apelearn.com/question/960 

apache只记录指定URI的日志 
http://ask.apelearn.com/question/981 

apache日志记录客户端请求的域名 
http://ask.apelearn.com/question/1037 

apache 日志切割问题 
http://ask.apelearn.com/question/566 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值