青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

大龍的博客

常用鏈接

統(tǒng)計(jì)

最新評(píng)論

logback 配置詳解(一) and

一:根節(jié)點(diǎn)<configuration>包含的屬性:

 

scan:

當(dāng)此屬性設(shè)置為true時(shí),配置文件如果發(fā)生改變,將會(huì)被重新加載,默認(rèn)值為true。

scanPeriod:

設(shè)置監(jiān)測(cè)配置文件是否有修改的時(shí)間間隔,如果沒(méi)有給出時(shí)間單位,默認(rèn)單位是毫秒。當(dāng)scan為true時(shí),此屬性生效。默認(rèn)的時(shí)間間隔為1分鐘。

debug:

當(dāng)此屬性設(shè)置為true時(shí),將打印出logback內(nèi)部日志信息,實(shí)時(shí)查看logback運(yùn)行狀態(tài)。默認(rèn)值為false。

例如:

 

Xml代碼  收藏代碼
  1. <configuration scan="true" scanPeriod="60 seconds" debug="false">  
  2.       <!-- 其他配置省略-->  
  3. </configuration>  

 

二:根節(jié)點(diǎn)<configuration>的子節(jié)點(diǎn):

 

2.1設(shè)置上下文名稱:<contextName>

每個(gè)logger都關(guān)聯(lián)到logger上下文,默認(rèn)上下文名稱為“default”。但可以使用<contextName>設(shè)置成其他名字,用于區(qū)分不同應(yīng)用程序的記錄。一旦設(shè)置,不能修改。

 

Xml代碼  收藏代碼
  1. <configuration scan="true" scanPeriod="60 seconds" debug="false">  
  2.       <contextName>myAppName</contextName>  
  3.       <!-- 其他配置省略-->  
  4. </configuration>  

 

2.2設(shè)置變量: <property>

用來(lái)定義變量值的標(biāo)簽,<property> 有兩個(gè)屬性,name和value;其中name的值是變量的名稱,value的值時(shí)變量定義的值。通過(guò)<property>定義的值會(huì)被插 入到logger上下文中。定義變量后,可以使“${}”來(lái)使用變量。

例如使用<property>定義上下文名稱,然后在<contentName>設(shè)置logger上下文時(shí)使用。

Xml代碼  收藏代碼
  1. <configuration scan="true" scanPeriod="60 seconds" debug="false">  
  2.       <property name="APP_Name" value="myAppName" />   
  3.       <contextName>${APP_Name}</contextName>  
  4.       <!-- 其他配置省略-->  
  5. </configuration>   

 

 

2.3獲取時(shí)間戳字符串:<timestamp>

兩個(gè)屬性 key:標(biāo)識(shí)此<timestamp> 的名字;datePattern:設(shè)置將當(dāng)前時(shí)間(解析配置文件的時(shí)間)轉(zhuǎn)換為字符串的模式,遵循java.txt.SimpleDateFormat的格式。

        例如將解析配置文件的時(shí)間作為上下文名稱:

Xml代碼  收藏代碼
  1. <configuration scan="true" scanPeriod="60 seconds" debug="false">  
  2.       <timestamp key="bySecond" datePattern="yyyyMMdd'T'HHmmss"/>   
  3.       <contextName>${bySecond}</contextName>  
  4.       <!-- 其他配置省略-->  
  5. </configuration>   

 

2.4設(shè)置loger:

<loger>

用來(lái)設(shè)置某一個(gè)包或者具體的某一個(gè)類的日志打印級(jí)別、以及指定<appender>。<loger>僅有一個(gè)name屬性,一個(gè)可選的level和一個(gè)可選的addtivity屬性。

name:

用來(lái)指定受此loger約束的某一個(gè)包或者具體的某一個(gè)類。

level:

用來(lái)設(shè)置打印級(jí)別,大小寫無(wú)關(guān):TRACE, DEBUG, INFO, WARN, ERROR, ALL 和 OFF,還有一個(gè)特俗值INHERITED或者同義詞NULL,代表強(qiáng)制執(zhí)行上級(jí)的級(jí)別。

