文档章节

日志中记录代理IP以及真实客户端、apache只记录指定URI的日志

李超小牛子
 李超小牛子
发布于 08/21 20:42
字数 791
阅读 10
收藏 0

apache 日志中记录代理IP以及真实客户端

  • 默认情况下log日志格式为: LogFormat "%h %l %u %t "%r" %>s %b "%{Referer}i" "%{User-Agent}i"" combined
  • 其中%h 是记录访问者的IP,如果在web的前端有一层代理,那么这个%h其实就是代理机器的IP,这不是我们想要的。
  • 在这种情况下, %{X-FORWARDED-FOR}i 字段会记录客户端真实的IP。所以log日志改为: LogFormat "%h %{X-FORWARDED-FOR}i %l %u %t "%r" %>s %b "%{Referer}i" "%{User-Agent}i"" combined

apache只记录指定URI的日志

例如:把类似请求 www.aaa.com/aaa/... 这样的请求才记录日志。

  • 在httpd.conf 或者 相关的虚拟主机配置文件中添加
SetEnvIf Request_URI "^/aaa/.*" aaa-request
CustomLog "|/usr/local/apache/bin/rotatelogs -l /usr/local/apache/logs/aaa-access_%Y%m%d.log 86400" combined env=aaa-request

apache的日志是可以自动切割的。

  • 方法一: 使用 cronolog 为每一天建立一个新的日志 CustomLog "|bin/cronolog logs/access_%Y%m%d.log" combined
  • 也可以按小时 CustomLog "|bin/cronolog logs/access_%Y%m%d%h.log" combined
  • 方法二:使用 rotatelogs 每一天记录一个日志 CustomLog "|bin/rotatelogs -l logs/access_%Y%m%d.log 86400" combined
  • 每小时 CustomLog "|bin/rotatelogs -l logs/access_%Y%m%d%H.log 3600" combined

再看apache rotatelogs语法

rotatelogs [ -l ] logfile [ rotationtime [ offset ]] | [ filesizeM ]

  • -l 使用本地时间代替GMT时间作为时间基准。注意:在一个改变GMT偏移量(比如夏令时)的环境中使用-l会导致不可预料的结果。所以一定要加上-l 否则出现的日志时间和实际时间是相差8小时的。
  • logfile 它加上基准名就是日志文件名。如果logfile中包含”%”,则它会被视为用于strftime()的格式字符串;否则它会被自动加上以秒为单位的”.nnnnnnnnnn”后缀。这两种格式都表示新的日志开始使用的时间。
  • rotationtime 日志文件滚动的以秒为单位的间隔时间。
  • offset 相对于UTC的时差的分钟数。如果省略,则假定为”0″并使用UTC时间。比如,要指定UTC时差为”-5小时”的地区的当地时间,则此参数应为”-300″。
  • filesizeM 指定以filesizeM文件大小滚动,而不是按照时间或时差滚动。

apache日志记录客户端请求的域名

正常情况下,没有必要记录这一项,毕竟大都根据虚拟主机来设置相应的访问日志,但也有个别的情况,比如 ServerName *.abc.com 这样泛解析的形式,所以有必要记录一下用户请求的域名到底是哪个。 而apache的LogFormat 中正好有一项值满足了这个需求。即 %V 这里是大写的V ,小写的v 记录的是咱们在虚拟主机中设置的ServerName ,这个的确是没有必要记录的。

© 著作权归作者所有

共有 人打赏支持
李超小牛子
粉丝 2
博文 90
码字总数 104721
作品 0
通州
apacheri访问日志记录

访问日志不记录静态文件 按F12默认定位在network 重新刷新网页 每一行都是元素 修改虚拟主机配置文件 SetEnvif 环境 ENV=!img 验证 上传图片之后 访问有图片显示 日志里面却没有记录PNG 配置...

yongqiao
03/05
0
0
扩展44:apache记录代理IP及真实IP 客户端请求域名 只记录指定URL日记 日记切割

1、apache日记中记录代理IP及真实客户端IP地址: 1、apache的访问日记格式定义: /usr/local/apapche2.4/conf/httpd.conf 如上图例是apache的三种日记格式,我们使用的第一种:需要把combine...

芬野de博客
09/02
0
0
Apache优化——日志管理 11.22 访问日志不记录静态文件 11.23 访问日志切割 11.24 静态元素过期时间

11.22 访问日志不记录静态文件 网站大多元素为静态文件,如图片、css、js等,这些元素可以不用记录 编辑虚拟主机配置文件“httpd-vhosts.conf”: 说明: 将所有访问图片的请求定义为变量img...

Champin
2017/12/21
0
0
志筛选记录、日志切割、过期时间设置

11.22 访问日志不记录静态文件 网站大多元素为静态文件,如图片、css、js等,这些元素可以不用记录 把虚拟主机配置文件改成如下:在custom上边进行配置 重新加载配置文件 -t, graceful 11.23...

派派菠菜
05/31
0
0
LAMP架构(Apache访问日志不记录静态文件、访问日志切割、静态元素过期时间)

Apache访问日志不记录静态文件 即在虚拟主机处配置访问特定资源不产生日志过滤,具体实例即网站不需要记录访问静态资源的日志,记录关键重要信息即可 编辑虚拟主机配置文件,添加如下配置。 ...

Hi_Yolks
08/05
0
0

没有更多内容

加载失败,请刷新页面

加载更多

中文地址

火力全開
23分钟前
0
0
71:循环之for、while、break、continue、exit

1、for循环语法: for 变量名 in 条件;do......;done 1:案例1:求1加到100的和: [root@localhost_02 for]# vim for1.sh #!/bin/bashsum=0for i in `seq 1 100`do sum=$[$sum...

芬野de博客
26分钟前
0
0
Log4j2 Analysis

Log4j2 improvement compare with Log4j : AsyncLogger : Implemented by LMAX Disruptor technology (a lock-free inter-thread communication library, instead of queues, resulting in h......

Yixin_Nemo
36分钟前
0
0
玩转js之——new方法的模拟实现

已知new的作用 1.实例可以访问到构造函数的属性和方法 2.实例可以访问到构造函数原型中的属性和方法 //demo:function Person(name, age) { this.name = name this.age = age}Person...

lsner
36分钟前
0
0
SQL--索引使用(1)

以下是优化真实环境sql。 一、原始sql查询时长如下 二、EXPLAIN分析如下,说明 关于explain的讲解详见我另一篇文章 三、结合sql语句分析出 3.1 可以单独给business_id加索引,会优化一部分效...

求是科技
38分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部