Logback日志系統(tǒng)

特點(diǎn)

  1. 配置簡單脆丁,易于上手
  2. 一個日志文件中只能某一個級別的日志
  3. 一個類中可以指定多個不同的日志构眯,并且生成的每個日志文件中只包含其本身的內(nèi)容
  4. 可以關(guān)閉或者打開某幾個包的日志,并且可以設(shè)置不同的包使用不同的日志級別

一忠烛、易用性

logback的易用性不用多講坯墨,只需要通過下面兩行就可以在console中輸出日志:

Logger debugLogger = LoggerFactory.getLogger(MyClass.class);
logger.info("This is a log");

程序運(yùn)行時寂汇,logback會查找默認(rèn)的配置文件logback.xml或者logback-test.xml文件,如果沒有找到它就會使用默認(rèn)的配置捣染,將日志打印到console中骄瓣。下面是一個配置文件示例:

<?xml version="1.0" encoding="UTF-8" ?>
<configuration>
    <!-- 設(shè)置日志輸出根目錄 -->
    <property name="log.dir" value="logs" />
    <property name="encoding" value="UTF-8" />
    <property name="pattern"
              value="%d{yyyy-MM-dd.HH:mm:ss} %-5level [%thread] %logger.%M:%L  %msg%n" />

    <!-- 控制臺輸出日志 -->
    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
        <layout class="ch.qos.logback.classic.PatternLayout">
            <pattern>${pattern}</pattern>
        </layout>
    </appender>
    <!-- 主日志 -->
    <appender name="FILE"
              class="ch.qos.logback.core.rolling.RollingFileAppender">
        <File>main.log</File>
        <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
            <level>INFO</level>
        </filter>
        <file>${log.dir}/main.log</file>
        <prudent>false</prudent>
        <encoder charset="UTF-8">
            <pattern>${pattern}</pattern>
        </encoder>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>${log.dir}/main.%d{yyyy-MM-dd-HH}.log.gz</fileNamePattern>
        </rollingPolicy>
    </appender>
    <!-- 錯誤日志 -->
    <appender name="ERROR_FILE"
              class="ch.qos.logback.core.rolling.RollingFileAppender">
        <File>error.log</File>
        <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
            <level>ERROR</level>
        </filter>
        <file>${log.dir}/error.log</file>
        <prudent>false</prudent>
        <encoder charset="UTF-8">
            <pattern>${pattern}</pattern>
        </encoder>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>${log.dir}/error.%d{yyyy-MM-dd-HH}.log.gz</fileNamePattern>
        </rollingPolicy>
    </appender>

    <logger name="com.qunar.fresh2017.exam1">
        <level value="INFO" />
        <appender-ref ref="STDOUT" />
        <appender-ref ref="FILE" />
        <appender-ref ref="ERROR_FILE" />
    </logger>

</configuration>

二、日志級別限制

在多數(shù)的Log工具中耍攘,級別是可以傳遞榕栏,例如如果指定了日志輸出級別為DEBUG畔勤,那么INFO、ERROR級別的log也會出現(xiàn)在日志文件扒磁。這種默認(rèn)給程序的調(diào)試帶來了很多的麻煩庆揪。而在logback中可以通過appender中的filter來嚴(yán)格限制日志的輸出級別:

<filter class="ch.qos.logback.classic.filter.LevelFilter">  
    <level>INFO</level>  
    <onMatch>ACCEPT</onMatch>  
    <onMismatch>DENY</onMismatch>  
</filter>  

上面的設(shè)置中只會在文件中出現(xiàn)級別為INFO的日志內(nèi)容。

三妨托、同一個類中包含不同的日志

有時候一個類中可能要求打印不同的日志信息缸榛,例如有的用來調(diào)試,有的用來記錄程序運(yùn)行中的某些參數(shù)的變化等等兰伤。這時候可以通過下面的語句聲明不同的日志:

<appender name="monitor" class="ch.qos.logback.core.rolling.RollingFileAppender">  
    <File>${log.dir}/monitor.log</File>  
    <encoder>  
        <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} : %m%n</pattern>  
    </encoder>  
    <filter class="ch.qos.logback.classic.filter.ThresholdFilter">  
        <level>INFO</level>  
    </filter>  
    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">  
        <fileNamePattern>${log.dir}/sensitive.log.%d{yyyy-MM-dd}</fileNamePattern>  
    </rollingPolicy>  
