• Linux centos7 VMware Apache访问日志不记录静态文件、访问日志切割、静态元素过期时间


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

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

    vim /usr/local/apache2.4/conf/extra/httpd-vhosts.conf //改为如下

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

     

    重新加载

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

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

    mkdir /data/wwwroot/www.111.com/images //创建目录,并在这目录下上传一个图片

    curl -x127.0.0.1:80 -I www.111.com/images/123.jpg

    把配置文件env=!img 去掉就有日志生成了

     tail /usr/local/apache2.4/logs/www.111.com-access_log

    把配置文件env=!img 加上就没有日志生成了

    二、访问日志切割

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

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

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

    <VirtualHost *:80>

    DocumentRoot "/data/wwwroot/www.111.com"

    ServerName www.111.com

    ServerAlias 111.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/111.com-access_%Y%m%d.log 86400" combined env=!img

    </VirtualHost>

    img 可以变化,可以是image-request

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

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

    ls /usr/local/apache2.4/logs  还没有以日期为单位的日志文件

    访问一个网页

    查看就可以生成日志文件了

    ls /usr/local/apache2.4/logs

     

    更改权限使它可以可读可写可执行

    访问一个网页

    再查看日志,就可以看到访问记录了

    [root@davery ~]# cat /usr/local/apache2.4/logs/123.com-access_20180603.log

    [root@davery ~]# tail /usr/local/apache2.4/logs/123.com-access_20180603.log

    访问图片就没有日志生成

    访问网页就有日志生成

    三、静态元素过期时间

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

    增加配置

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

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

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

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

    查看expier模块有没有打开

    没有打开,则需编辑主配置文件

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

    搜索expires

     

    把注释去掉

    expires_module就打开了、

    curl测试,看cache-control: max-age

  • 相关阅读:
    [20170706]SQL Server事务复制订阅端,job不小心被删,修复
    [20170629]带过滤的复制项UI操作导致订阅全部初始化问题
    自动创建数据库镜像,证书交换
    “RESOURCE MONITOR“CPU占用特别高
    索引视图导致死锁
    Percona TokuDB
    从MySQL 5.5迁移到Mariadb 10.1.14
    SQL Server 2014新特性:其他
    SQL Server 2014新特性:分区索引重建
    SQL Server 2012 新特性:其他
  • 原文地址:https://www.cnblogs.com/davery/p/8934443.html
Copyright © 2020-2023  润新知