亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Java > 正文

log4j的配置文件詳細解析

2019-11-26 15:59:41
字體:
來源:轉載
供稿:網友

1.Log4j的優點
Log4j是Apache的一個開放源代碼項目,通過使用Log4j,我們可以控制日志信息輸送地;我們也可以控制每一條日志的輸出格式;通過定義每一條日志信息的級別,我們能夠更加細致地控制日志的生成過程。最令人感興趣的就是,這些可以通過一個配置文件來靈活地進行配置,而不需要修改應用的代碼。

log4j的好處在于:
(1) 通過修改配置文件,就可以決定log信息的目的地――控制臺、文件、GUI組件、甚至是套接口服務器、NT的事件記錄器、UNIX Syslog守護進程等。

(2) 通過修改配置文件,可以定義每一條日志信息的級別,從而控制是否輸出。在系統開發階段可以打印詳細的log信息以跟蹤系統運行情況,而在系統穩定后可以關閉log輸出,從而在能跟蹤系統運行情況的同時,又減少了垃圾代碼(System.out.println(......)等)。

(3) 使用log4j,需要整個系統有一個統一的log機制,有利于系統的規劃。

2.配置文件
Log4j由三個重要的組件構成:日志信息的優先級,日志信息的輸出目的地,日志信息的輸出格式。日志信息的優先級從高到低有FATAL、ERROR、WARN、INFO、DEBUG、TRACE、ALL,分別用來指定這條日志信息的重要程度;日志信息的輸出目的地指定了日志將打印到控制臺還是文件中;而輸出格式則控制了日志信息的顯示內容。

2.1 日志信息的優先級
Log4j建議只使用四個級別,優先級從高到低分別是ERROR、WARN、INFO、DEBUG。通過在這里定義的級別,您可以控制到應用程序中相應級別的日志信息的開關。如在這里定義了INFO級別,則應用程序中所有低于INFO級別的日志信息將不被打印出來。

2.2 輸出源的使用
有選擇的能用或者禁用日志請求僅僅是Log4j的一部分功能。Log4j允許日志請求被輸出到多個輸出源。用Log4j的話說,一個輸出源被稱做一個Appender。

Appender包括console(控制臺), files(文件), GUI components(圖形的組件), remote socket servers(socket 服務), JMS(java信息服務), NT Event Loggers(NT的事件日志), remote UNIX Syslog daemons(遠程UNIX的后臺日志服務)。它也可以做到異步記錄。 一個logger可以設置超過一個的appender。 用addAppender方法添加一個appender到一個給定的logger。對于一個給定的logger它每個生效的日志請求都被轉發到該logger所有的appender上和該logger的父輩 logger的appender上。

2.2.1 ConsoleAppender
如果使用ConsoleAppender,那么log信息將寫到Console。效果等同于直接把信息打印到System.out上了。

2.2.2 FileAppender
使用FileAppender,那么log信息將寫到指定的文件中。這應該是比較經常使用到的情況。 相應地,在配置文件中應該指定log輸出的文件名。如下配置指定了log文件名為log.txt。

log4j.appender.appendername.File=log.txt 注意將appendername替換為具體配置中Appender的別名。

注意:指定的log文件路徑問題

2.2.3 DailyRollingAppender
使用FileAppender可以將log信息輸出到文件中,但是如果文件太大了讀起來就不方便了。這時就可以使用DailyRollingAppender。DailyRollingAppender可以把Log信息輸出到按照日期來區分的文件中。配置文件就會每天(時間可以設定)產生一個log文件,每個log文件只記錄當天的log信息:

復制代碼 代碼如下:

log4j.appender.appendername=org.apache.log4j.DailyRollingFileAppender 
log4j.appender.Aappendername.file=log 
log4j.appender.appendername.DatePattern='.'yyyy-MM-dd 
log4j.appender.appendername.layout=org.apache.log4j.PatternLayout 
log4j.appender.appendername.layout.ConversionPattern= %5r %-5p %c{2} - %m%n

2.2.4 RollingFileAppender
文件大小到達指定尺寸的時候產生一個新的文件。
復制代碼 代碼如下:

og4j.appender.appendername=org.apache.log4j.RollingFileAppender 
log4j.appender.appendername.File= ../logs/rlog.log 
# Control the maximum log file size 
log4j.appender.appendername.MaxFileSize=100KB 
# Archive log files (one backup file here) 
log4j.appender.appendername.MaxBackupIndex=1