如果未設(shè)置此屬性,那么當(dāng)前l(fā)oger將會(huì)繼承上級(jí)的級(jí)別。

addtivity:

是否向上級(jí)loger傳遞打印信息。默認(rèn)是true。

<loger>可以包含零個(gè)或多個(gè)<appender-ref>元素,標(biāo)識(shí)這個(gè)appender將會(huì)添加到這個(gè)loger。

 

<root>

也是<loger>元素,但是它是根loger。只有一個(gè)level屬性,應(yīng)為已經(jīng)被命名為"root".

level:

用來(lái)設(shè)置打印級(jí)別,大小寫無(wú)關(guān):TRACE, DEBUG, INFO, WARN, ERROR, ALL 和 OFF,不能設(shè)置為INHERITED或者同義詞NULL。

默認(rèn)是DEBUG。

<root>可以包含零個(gè)或多個(gè)<appender-ref>元素,標(biāo)識(shí)這個(gè)appender將會(huì)添加到這個(gè)loger。

 

例如:

LogbackDemo.java類

Java代碼  收藏代碼
  1. package logback;  
  2.   
  3. import org.slf4j.Logger;  
  4. import org.slf4j.LoggerFactory;  
  5.   
  6. public class LogbackDemo {  
  7.     private static Logger log = LoggerFactory.getLogger(LogbackDemo.class);  
  8.     public static void main(String[] args) {  
  9.         log.trace("======trace");  
  10.         log.debug("======debug");  
  11.         log.info("======info");  
  12.         log.warn("======warn");  
  13.         log.error("======error");  
  14.     }  
  15. }  

 

logback.xml配置文件

 

第1種:只配置root

Xml代碼  收藏代碼
  1. <configuration>   
  2.    
  3.   <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">   
  4.     <!-- encoder 默認(rèn)配置為PatternLayoutEncoder -->   
  5.     <encoder>   
  6.       <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>   
  7.     </encoder>   
  8.   </appender>   
  9.    
  10.   <root level="INFO">             
  11.     <appender-ref ref="STDOUT" />   
  12.   </root>     
  13.      
  14.  </configuration>  

 其中appender的配置表示打印到控制臺(tái)(稍后詳細(xì)講解appender );

<root level="INFO">將root的打印級(jí)別設(shè)置為“INFO”,指定了名字為“STDOUT”的appender。

 

當(dāng)執(zhí)行l(wèi)ogback.LogbackDemo類的main方法時(shí),root將級(jí)別為“INFO”及大于“INFO”的日志信息交給已經(jīng)配置好的名為“STDOUT”的appender處理,“STDOUT”appender將信息打印到控制臺(tái);

打印結(jié)果如下:

Xml代碼  收藏代碼
  1. 13:30:38.484 [main] INFO  logback.LogbackDemo - ======info  
  2. 13:30:38.500 [main] WARN  logback.LogbackDemo - ======warn  
  3. 13:30:38.500 [main] ERROR logback.LogbackDemo - ======error  

 

  第2種:帶有l(wèi)oger的配置,不指定級(jí)別,不指定appender,

Xml代碼  收藏代碼
  1. <configuration>   
  2.    
  3.   <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">   
  4.     <!-- encoder 默認(rèn)配置為PatternLayoutEncoder -->   
  5.     <encoder>   
  6.       <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>   
  7.     </encoder>   
  8.   </appender>   
  9.    
  10.   <!-- logback為java中的包 -->   
  11.   <logger name="logback"/>   
  12.    
  13.   <root level="DEBUG">             
  14.     <appender-ref ref="STDOUT" />   
  15.   </root>     
  16.      
  17.  </configuration>  

 其中appender的配置表示打印到控制臺(tái)(稍后詳細(xì)講解appender );

