使用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] =>
[Cookie] => __utma=217127135.1188793388.1263188369.1263364666.1263368206.5;嬰兒起名
__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
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69918221/viewspace-2643373/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Django筆記三十之log日誌記錄詳解Django筆記
- Apache 記錄請求響應時間日誌Apache
- 在日誌中記錄Java異常資訊的正確姿勢Java
- golang常用庫包:log日誌記錄-uber的Go日誌庫zap使用詳解Golang
- 一種簡化操作日誌記錄方案
- Java日誌記錄幾種實現方案Java
- 記錄騰訊雲使用日誌
- .NET Core使用Nlog記錄日誌
- 運維平臺之應用日誌解決方案--ELK運維應用日誌
- 關於 Laravel 使用了 CDN 獲取真實 IP 記錄Laravel
- 禁用 Logback 中特定類的日誌記錄
- Loguru:Python 日誌終極解決方案Python
- 小白折騰伺服器(五):自己寫個記錄日誌的小方法,解決使用 supervisor 後日志堆疊伺服器
- Python:使用logging模組記錄日誌Python
- 日誌記錄器
- ThinkPHP日誌記錄PHP
- 使用 logzero 在 Python 中進行簡單日誌記錄Python
- 伺服器忘記IP後找回IP地址伺服器
- NAS中如何檢視日誌記錄?
- 記錄下解決自定義 Feign 呼叫,響應content-type 格式不正確導致的解析錯誤
- 日誌分析-apache日誌分析Apache
- 基於.NetCore3.1系列 —— 日誌記錄之自定義日誌元件NetCore元件
- springboot使用logback記錄日誌,配置檔案Spring Boot
- Swoft AOP 記錄使用者操作日誌
- Gin 框架 - 使用 logrus 進行日誌記錄框架
- [python] Python日誌記錄庫loguru使用指北Python
- 【Rust】使用日誌記錄利器flexi_loggerRustFlex
- golang常用庫:日誌記錄庫-logrus使用Golang
- Laravel sql 日誌記錄LaravelSQL
- linux apache 使用記錄LinuxApache
- NetCore的全域性日誌記錄NetCore
- python日誌記錄器的配置Python
- Python 類的建構函式中初始化日誌記錄器後,導致日誌被重複列印Python函式
- CDN日誌實時分析
- win10 office元件安裝不正確怎麼辦_win10電腦中office元件安裝不正確的解決教程Win10元件
- Spring Boot 2 中如何使用 Log4j2 記錄日誌Spring Boot
- .Net Core中使用DiagnosticSource進行日誌記錄
- 使用配置檔案方式記錄Python程式日誌Python