Apache访问日志切割和自定义格式

十周四次课(12月21日) 11.22 访问日志不记录静态文件 11.23 访问日志切割 11.24 静态元素过期时间

扩展 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

修改apache日志不记录图片,js和css访问日志

vim /usr/local/apache2.4/conf/extra/httpd-vhosts.conf
在CustomLog 上方添加img标记,在添加env=!img 
<VirtualHost *:80>
    DocumentRoot "/data/wwwroot/123.com"
    ServerName 123.com
    ServerAlias www.123.com 1123.com.cn
     <IfModule mod_rewrite.c>
        RewriteEngine on
        RewriteCond %{HTTP_HOST} !^123.com$
        RewriteRule ^/(.*)$ http://www.123.com/$1 [R=301,L]
     </IfModule>
    ErrorLog "logs/123.com-error_log"
    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>

查看日志记录情况
tail /usr/local/apache2.4/logs/abc.com-access_log

apache日志切割

vim /usr/local/apache2.4/conf/extra/httpd-vhosts.conf
<VirtualHost *:80>
    DocumentRoot "/data/wwwroot/123.com"
    ServerName 123.com
    ServerAlias www.123.com 1123.com.cn
     <IfModule mod_rewrite.c>
        RewriteEngine on
        RewriteCond %{HTTP_HOST} !^123.com$
        RewriteRule ^/(.*)$ http://www.123.com/$1 [R=301,L]
     </IfModule>
    ErrorLog "logs/123.com-error_log"
    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>

-l是已当前系统时间切割,不加-l就是ust美国时间,在中国是cst
86400秒就是一天

浏览器访问网站的图片时会把静态的文件缓存在本地电脑里,这样下次再访问时就不用去远程下载了
配置静态文件过期时间,需要启动expires_module模块
/usr/local/apache2.4/bin/apachectl -M| grep expires_module
vim /usr/local/apache2.4/conf/httpd.conf
LoadModule expires_module modules/mod_expires.so

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

[root@wwlinux701 ~]# vim /usr/local/apache2.4/conf/extra/httpd-vhosts.conf
#
<VirtualHost *:80>
    DocumentRoot "/data/wwwroot/abc.com"
    ServerName abc.com
    ServerAlias www.abc.com www.111.com
    ErrorLog "logs/abc.com-error_log"
    CustomLog "logs/abc.com-access_log" common
</VirtualHost>

<VirtualHost *:80>
    DocumentRoot "/data/wwwroot/123.com"
    ServerName 123.com
    ServerAlias www.123.com 1123.com.cn
# <Directory /data/wwwroot/123.com>
 #  <FilesMatch admin.php> 
 #      AllowOverride AuthConfig
 #       AuthName "123.com user auth"
 #       AuthType Basic 
 #       AuthUserFile /data/.htpasswd  
 #       require valid-user
 #  </FilesMatch> 
#    </Directory>
    <IfModule mod_rewrite.c> 
        RewriteEngine on
        RewriteCond %{HTTP_HOST} !^123.com$
        RewriteRule ^/(.*)$ http://www.123.com/$1 [R=301,L]
     </IfModule>
    <IfModule mod_expires.c>
     ExpiresActive on  #开关设置打开
     ExpiresByType image/gif  "access plus 1 days"   #1天,单位可以按天或小时
     ExpiresByType image/jpeg "access plus 24 hours"  #24小时
     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>
    ErrorLog "logs/123.com-error_log"
    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>

curl -x127.0.0.1:80 123.com/15.png -I
这里写图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值