<logger name="logback" />將控制logback包下的所有類的日志的打印,但是并沒(méi)用設(shè)置打印級(jí)別,所以繼承他的上級(jí)<root>的日志級(jí)別“DEBUG”;

沒(méi)有設(shè)置addtivity,默認(rèn)為true,將此loger的打印信息向上級(jí)傳遞;

沒(méi)有設(shè)置appender,此loger本身不打印任何信息。

<root level="DEBUG">將root的打印級(jí)別設(shè)置為“DEBUG”,指定了名字為“STDOUT”的appender。

 

當(dāng)執(zhí)行l(wèi)ogback.LogbackDemo類的main方法時(shí),因?yàn)?LogbackDemo 在包logback中,所以首先執(zhí)行<logger name="logback" />,將級(jí)別為“DEBUG”及大于“DEBUG”的日志信息傳遞給root,本身并不打印;

root接到下級(jí)傳遞的信息,交給已經(jīng)配置好的名為“STDOUT”的appender處理,“STDOUT”appender將信息打印到控制臺(tái);

打印結(jié)果如下:

Xml代碼  收藏代碼
  1. 13:19:15.406 [main] DEBUG logback.LogbackDemo - ======debug  
  2. 13:19:15.406 [main] INFO  logback.LogbackDemo - ======info  
  3. 13:19:15.406 [main] WARN  logback.LogbackDemo - ======warn  
  4. 13:19:15.406 [main] ERROR logback.LogbackDemo - ======error  

 

 第3種:帶有多個(gè)loger的配置,指定級(jí)別,指定appender  

Xml代碼  收藏代碼
  1. <configuration>   
  2.    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">   
  3.     <!-- encoder 默認(rèn)配置為PatternLayoutEncoder -->   
  4.     <encoder>   
  5.       <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>   
  6.     </encoder>   
  7.   </appender>   
  8.    
  9.   <!-- logback為java中的包 -->   
  10.   <logger name="logback"/>   
  11.   <!--logback.LogbackDemo:類的全路徑 -->   
  12.   <logger name="logback.LogbackDemo" level="INFO" additivity="false">  
  13.     <appender-ref ref="STDOUT"/>  
  14.   </logger>   
  15.     
  16.   <root level="ERROR">             
  17.     <appender-ref ref="STDOUT" />   
  18.   </root>     
  19. </configuration>  

其中appender的配置表示打印到控制臺(tái)(稍后詳細(xì)講解appender );

 

<logger name="logback" />將控制logback包下的所有類的日志的打印,但是并沒(méi)用設(shè)置打印級(jí)別,所以繼承他的上級(jí)<root>的日志級(jí)別“DEBUG”;

沒(méi)有設(shè)置addtivity,默認(rèn)為true,將此loger的打印信息向上級(jí)傳遞;

沒(méi)有設(shè)置appender,此loger本身不打印任何信息。

 

 <logger name="logback.LogbackDemo" level="INFO" additivity="false">控制logback.LogbackDemo類的日志打印,打印級(jí)別為“INFO”;

additivity屬性為false,表示此loger的打印信息不再向上級(jí)傳遞,

指定了名字為“STDOUT”的appender。

 

<root level="ERROR">將root的打印級(jí)別設(shè)置為“ERROR”,指定了名字為“STDOUT”的appender。

 

 當(dāng)執(zhí)行l(wèi)ogback.LogbackDemo類的main方法時(shí),先執(zhí) 行<logger name="logback.LogbackDemo" level="INFO" additivity="false">,將級(jí)別為“INFO”及大于“INFO”的日志信息交給此loger指定的名為“STDOUT”的 appender處理,在控制臺(tái)中打出日志,不再向次loger的上級(jí) <logger name="logback"/> 傳遞打印信息;

<logger name="logback"/>未接到任何打印信息,當(dāng)然也不會(huì)給它的上級(jí)root傳遞任何打印信息;

打印結(jié)果如下:  