</appender>  

# 這里通過設(shè)置additivity="false"禁止monitor里的內(nèi)容向上傳遞内颗,否則會同時顯示在默認(rèn)的日志中。
<logger name="monitor" additivity="false" level="INFO">  
    <span style="white-space:pre"></span>
    <appender-ref ref="monitor" />  
    <span style="white-space:pre"></span>
</logger>  

Logger debugLogger = LoggerFactory.getLogger(MyClass.class);  
Logger monitorLogger = LoggerFactory.getLogger("monitor");  

四敦腔、精確控制日志的應(yīng)用范圍

在程序調(diào)試中起暮,經(jīng)常出現(xiàn)的情況是:錯誤只在某一個或者幾個類或者包里,所以只需要打開這幾個類或者包里的DEBUG級別的log会烙。在以前的項目负懦,使用spring和hibernate時,一旦打開DEBUG級別的log柏腻,程序本身的debug信息就會被Spring和Hibernate的大量日志淹沒纸厉,大大降低了調(diào)試的效率。而logback讓這一切變的簡單起來了:

<logger name="org" level="ERROR" />  
這一行就將org包下面的所有日志級別設(shè)為了ERROR五嫂,不會再打擾我們的DEBUG颗品。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市沃缘,隨后出現(xiàn)的幾起案子躯枢,更是在濱河造成了極大的恐慌,老刑警劉巖槐臀,帶你破解...
    沈念sama閱讀 218,607評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件锄蹂,死亡現(xiàn)場離奇詭異,居然都是意外死亡水慨,警方通過查閱死者的電腦和手機(jī)得糜,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,239評論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來晰洒,“玉大人朝抖,你說我怎么就攤上這事〉海” “怎么了治宣?”我有些...
    開封第一講書人閱讀 164,960評論 0 355
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我侮邀,道長缆巧,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,750評論 1 294
  • 正文 為了忘掉前任豌拙,我火速辦了婚禮陕悬,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘按傅。我一直安慰自己捉超,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,764評論 6 392
  • 文/花漫 我一把揭開白布唯绍。 她就那樣靜靜地躺著拼岳,像睡著了一般。 火紅的嫁衣襯著肌膚如雪况芒。 梳的紋絲不亂的頭發(fā)上惜纸,一...
    開封第一講書人閱讀 51,604評論 1 305
  • 那天,我揣著相機(jī)與錄音绝骚,去河邊找鬼耐版。 笑死,一個胖子當(dāng)著我的面吹牛压汪,可吹牛的內(nèi)容都是我干的粪牲。 我是一名探鬼主播,決...
    沈念sama閱讀 40,347評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼止剖,長吁一口氣:“原來是場噩夢啊……” “哼腺阳!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起穿香,我...
    開封第一講書人閱讀 39,253評論 0 276
  • 序言:老撾萬榮一對情侶失蹤亭引,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后皮获,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體焙蚓,經(jīng)...
    沈念sama閱讀 45,702評論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,893評論 3 336
  • 正文 我和宋清朗相戀三年魔市,在試婚紗的時候發(fā)現(xiàn)自己被綠了主届。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,015評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡待德,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出枫夺,到底是詐尸還是另有隱情将宪,我是刑警寧澤,帶...
    沈念sama閱讀 35,734評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站较坛,受9級特大地震影響印蔗,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜丑勤,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,352評論 3 330
  • 文/蒙蒙 一华嘹、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧法竞,春花似錦耙厚、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,934評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至呆细,卻和暖如春型宝,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背絮爷。 一陣腳步聲響...
    開封第一講書人閱讀 33,052評論 1 270
  • 我被黑心中介騙來泰國打工趴酣, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人坑夯。 一個月前我還...
    沈念sama閱讀 48,216評論 3 371
  • 正文 我出身青樓价卤,卻偏偏與公主長得像,于是被迫代替她去往敵國和親渊涝。 傳聞我的和親對象是個殘疾皇子慎璧,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,969評論 2 355

推薦閱讀更多精彩內(nèi)容