log4j.appender.appendername.layout=org.apache.log4j.PatternLayout 
log4j.appender.appendername.layout.ConversionPattern=%p %t %c - %m%n


這個配置文件指定了輸出源appendername,是一個輪轉日志文件。最大的文件是100KB,當一個日志文件達到最大尺寸時,Log4J會自動把rlog.log重命名為rlog.log.1,然后重建一個新的rlog.log文件,依次輪轉。

2.2.5 WriterAppender
將日志信息以流格式發送到任意指定的地方。

2.3 Layout的配置
Layout指定了log信息輸出的樣式。

2.3.1 布局樣式

復制代碼 代碼如下:

org.apache.log4j.HTMLLayout(以HTML表格形式布局), 
org.apache.log4j.PatternLayout(可以靈活地指定布局模式), 
org.apache.log4j.SimpleLayout(包含日志信息的級別和信息字符串), 
org.apache.log4j.TTCCLayout(包含日志產生的時間、線程、類別等等信息) 

2.3.2 格式
復制代碼 代碼如下:

%m 輸出代碼中指定的消息 
%p 輸出優先級,即DEBUG,INFO,WARN,ERROR,FATAL 
%r 輸出自應用啟動到輸出該log信息耗費的毫秒數 
%c 輸出所屬的類目,通常就是所在類的全名 
%t 輸出產生該日志事件的線程名 
%n 輸出一個回車換行符,Windows平臺為"rn",Unix平臺為"n" 
%d 輸出日志時間點的日期或時間,默認格式為ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss,SSS},輸出類似:2002年10月18日 22:10:28,921 
%l 輸出日志事件的發生位置,包括類目名、發生的線程,以及在代碼中的行數。舉例:Testlog4.main(Test Log4.java:10)

3.為不同的Appender設置日志輸出級別
通過在配置中修改Appender的Threshold即能實現,比如下面的例子:

配置文件:
log4j.rootLogger = debug,A,B,C

# 輸出到控制臺
log4j.appender.A = org.apache.log4j.ConsoleAppender
log4j.appender.A.Target = System.out
log4j.appender.A.layout = org.apache.log4j.PatternLayout
log4j.appender.A.layout.ConversionPattern = %p %t %c - %m%n

# 輸出到日志文件
log4j.appender.B = org.apache.log4j.DailyRollingFileAppender
log4j.appender.B.File = logs/log.log
log4j.appender.B.Append = true
log4j.appender.B.Threshold = DEBUG # 輸出EBUG級別以上的日志
log4j.appender.B.layout = org.apache.log4j.PatternLayout
log4j.appender.B.layout.ConversionPattern = %p %t %c - %m%n