Xml代碼  收藏代碼
  1. 14:05:35.937 [main] INFO  logback.LogbackDemo - ======info  
  2. 14:05:35.937 [main] WARN  logback.LogbackDemo - ======warn  
  3. 14:05:35.937 [main] ERROR logback.LogbackDemo - ======error  

 如果將<logger name="logback.LogbackDemo" level="INFO" additivity="false">修改為 <logger name="logback.LogbackDemo" level="INFO" additivity="true">那打印結(jié)果將是什么呢?

沒(méi)錯(cuò),日志打印了兩次,想必大家都知道原因了,因?yàn)榇蛴⌒畔⑾蛏霞?jí)傳遞,logger本身打印一次,root接到后又打印一次

打印結(jié)果如下:  

Xml代碼  收藏代碼
  1. 14:09:01.531 [main] INFO  logback.LogbackDemo - ======info  
  2. 14:09:01.531 [main] INFO  logback.LogbackDemo - ======info  
  3. 14:09:01.531 [main] WARN  logback.LogbackDemo - ======warn  
  4. 14:09:01.531 [main] WARN  logback.LogbackDemo - ======warn  
  5. 14:09:01.531 [main] ERROR logback.LogbackDemo - ======error  
  6. 14:09:01.531 [main] ERROR logback.LogbackDemo - ======error

posted on 2012-08-16 03:53 大龍 閱讀(494) 評(píng)論(0)  編輯 收藏 引用


