专栏首页linux运维学习linux学习第四十篇:访问日志不记录静态文件,访问日志切割,静态元素过期时间

linux学习第四十篇:访问日志不记录静态文件,访问日志切割,静态元素过期时间

访问日志不记录静态文件

网站大多元素为静态文件,如图片、css、js等,这些元素可以不用记录 。如果不去做限制,每个请求都包含很多图片,每个请求都会记录日志,日志会变得越来越大,不仅会消耗磁盘空间还会消耗磁盘IO。

  • 把虚拟主机配置文件添加如下:
    SetEnvIf Request_URI ".*\.gif$" img   //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  //env=!img就是记录除了img之外的东西
  • 重新加载配置文件 -t, graceful,并在/data/wwwroot/111.com目录下上传jpg图片
  • 访问111.com的jpg图片: curl -x127.0.0.1:80 -I 111.com/123.jpg
  • 查看访问日志,会发现访问的jpg图片不会记录在日志中: tail /usr/local/apache2.4/logs/123.com-access_log
  • 当我们把配置文件里的env=!img去掉,再去访问jpg图片,日志就会再次记录。

访问日志切割

  • 日志一直记录总有一天会把整个磁盘占满,所以有必要让它自动切割,并删除老的日志文件
  • 把虚拟主机配置文件修改CustomLog如下:
 <VirtualHost *:80>
    DocumentRoot "/data/wwwroot/111.com"
    ServerName 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 
//rotatelogs是Apache自带的日志切割工具,
//-l是以系统当前的时间为准。
//Y是年,m是月,d是天。
//86400是86400秒也就是24小时,表示每天切割一次
</VirtualHost>
  • 重新加载配置文件 -t, graceful
  • 查看logs目录,会出现新的日志,每天的凌晨都会生成一个新的日志(需要做一个任务计划,把超过一个月或者两个月的日志删除): ls /usr/local/apache2.4/logs

静态元素过期时间

浏览器访问网站的图片时会把静态的文件缓存在本地电脑里,这样下次再访问时就不用去远程下载了。304状态码表示不会再去服务器下载静态元素,如果有更改就会重新下载。怎么去定义静态元素缓存的失效日期。

  • 增加配置
<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,到主配置文件vim /usr/local/apache2.4/conf/httpd.conf中找到expires模块并把#号注释去掉。
  • 重新加载配置文件 -t, graceful
  • curl测试,看cache-control: max-age

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

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • MySQL延迟主从复制

    世界上没有卖后悔药的,一旦做错了,后悔莫及。我们作为运维,尤其是不小心误删除数据库里的数据时,那更是损失巨大。对于MySQL来说,这里有一种方法,可以避免这种悲...

    用户1215343
  • linux学习第六十九篇:分发系统介绍,expect脚本远程登录,expect脚本远程执行命令,expect脚本传递参数

    分发系统介绍 expect可以让我们实现自动登录远程机器,并且可以实现自动远程执行命令。当然若是使用不带密码的密钥验证同样可以实现自动登录和自动远程执行命令。...

    用户1215343
  • linux学习第六十二篇:添加自定义监控项目,配置邮件告警,测试告警,不发邮件的问题处理

    添加自定义监控项目 需求:监控某台web的80端口连接数,并出图 两步:1)zabbix监控中心创建监控项目;2)针对该监控项目以图形展现 对于第一步,需要到客...

    用户1215343
  • 你确定不来了解一下Redis跳跃表的原理吗

    目前经常使用的平衡数据结构有:B树,红黑树,AVL树,Splay Tree, Treep等。想象一下,给你一张草稿纸,一只笔,一个编辑器,你能立即实现一颗红黑树...

    王知无
  • 在Centos8中编译安装nodejs与yum安装

    Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行环境。官网地址https://nodejs.org/en/ 其优点在于使用了...

    cn華少
  • Kafka重置消费的OffsetKafka源码分析-汇总

    扫帚的影子
  • Kafka+Spark Streaming管理offset的几种方法

    场景描述:Kafka配合Spark Streaming是大数据领域常见的黄金搭档之一,主要是用于数据实时入库或分析。为了应对可能出现的引起Streaming程序...

    暴走大数据
  • search(6)- elastic4s-CRUD

    如果我们把ES作为某种数据库来使用的话,必须熟练掌握ES的CRUD操作。在这之前先更正一下上篇中关于检查索引是否存在的方法:elastic4s的具体调用...

    用户1150956
  • Python MD5加密

    简单介绍一下使用Python内置哈希库对字符串进行MD5加密的方法: 首先是导入MD5加密所需模块:

    周小董
  • Kafka+Spark Streaming管理offset的几种方法

    场景描述:Kafka配合Spark Streaming是大数据领域常见的黄金搭档之一,主要是用于数据实时入库或分析。为了应对可能出现的引起Streaming程序...

    王知无

扫码关注云+社区

领取腾讯云代金券