使用CDN之后APACHE日志记录中IP地址不正确的解决方法

这里主要介绍了使用CDN之后APACHE日志记录中IP地址不正确的解决方案,需要的朋友可以参考下

最近在搞APACHE日志分析,装好了awstats之后,这两天进行了观察

报表日期 月 1 月 2010

首次参观日期 2010年01月12日 11:04

最近参观日期 2010年01月13日 23:59

参观者 参观人次 网页数 文件数 字节

浏览器流量 * 77 226 (2.93 参观人次/参观者) 508979 (2252.11 网页数/参观) 509492 (2254.38 文件数/参观) 13.67 G字节 (63430.28 K字节/参观)

非浏览器流量 * 117312 122716 736.24 M字节

这边的结果很让人费解,通过google统计网站的独立IP访问量有2W做,这里显示的数字相差甚远。 后面的网页数和文件数又都与实际相吻合。 经过原因发现 apache日志里记录的IP不正确,大部分都是cdn的节点地址。 产生的原因很显然是因为CDN造成的,之前在网站后台程序里读取用户IP也出现了类似问题。 可以使用print_r($_SERVER) (PHP语言),查找到真实的用户IP,本站为 $_SERVER[‘HTTP_CDN-SRC-IP’]. 这个是CDN携带的真实的客户IP(这里不计较用户是否使用代理)。 但在APACHE的日志记录里如何使用这个值呢? 本人在GOOGLE和百度里了许久都没有找到相应的资料或者说解决方案,只好自己思考寻求了。

仔细看了下APACHE里日志记录的相关配置,针对LogFormat:

LogFormat “%h %l %u %t /”%r/" %>s %b /"%{Referer}i/" /"%{User-Agent}i/"" combined

我思索里面的%{Referer}和%{User-Agent} 是如何取得的, 这两个是在程序里也是经常会用到的东西,客户端发送请求的时候 这两个信息都是作为头详细发送到服务器的。后来查看了下访问时的所有头信息,如下:

 代码如下:

Array

(

[Cdn-Src-Ip] => 222.44.46.58

[Accept] => image/gif, image/jpeg, image/pjpeg, image/pjpeg, application/x-shockwave-flash, application/vnd.ms-excel, application/vnd.ms-powerpoint, application/msword,/

[Accept-Language] => zh-cn

[User-Agent] => Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 5.1; Trident/4.0; CIBA; .NET CLR 2.0.50727)

[Host] => www.875.cn

[Cookie] => __utma=217127135.1188793388.1263188369.1263364666.1263368206.5;婴儿起名http://www.bbqmw.net/qm_yeqm

__utmz=217127135.1263368206.5.2.utmcsr=211.167.92.250|utmccn=(referral)|utmcmd=referral|utmcct=/cgi-bin/awstats/awstats.pl; viewedShopsID=621; viewedShopsPP=%u6B27%u5C1A%u574A

[Accept-Encoding] => gzip

[Via] => 1.1 hnay40:80 (Cdn Cache Server V2.0)

[Connection] => keep-alive

)

当然rerfer的时候也会有rerfer信息出现在头部信息里,上面也有Cookie、Host、User-Agent等信息,这些信息都是可以在apache配置文件里可以使用的变量,当然这里Cdn-Src-Ip正是我想要的客户的真实IP。 于是推测${Cdn-Src-Ip}在日志记录格式里应该也是可以使用的。 后面的i应该是指忽略大小写的意思。于是得出一个解决方案:

添加一个新的logformat信息

 代码如下:

LogFormat “%{Cdn-Src-Ip}i %l %u %t /”%r/" %>s %b /"%{Referer}i/" /"%{User-Agent}i/"" combinedcdn

原创文章,作者:HQPRZ,如若转载,请注明出处:http://www.wangzhanshi.com/n/12513.html

(0)
HQPRZ的头像HQPRZ
上一篇 2025年1月1日 17:07:12
下一篇 2025年1月1日 17:07:14

相关推荐

  • 高防CDN的防护效果对比高防服务器好在哪里

    与其他CDN服务商相比,网站那些事CDN的主要优势包括稳定快速、性价比高、简单易用、高效智能。比较多的用户会问到稳定快速这个优点,一般来说,网站那些事的CDN特点是分担源站压力,避…

    2025年1月1日
  • 遇到DDOS攻击应该选高防云服务器还是高防cdn

    网站那些事内容分发网络(Content Delivery Network,简称CDN)是建立并覆盖在承载网之上,由分布在不同区域的边缘节点云服务器群组成的分布式网络。网站那些事CD…

    CDN加速 2025年1月2日
  • CDN技术有哪些优点

    概念 CDN这个概念相信大家都比较耳熟,到底什么是CDN呢? CDN,全称为Content Delivery Network,即内容分发网络。 其基本思路是尽可能避开互联网上有可能…

    2025年1月1日
  • 国内外CDN的区别有哪些

    由于国内外网络环境的差异,CDN(内容分发网络)的意义也有了不同。在国内,CDN最主要解决的问题是运营商之间的互联互通问题,当然也确实解决了突发流量、大范围覆盖、网民访问缓慢的问题…

    CDN加速 2025年1月1日
  • 怎么更好的给CDN降本

    第一种是使用基于P2P技术的CDN。拿阿里云的PCDN举例,它通过挖掘利用电信边缘网络海量碎片化闲置资源而构建的低成本高品质内容分发网络服务。客户通过集成PCDN  SD…

    2025年1月1日
  • cdn加速可以应用在哪些方面

    与其他CDN服务商相比,网站那些事CDN的主要优势包括稳定快速、性价比高、简单易用、高效智能。比较多的用户会问到稳定快速这个优点,一般来说,网站那些事的CDN特点是分担源站压力,避…

    2025年1月2日
  • cdn支持虚拟主机么

    cdn支持虚拟主机吗?虚拟主机是支持cdn加速的。cdn加速技术,可以避免网站打开速度慢,或是高峰时间段,由于网站访问量过大,服务器无法负载,导致访问网站速度下降等情况。 cdn通…

    CDN加速 2025年1月1日
  • cdn好不好?有什么好处?

    用户在购买网站那些事的CDN服务之后,在使用过程中会比较关心是否有实际效果,首先大家要先确保是否已经开通成功,然后按照基本步骤添加加速域名、配置CNAME,这些都成功搞定之后,接下…

    2025年1月1日
  • CDN回源原理和CDN多级缓存是什么

      CDN回源   回源原理 回源是指浏览器在发送请求报文时,响应该请求报文的是源站点的服务器,而不是各节点上的缓存服务器(比如nginx开启缓存),那么这个过…

    2025年1月1日
  • CentOS下使用Squid架设CDN服务器的方法

    这篇文章主要介绍了CentOS下使用Squid架设CDN服务器的方法,需要的朋友可以参考下 很多站长在建设大型网站的过程当中,常会遇到网站在特定地区打开速度慢的问题。这时候一般会在…

    CDN加速 2025年1月1日

发表回复

登录后才能评论