只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            牛牛影视久久网| 国产偷国产偷精品高清尤物| 一区二区三区毛片| 亚洲国产视频一区| 欧美一级二区| 久久精品国产一区二区三区免费看| 欧美亚洲视频| 久久综合一区二区三区| 欧美国产一区二区在线观看| 91久久精品一区| 在线亚洲成人| 久久深夜福利| 欧美日在线观看| 国产综合香蕉五月婷在线| 激情亚洲成人| 中文在线不卡| 亚洲欧美日韩一区在线观看| 久久色中文字幕| 免费不卡中文字幕视频| 亚洲国产精品久久久| 日韩亚洲欧美综合| 欧美影院午夜播放| 欧美日韩亚洲一区三区| 国产一区导航| 一本色道88久久加勒比精品| 欧美伊人久久| 亚洲国产免费看| 性色一区二区三区| 欧美精品一区二区三区一线天视频| 国产精品视频久久一区| 亚洲国产精品尤物yw在线观看 | 免费高清在线一区| 国产精品a久久久久久| 一区二区三区中文在线观看 | 欧美亚洲三级| 亚洲第一久久影院| 亚洲欧美经典视频| 欧美日韩国语| 亚洲精品在线视频观看| 久久久999精品视频| 亚洲少妇中出一区| 欧美日韩国产一区二区三区| 黄色欧美成人| 久久久精品久久久久| 一区二区免费在线视频| 欧美黄色免费| 亚洲精品欧美精品| 欧美jizz19性欧美| 久久久久国产免费免费| 国产欧美日本| 香蕉乱码成人久久天堂爱免费 | 久久精品免费观看| 国产精品丝袜白浆摸在线| 亚洲图片欧洲图片av| 亚洲国产乱码最新视频| 久久亚洲影院| 亚洲黄色在线看| 欧美1区视频| 久久影院午夜论| 在线国产日韩| 欧美h视频在线| 久久久久欧美| 亚洲第一综合天堂另类专| 久久婷婷一区| 久久久久免费观看| 亚洲精品久久嫩草网站秘色| 亚洲国产精品一区二区尤物区| 欧美日韩福利在线观看| 99这里只有久久精品视频| 亚洲精品婷婷| 欧美日韩中文| 午夜精品久久久久久久男人的天堂 | 久久综合电影一区| 亚洲国产精品免费| 亚洲激精日韩激精欧美精品| 欧美成人免费网| 亚洲视频在线观看一区| 99v久久综合狠狠综合久久| 国产精品va在线播放| 欧美一区观看| 另类激情亚洲| 亚洲一区二区av电影| 亚洲欧美日韩国产综合精品二区| 国产亚洲成精品久久| 免费观看不卡av| 欧美日韩二区三区| 午夜视频在线观看一区| 久久精品国产久精国产一老狼 | 极品裸体白嫩激情啪啪国产精品| 免费久久精品视频| 欧美精品福利在线| 欧美综合77777色婷婷| 久久精品国产一区二区三区免费看| 亚洲国产成人av| 亚洲视频精选| 亚洲国产精品久久久久久女王| 亚洲免费精品| 亚洲欧美区自拍先锋| 亚洲电影专区| 一个人看的www久久| 国内外成人免费激情在线视频 | 亚洲激情综合| 国产亚洲一区二区三区在线观看| 欧美大片18| 国产伦精品一区二区三区在线观看 | 亚洲精选在线| 国产一区二区日韩精品| 亚洲三级电影全部在线观看高清 | 国产精品一区二区黑丝| 亚洲大胆av| 国产在线观看精品一区二区三区| 亚洲黄一区二区三区| 韩国成人福利片在线播放| 99精品欧美一区二区三区综合在线| 影音先锋日韩精品| 午夜国产不卡在线观看视频| 99亚洲视频| 欧美精品在线免费观看| 嫩草成人www欧美| 国产精品免费网站在线观看| 亚洲国产婷婷香蕉久久久久久99| 国产日韩精品在线观看| 9色国产精品| 一区二区三区不卡视频在线观看| 久久精品免费播放| 久久人体大胆视频| 国产色综合久久| 亚洲女性裸体视频| 欧美一区二区三区久久精品| 国产精品av久久久久久麻豆网| 亚洲激情影院| 日韩午夜精品视频| 欧美国产精品| 亚洲黄色高清| 亚洲美女黄色| 欧美日韩国产经典色站一区二区三区| 欧美成人精品在线观看| 亚洲电影免费| 欧美成人小视频| 亚洲日本理论电影| 一本久久综合亚洲鲁鲁| 欧美少妇一区| 亚洲一区图片| 久久久激情视频| 在线播放中文字幕一区| 久久久精品日韩欧美| 免费欧美网站| 日韩视频第一页| 欧美性事在线| 午夜欧美精品久久久久久久| 久久久久久亚洲精品中文字幕| 韩日在线一区| 欧美成人免费全部观看天天性色| 亚洲激情一区二区| 亚洲欧美国产毛片在线| 国产一区二区三区在线播放免费观看 | 亚洲一区亚洲二区| 国产精品男女猛烈高潮激情| 午夜免费在线观看精品视频| 浪潮色综合久久天堂| 91久久久久久久久| 欧美午夜电影完整版| 欧美影院成人| 亚洲国产一区二区三区在线播| 亚洲深夜福利视频| 国产婷婷成人久久av免费高清| 可以免费看不卡的av网站| 亚洲麻豆视频| 久久天堂av综合合色| 99国产麻豆精品| 国产偷自视频区视频一区二区| 欧美 日韩 国产在线| 国产精品99久久久久久www| 麻豆久久久9性大片| 亚洲综合精品一区二区| 狠狠久久综合婷婷不卡| 欧美日本精品在线| 久久精品视频在线看| aaa亚洲精品一二三区| 麻豆成人精品| 午夜精品久久久久久99热| 91久久精品www人人做人人爽 | 你懂的国产精品| 欧美亚洲日本国产| 亚洲激情在线激情| 亚洲视频自拍偷拍| 久久精品国产亚洲5555| 亚洲激情av| 国产免费亚洲高清| 欧美韩国一区| 久久久国产精彩视频美女艺术照福利| 亚洲狼人综合| 欧美jizz19hd性欧美| 欧美尤物一区| 亚洲一区在线直播| 99精品99久久久久久宅男| 尤物九九久久国产精品的分类| 国产免费成人在线视频| 欧美视频第二页| 欧美精品色一区二区三区|