• <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>

            大龍的博客

            常用鏈接

            統(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 大龍 閱讀(486) 評(píng)論(0)  編輯 收藏 引用


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


            国产精品99久久精品| 亚洲AV成人无码久久精品老人| 99久久婷婷国产一区二区| 久久国产美女免费观看精品| 国产精品久久婷婷六月丁香| 精品国产乱码久久久久久1区2区 | 天天爽天天爽天天片a久久网| 久久久久99精品成人片| 天天躁日日躁狠狠久久| 久久精品亚洲乱码伦伦中文| 无码人妻少妇久久中文字幕蜜桃 | 国产精品福利一区二区久久| 久久一区二区三区99| 国产一级持黄大片99久久| 性做久久久久久久久久久| 久久精品这里热有精品| 久久婷婷五月综合97色| 日韩欧美亚洲国产精品字幕久久久 | 久久天天躁狠狠躁夜夜avapp| 99久久精品午夜一区二区| 久久综合亚洲色HEZYO社区| 国产精久久一区二区三区| 久久精品www人人爽人人| 亚洲午夜久久久久久久久久| 欧美激情精品久久久久久久九九九 | 久久久久噜噜噜亚洲熟女综合| 狠狠色丁香婷婷久久综合不卡| 久久99久国产麻精品66| 热久久最新网站获取| 中文成人久久久久影院免费观看| 久久久青草青青亚洲国产免观| 精品无码久久久久久午夜| 色婷婷综合久久久久中文一区二区| 亚洲精品成人久久久| 国产香蕉久久精品综合网| 色偷偷88欧美精品久久久| 中文字幕久久精品| 老男人久久青草av高清| 亚洲va久久久噜噜噜久久天堂| 五月丁香综合激情六月久久| 久久ZYZ资源站无码中文动漫|