Tomcat訪問日誌淺析
分享一下我老師大神的人工智慧教程!零基礎,通俗易懂!http://blog.csdn.net/jiangjunshow
也歡迎大家轉載本篇文章。分享知識,造福人民,實現我們中華民族偉大復興!
<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
prefix="localhost_access_log." suffix=".txt" pattern="%s %D %t %a %U" fileDateFormat="yyyy-MM-dd.HH" resolveHosts="false"/>
Tomcat的訪問日誌是靠org.apache.catalina.valves.AccessLogValve來控制的,你可以修改$tomcat/conf/server.xml來啟用它 ($tomcat是Tomcat安裝的目錄)。AccessLogValve預設應該是註釋掉的,簡單的將其註釋去掉,然後重啟Tomcat就可以了。
以下是Tomcat預設的配置:
<valve classname=“org.apache.catalina.valves.accesslogvalve”< p=""></valve classname=“org.apache.catalina.valves.accesslogvalve”<>
directory=“logs” prefix=“localhost_access_log.” suffix=“.txt”
pattern=“common” resolveHosts=“false”/>
你可以設定日誌儲存的目錄(directory),日誌的檔名的字首(prefix),字尾(suffix)和日誌的具體格式。儲存目錄,檔名的字首、字尾都很簡單,一般預設設定也就可以了。resolveHost出於效能的考慮,一般也設為false. 但訪問日誌的格式(pattern)卻有很多的選項供你選擇。以下列出了一些基本的日誌格式項:
%a – 遠端主機的IP (Remote IP address)
%A – 本機IP (Local IP address)
%b – 傳送位元組數,不包含HTTP頭,0位元組則顯示 ‘-’ (Bytes sent, excluding HTTP headers, or ‘-’ if no bytes
were sent)
%B – 傳送位元組數,不包含HTTP頭 (Bytes sent, excluding HTTP headers)
%h – 遠端主機名 (Remote host name)
%H – 請求的具體協議,HTTP/1.0 或 HTTP/1.1 (Request protocol)
%l – 遠端使用者名稱,始終為 ‘-’ (Remote logical username from identd (always returns ‘-’))
%m – 請求方式,GET, POST, PUT (Request method)
%p – 本機埠 (Local port)
%q – 查詢串 (Query string (prepended with a ‘?’ if it exists, otherwise
an empty string)
%r – HTTP請求中的第一行 (First line of the request)
%s – HTTP狀態碼 (HTTP status code of the response)
%S – 使用者會話ID (User session ID)
%t – 訪問日期和時間 (Date and time, in Common Log Format format)
%u – 已經驗證的遠端使用者 (Remote user that was authenticated
%U – 請求的URL路徑 (Requested URL path)
%v – 本地伺服器名 (Local server name)
%D – 處理請求所耗費的毫秒數 (Time taken to process the request, in millis)
%T – 處理請求所耗費的秒數 (Time taken to process the request, in seconds)
你可以用以上的任意組合來定製你的訪問日誌格式,也可以用下面兩個別名common和combined來指定常用的日誌格式:
common – %h %l %u %t "%r" %s %b
combined -
%h %l %u %t "%r" %s %b "%{Referer}i" "%{User-Agent}i"
另外你還可以將cookie, 客戶端請求中帶的HTTP頭(incoming header), 會話(session)或是ServletRequest中的資料都寫到Tomcat的訪問日誌中,你可以用下面的語法來引用。
%{xxx}i – 記錄客戶端請求中帶的HTTP頭xxx(incoming headers)
%{xxx}c – 記錄特定的cookie xxx
%{xxx}r – 記錄ServletRequest中的xxx屬性(attribute)
%{xxx}s – 記錄HttpSession中的xxx屬性(attribute)
比如下面是實際的一個訪問日誌格式的配置:
<valve classname=“org.apache.catalina.valves.accesslogvalve”< p=""></valve classname=“org.apache.catalina.valves.accesslogvalve”<>
directory=“logs” prefix=“phone_access_log.” suffix=“.txt”
pattern=“%h %l %T %t %r %s %b %{Referer}i %{User-Agent}i MSISDN=%{x-up-calling-line-id}i”resolveHosts=“false”/>
其中日誌格式(pattern)指定為”%h %l %T %t %r %s %b %{Referer}i %{User-Agent}i MSISDN=%{x-up-calling-line-id}i“,則實際的訪問日誌中將會包括:
%h – 遠端主機名
%l - 遠端使用者名稱,始終為 ‘-’
%T - 處理請求所耗費的秒數
%t – 訪問日期和時間
%r – HTTP請求中的第一行
%s – HTTP狀態碼
%b – 傳送位元組數,不包含HTTP頭(0位元組則顯示 ‘-’)
%{Referer}i – Referer URL
%{User-Agent}i – User agent
MSISDN=%{x-up-calling-line-id}i – 手機號
實際的訪問日誌如下:
xxx.xxx.xx.xxx – 0.270 [14/Jul/2008:13:10:53 +0800] POST /phone/xxx/gprs HTTP/1.1 200 91812 – SonyEricssonW890i/R1EA Profile/MIDP-2.1 Configuration/CLDC-1.1 MSISDN=11111111111
… …
xxx.xxx.xx.xxx – 0.083 [14/Jul/2008:21:20:55 +0800] POST /phone/xxx/gprs HTTP/1.1 200 404 – SonyEricssonW910i/R1FA Profile/MIDP-2.1 Configuration/CLDC-1.1 MSISDN=11111111111
來源:
給我老師的人工智慧教程打call!http://blog.csdn.net/jiangjunshow
相關文章
- WEB訪問日誌自動化分析淺談Web
- 配置Tomcat的訪問日誌格式化輸出Tomcat
- Apche日誌系列(1):訪問日誌(轉)
- FeignClient配置日誌訪問client
- 使用Fluentd + Elasticsearch收集訪問日誌Elasticsearch
- nginx自動切割訪問日誌Nginx
- Nginx 訪問日誌格式設定Nginx
- Nginx 訪問日誌實時解析 ngxtopNginx
- AWK應用之統計訪問日誌
- 使用外部表訪問監聽日誌
- 使用外部表訪問警告日誌檔案
- awk統計訪問nginx日誌次數Nginx
- go fiber: 增加訪問日誌accesslogGo
- 淺析Windows的訪問許可權檢查機制Windows訪問許可權
- Tomcat訪問分析Tomcat
- Nginx訪問日誌、Nginx日誌切割、靜態檔案不記錄日誌和過期時間Nginx
- tomcat日誌切割-logrotateTomcatlogrotate
- mysql audit-訪問日誌記錄應用MySql
- 使用apache日誌進行訪問ip的排序Apache排序
- MySQL的共享鎖阻塞會話案例淺析輸入日誌標題MySql會話
- 淺析JAVA日誌中的幾則效能實踐與原理解釋Java
- Linux下使用GoAccess監控Nginx訪問日誌LinuxGoNginx
- 如何訪問Docker容器中的Spring Boot日誌DockerSpring Boot
- OSS訪問日誌分析(1):概念+巨集觀指標指標
- Apache訪問日誌access.log按天歸檔Apache
- 實時檢視tomcat日誌Tomcat
- Tomcat日誌路徑修改方法Tomcat
- 瘋狂刪除tomcat日誌Tomcat
- 日誌服務之分析使用者訪問行為
- log4jdbc資料庫訪問日誌框架使用JDBC資料庫框架
- 怎樣設定不讓JBOSS記錄訪問日誌???
- tomcat高訪問設定問題Tomcat
- 【shell】實現tomcat日誌切割功能Tomcat
- 清理tomcat日誌大的檔案Tomcat
- ITMySQL錯誤日誌與通用查詢日誌圖文詳析jugMySql
- 網站訪問變慢最佳化,淺析10種網站訪問變慢最佳化方法的作用網站
- 【日誌亂碼】解決Tomcat啟動控制檯亂碼問題Tomcat
- 敢問路在何方——Flutter 路由淺析Flutter路由