常規tomcat,apache,nginx,錯誤日志,還有項目log4j日志
tomcat (以tomcat7.082為例)
tomcat日志配置 運行日志和訪問日志結合在一起,先說下日志哪邊配置,在tomcat/conf/server.xml下查詢pattern選項
valve className="org.apache.catalina.valves.AccessLogValve" java定義類,不動
directory="logs" 默認存放在tomcat根下logs文件下,可以修改路徑
prefix="localhost_access_log." 日志文件名的前綴,如果沒有指定,缺省值是”localhost_access_log.;(要注意后面有個小點)
suffix=".txt" 日志文件的后綴名(注意小點)
pattern 需要記錄的日志信息的格式布局,有以下參數:
%a 遠端IP
%A 本地IP
%b 發送的字節數,不包含HTTP頭,如果為0,使用”-”
%B 發送的字節數,不包含HTTP頭
%h 遠端主機名(如果resolveHosts=false),遠端的IP
%H 請求協議
%l 從identd返回的遠端邏輯用戶名,總是返回’-’
%m 請求的方法
%p 收到請求的本地端口號
%q 查詢字符串
%r 請求的第一行
%s 響應的狀態碼
%S 用戶的sessionID
%t 日志和時間,使用通常的log格式
%u 認證以后的遠端用戶(如果存在的話,否則為’-’)
%U 請求的URI路徑
%v 本地服務器的名稱
%D 處理請求的時間,以毫秒為單位
%T 處理請求的時間,以秒為單位
可以自定義修改日志輸出內容
tomcat日志級別,在tomcat根下conf/logging.properties
日志分為5類
catalina 、 localhost 、 manager 、 admin 、 host-manager
日志每類分為從高到低
SEVERE (highest value) > WARNING > INFO > CONFIG > FINE > FINER > FINEST (lowest value)
level為日志級別(OFF設置關閉,ALL設置所有日志均輸出),dicectory為日志路徑,prefix為文件名稱,1-4日志進行拼接最終輸出一份日志
參考https://blog.csdn.net/qiuyinthree/article/details/72677173
log4j日志(一般開發將該文件放在項目的缺省目錄即源包下,在文件系統里,就是在項目的/src/java目錄下,缺省的文件名是log4j.properties,這樣項目發布后,就在tomcat的安裝目錄下的/webapps/項目名稱/WEB-INF/classes里)
先了解下log4j的配置
1. 配置文件
#配置根Logger log4j.rootLogger = [ level ] , appenderName1 , appenderName2 , … #配置日志信息輸出目的地Appender log4j.appender.appenderName = fully.qualified.name.of.appender.class log4j.appender.appenderName.option1 = value1 … log4j.appender.appenderName.optionN = valueN #配置日志信息的格式(布局) log4j.appender.appenderName.layout = fully.qualified.name.of.layout.class log4j.appender.appenderName.layout.option1 = value1 … log4j.appender.appenderName.layout.optionN = valueN
[level] 是日志輸出級別,共有5級:
ERROR 3
WARN 4
INFO 6
DEBUG 7
Appender 為日志輸出目的地,Log4j提供的appender有以下幾種:
org.apache.log4j.ConsoleAppender(控制台),
org.apache.log4j.FileAppender(文件),
org.apache.log4j.DailyRollingFileAppender(每天產生一個日志文件),
org.apache.log4j.RollingFileAppender(文件大小到達指定尺寸的時候產生一個新的文件),
org.apache.log4j.WriterAppender(將日志信息以流格式發送到任意指定的地方)
Layout:日志輸出格式,Log4j提供的layout有以下幾種:
org.apache.log4j.HTMLLayout(以HTML表格形式布局),
org.apache.log4j.PatternLayout(可以靈活地指定布局模式),
org.apache.log4j.SimpleLayout(包含日志信息的級別和信息字符串),
org.apache.log4j.TTCCLayout(包含日志產生的時間、線程、類別等等信息)
打印參數: Log4J采用類似C語言中的printf函數的打印格式格式化日志信息,如下:
%m 輸出代碼中指定的消息
%p 輸出優先級,即DEBUG,INFO,WARN,ERROR,FATAL %r 輸出自應用啟動到輸出該log信息耗費的毫秒數
%c 輸出所屬的類目,通常就是所在類的全名
%t 輸出產生該日志事件的線程名
%n 輸出一個回車換行符,Windows平台為“/r/n”,Unix平台為“/n”
%d 輸出日志時間點的日期或時間,默認格式為ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss , SSS},輸出類似:2002年10月18日 22 : 10 : 28 , 921
%l 輸出日志事件的發生位置,包括類目名、發生的線程,以及在代碼中的行數。舉例:Testlog4.main(TestLog4.java: 10 )
2. 在代碼中初始化Logger:
1)在程序中調用BasicConfigurator.configure()方法:給根記錄器增加一個ConsoleAppender,輸出格式通過PatternLayout設為"%-4r [%t] %-5p %c %x - %m%n",還有根記錄器的默認級別是Level.DEBUG.
2)配置放在文件里,通過命令行參數傳遞文件名字,通過PropertyConfigurator.configure(args[x])解析並配置;
3)配置放在文件里,通過環境變量傳遞文件名等信息,利用log4j默認的初始化過程解析並配置;
4)配置放在文件里,通過應用服務器配置傳遞文件名等信息,利用一個特殊的servlet來完成配置。
3. 為不同的 Appender 設置日志輸出級別:
當調試系統時,我們往往注意的只是異常級別的日志輸出,但是通常所有級別的輸出都是放在一個文件里的,如果日志輸出的級別是BUG!?那就慢慢去找吧。
這時我們也許會想要是能把異常信息單獨輸出到一個文件里該多好啊。當然可以,Log4j已經提供了這樣的功能,我們只需要在配置中修改Appender的Threshold 就能實現,比如下面的例子:
### set log levels ### log4j.rootLogger = debug , stdout , D , E
### 輸出到控制台 ### log4j.appender.stdout = org.apache.log4j.ConsoleAppender log4j.appender.stdout.Target = System.out log4j.appender.stdout.layout = org.apache.log4j.PatternLayout log4j.appender.stdout.layout.ConversionPattern = %d{ABSOLUTE} %5p %c{ 1 }:%L - %m%n
### 輸出到日志文件 ### log4j.appender.D = org.apache.log4j.DailyRollingFileAppender log4j.appender.D.File = logs/log.log log4j.appender.D.Append = true log4j.appender.D.Threshold = DEBUG ## 輸出DEBUG級別以上的日志 log4j.appender.D.layout = org.apache.log4j.PatternLayout log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n ### 保存異常信息到單獨文件 ### log4j.appender.D = org.apache.log4j.DailyRollingFileAppender log4j.appender.D.File = logs/error.log ## 異常日志文件名 log4j.appender.D.Append = true log4j.appender.D.Threshold = ERROR ## 只輸出ERROR級別以上的日志!!! log4j.appender.D.layout = org.apache.log4j.PatternLayout log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n
代碼中的使用
public class TestLog4j { public static void main(String[] args) { PropertyConfigurator.configure( " D:/Code/conf/log4j.properties " ); Logger logger = Logger.getLogger(TestLog4j. class ); logger.debug( " debug " ); logger.error( " error " ); } }
輸出結果:
參考https://blog.csdn.net/azheng270/article/details/2173430/
apache
apache日志分為訪問日志access.log,和錯誤日志error.log
可以在httpd.conf中配置
access.log
error.log
[發生錯誤時間] [錯誤嚴重等級] [pid號] [錯誤ip地址] [錯誤文件系統路徑]
nginx
nginx的日志分為access.log( 記錄了哪些用戶,哪些頁面以及用戶瀏覽器、ip和其他的訪問信息)和error.log(錯誤信息)
access.log: 在nginx根下log/access.log
ip地址--[訪問時間] “請求方式 /請求協議” 返回狀態碼 返回字節數 “跳轉來源,沒有為-” “瀏覽器信息”
自定義配置: 在nginx根下conf/nginx.conf
#access日志格式配置,具體參數不再細說,上面都已經說過了,自己對應一下即可 log_format main '$remote_addr - $remote_user [$time_local] ' 'fwf[$http_x_forwarded_for] tip[$http_true_client_ip] ' '$upstream_addr $upstream_response_time $request_time ' '$geoip_country_code ' '$http_host $request ' '"$status" $body_bytes_sent "$http_referer" ' '"$http_accept_language" "$http_user_agent" '; #配置access log日志的存儲位置及文件,注意:access.log文件是可以按日期進行分割的,方便查看及處理
error.log: 在nginx根下log/error.log
錯誤信息千奇百怪,我就不一 一舉例了,以上是81端口被占用
版權聲明:本文原創發表於 博客園,作者為 RainBol 本文歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接,否則視為侵權。