文档章节

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

李超小牛子
 李超小牛子
发布于 08/21 20:42
字数 791
阅读 11
收藏 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

没有更多内容

加载失败,请刷新页面

加载更多

iframe里弹出的层显示在整个网页上

通过在iframe页面添加js脚本,动态给父窗体创建一个div,然后设置让其显示在最顶层这样就可以了 在文件夹中创建两个文件,一个iframe页面,一个父页面index。

少年已不再年少
31分钟前
1
0
聊聊storm trident spout的_maxTransactionActive

序 本文主要研究一下storm trident spout的_maxTransactionActive MasterBatchCoordinator storm-core-1.2.2-sources.jar!/org/apache/storm/trident/topology/MasterBatchCoordinator.java ......

go4it
39分钟前
1
0
js时间函数getTime() 在苹果手机上返回NaN的问题

一、出现问题 var newStartDate = new Date('2017-08-30');var newStartTime = newStartDate.getTime(); 获取到的时间戳,在Android手机正常,在IPhone中返回NaN。 问题说明: 在苹果手机...

tianma3798
42分钟前
1
0
访问日志不记录静态文件、切割和静态元素过期时间

11月16日任务 11.22 访问日志不记录静态文件 11.23 访问日志切割 11.24 静态元素过期时间 11.22、 访问日志不记录静态文件 网站大多元素为静态文件,如图片、css、js等,这些元素可以不用记录...

zgxlinux
48分钟前
1
0
爬虫教程」Python做一个简单爬虫,小白也能看懂的教程

俗话说“巧妇难为无米之炊”,除了传统的数据源,如历史年鉴,实验数据等,很难有更为简便快捷的方式获得数据,在目前互联网的飞速发展写,大量的数据可以通过网页直接采集,“网络爬虫”应运...

糖宝lsh
今天
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部