# 保存異常信息到單獨文件
log4j.appender.C = org.apache.log4j.DailyRollingFileAppender
log4j.appender.C.File = logs/error.log # 異常日志文件名
log4j.appender.C.Append = true
log4j.appender.C.Threshold = ERROR #只輸出ERROR級別以上的日志
log4j.appender.C.layout = org.apache.log4j.PatternLayout
log4j.appender.C.layout.ConversionPattern = %p %t %c - %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");  
    }
}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91国内在线视频| 亚洲电影成人av99爱色| 国产日韩av在线播放| 成人激情免费在线| 色婷婷综合久久久久中文字幕1| 奇门遁甲1982国语版免费观看高清| 欧美精品videos性欧美| 日韩美女中文字幕| 午夜精品一区二区三区av| 欧美高清视频在线观看| 亚洲第一偷拍网| 久久久久久久久久久av| 国产成人精品综合久久久| 国产精品免费视频久久久| www国产精品视频| 久久久综合免费视频| 成人444kkkk在线观看| 日韩欧美精品在线观看| 国产精品美腿一区在线看| 精品国产一区久久久| 亚洲欧美另类在线观看| 97欧美精品一区二区三区| 欧美在线视频在线播放完整版免费观看| 欧美一区二区三区免费观看| 久久久久久久国产精品视频| 国产精品久久国产精品99gif| 欧美香蕉大胸在线视频观看| 亚洲一区二区三区久久| 日韩欧美主播在线| 浅井舞香一区二区| 久久久久久999| 久久福利网址导航| 成人高清视频观看www| 不卡av电影在线观看| 国产精品视频在线播放| 91po在线观看91精品国产性色| 国产+人+亚洲| 欧美在线一级va免费观看| 亚洲日本成人网| 国产日韩精品在线播放| 日韩在线高清视频| 亚洲iv一区二区三区| 91免费看视频.| 亚洲国产精品va在线看黑人动漫| 国产精品自产拍在线观看| 国产精品久久久久9999| 国产亚洲欧美日韩精品| 精品国产一区二区三区久久久狼| 亚洲国产欧美一区二区三区久久| 538国产精品一区二区免费视频| 伊人久久久久久久久久久| 国产精品久久久久久久久| 国产+成+人+亚洲欧洲| 国产欧美日韩免费看aⅴ视频| 视频直播国产精品| 欧美国产高跟鞋裸体秀xxxhd| 欧美在线免费观看| 中国日韩欧美久久久久久久久| 亚洲国产欧美一区二区三区久久| 97视频网站入口| 中文字幕亚洲一区| 亚洲欧美在线一区| 久久久久久国产精品三级玉女聊斋| 热久久这里只有精品| 成人久久精品视频| 亚洲女人天堂av| 日韩视频一区在线| 国产精品国产福利国产秒拍| 亚洲欧美日韩图片| 欧美亚洲视频在线看网址| 最新国产成人av网站网址麻豆| 粉嫩老牛aⅴ一区二区三区| 日日狠狠久久偷偷四色综合免费| 久久不射电影网| 亚洲欧美日韩精品久久奇米色影视| 国产日产亚洲精品| 韩国v欧美v日本v亚洲| 欧美亚洲视频在线观看| 丝袜一区二区三区| 丰满岳妇乱一区二区三区| 亚洲精品视频二区| 日韩精品欧美国产精品忘忧草| 亚洲成人精品在线| 91精品国产自产91精品| 最近2019中文字幕第三页视频| 久久天天躁狠狠躁夜夜躁| 日本韩国欧美精品大片卡二| 久久久久久成人| 日韩精品在线视频观看| 亚洲少妇激情视频| 欧美日韩国产999| 欧美精品一区二区免费| 68精品久久久久久欧美| 亚洲成色777777女色窝| 黑人精品xxx一区一二区| 色老头一区二区三区在线观看| 亚洲激情在线观看| 欧美一区深夜视频| 日韩久久午夜影院| 欧美黑人极品猛少妇色xxxxx| 8090成年在线看片午夜| 亚洲精品国精品久久99热| 欧美成人中文字幕在线| 欧美激情网站在线观看| 欧美极品少妇全裸体| 欧美激情一区二区三级高清视频| 国产精品免费一区豆花| 美女撒尿一区二区三区| 欧美老少做受xxxx高潮| 福利视频第一区| 一区二区三区日韩在线| 富二代精品短视频| 亚洲精品国偷自产在线99热| 中日韩美女免费视频网址在线观看| 欧美电影院免费观看| 欧美在线视频导航| 97成人在线视频| 欧美在线不卡区| 久久亚洲精品视频| 亚洲精品白浆高清久久久久久| 欧美黑人极品猛少妇色xxxxx| 亚洲最大av网| 欧美极品第一页| 国产99久久精品一区二区 夜夜躁日日躁| 伦伦影院午夜日韩欧美限制| 国产精品嫩草影院一区二区| 欧美日本亚洲视频| 日韩免费观看高清| 欧美福利视频在线观看| 久久久久女教师免费一区| 成人av色在线观看| 中文字幕亚洲欧美一区二区三区| 国产精品 欧美在线| 国产成人精品免费久久久久| 国产精品入口免费视| 欧美在线不卡区| 国产精品成久久久久三级| 午夜精品一区二区三区在线| 亚洲美女动态图120秒| 欧美孕妇与黑人孕交| 亚洲一区亚洲二区亚洲三区| 日韩二区三区在线| 亚洲精品黄网在线观看| 亚洲自拍欧美色图| 成人免费网站在线观看| 国产综合在线看| 97视频在线播放| 精品国产老师黑色丝袜高跟鞋| 久久久久久久久久国产精品| 一区二区欧美日韩视频| 91亚洲国产成人精品性色| 亚洲成在人线av| 成人免费xxxxx在线观看| 亚洲free性xxxx护士hd| 欧美片一区二区三区| 国产一区二区av| 97av视频在线| 中文字幕一区二区三区电影| 91地址最新发布| 欧美激情免费视频| 欧美日韩在线免费观看| 中文字幕成人在线| 在线精品国产成人综合| 日本在线精品视频|