Spring Boot 入門系列(三) 集成Logback

文章使用版本為 Spring Boot 2.1.x

前言

對(duì)于任何項(xiàng)目來說三娩,打印日志都是必不可少的庵芭,日志的框架很多,這里我們要學(xué)習(xí)的就是非常流行的 logback雀监,logback同時(shí)也是spring boot默認(rèn)使用的日志框架双吆。在spring boot中有兩種方式配置logback,一是直接在application.yml中配置会前,這種方式可以進(jìn)行簡(jiǎn)單的配置好乐;二是在logback-spring.xml中配置,這種方式功能強(qiáng)大回官,可以進(jìn)行復(fù)雜的配置曹宴。

日志級(jí)別

日志級(jí)別從低到高依次是trace搂橙、debug歉提、info笛坦、warn、error苔巨,當(dāng)我們?cè)O(shè)置了某個(gè)日志打印級(jí)別的時(shí)候版扩,那么級(jí)別比它高的也將被打印,比如日志級(jí)別設(shè)置為info侄泽,那么info礁芦、warn、error的日志都會(huì)被打印悼尾。

在application.yml中配置

新建一個(gè)spring boot項(xiàng)目柿扣,在application.yml中添加一下配置

logging:
  level:
    org.schhx.springbootlearn: debug #指定日志級(jí)別
  pattern:
    console: "%d %-5level - %msg%n" #日志輸出格式

添加測(cè)試類

package org.schhx.springbootlearn;

import org.junit.Test;
import org.junit.runner.RunWith;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;

@RunWith(SpringRunner.class)
@SpringBootTest
public class LogTest {

    private final Logger logger = LoggerFactory.getLogger(LogTest.class);

    @Test
    public void printLog() throws Exception {
        logger.trace("msg:{}", "trace");
        logger.debug("msg:{}", "debug");
        logger.info("msg:{}", "info");
        logger.warn("msg:{}", "warn");
        logger.error("msg:{}", "error");
    }
}

啟動(dòng)測(cè)試類,可以看到結(jié)果如下

2018-01-21 16:30:34,470 DEBUG - msg:debug
2018-01-21 16:30:34,474 INFO  - msg:info
2018-01-21 16:30:34,474 WARN  - msg:warn
2018-01-21 16:30:34,474 ERROR - msg:error

可以看出日志級(jí)別和輸出格式都是和我們的設(shè)置一致闺魏,這種方式可以做些簡(jiǎn)單的配置未状,但是做復(fù)雜的配置就顯得有些心有余而力不足。

在logback-spring.xml中配置

logback-spring.xml其實(shí)就是一個(gè)普通的logback的配置文件析桥,只不過這個(gè)文件會(huì)被spring boot自動(dòng)加載司草。關(guān)于logback的常用配置,本篇文章不會(huì)過多討論泡仗,如果不太熟悉可以參考 logback常用配置埋虹。

另外spring boot允許我們通過<springProperty>標(biāo)簽把a(bǔ)pplication.yml中的配置引用到logback-spring.xml。例如娩怎,我們?cè)赼pplication.yml中配置

logging:
  pattern: "%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger [%file:%line] - %msg%n"

然后可以在logback-spring.xml使用

<springProperty name="LOG_PATTERN" source="logging.pattern"
                    defaultValue="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger [%file:%line] - %msg%n"/>

<appender name="console" class="ch.qos.logback.core.ConsoleAppender">
    <encoder>
        <pattern>${LOG_PATTERN}</pattern>
        <charset>utf8</charset>
    </encoder>
</appender>

spring boot已經(jīng)內(nèi)置了一些引用我們可以直接使用搔课,例如logging.path對(duì)應(yīng)LOG_PATH,完整文檔請(qǐng)參考Spring Boot官方文檔峦树。

多環(huán)境配置

一般情況下辣辫,我們想在本機(jī)測(cè)試時(shí),把日志打印到控制臺(tái)魁巩;而在服務(wù)器上運(yùn)行時(shí)急灭,把日志打印到文件。想實(shí)現(xiàn)這種功能我們可以使用<springProfile>標(biāo)簽谷遂,例如

    <springProfile name="default">
        <root level="info">
            <appender-ref ref="console"/>
        </root>
        <logger name="org.schhx.springbootlearn" level="debug"/>
    </springProfile>

    <springProfile name="dev,test,prod">
        <root level="info">
            <appender-ref ref="file-error"/>
            <appender-ref ref="file-info"/>
        </root>
    </springProfile>

完整配置

下面是總結(jié)上述所說葬馋,給出一個(gè)完整的logback-spring.xml配置。

<?xml version="1.0" encoding="UTF-8"?>
<configuration scan="true" scanPeriod="60 seconds" debug="false">

    <springProperty name="LOG_PATTERN" source="logging.pattern"
                    defaultValue="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger [%file:%line] - %msg%n"/>

    <appender name="console" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <charset>UTF-8</charset>
            <pattern>${LOG_PATTERN}</pattern>
        </encoder>
    </appender>

    <appender name="file-error" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
            <level>ERROR</level>
        </filter>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <FileNamePattern>${LOG_PATH:-.}/error.%d{yyyy-MM-dd}.%i.log</FileNamePattern>
            <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                <maxFileSize>100MB</maxFileSize>
            </timeBasedFileNamingAndTriggeringPolicy>
        </rollingPolicy>
        <encoder>
            <charset>UTF-8</charset>
            <pattern>${LOG_PATTERN}</pattern>
        </encoder>
    </appender>
    <appender name="file-info" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <level>ERROR</level>
            <onMatch>DENY</onMatch>
            <onMismatch>ACCEPT</onMismatch>
        </filter>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <FileNamePattern>${LOG_PATH:-.}/info.%d{yyyy-MM-dd}.%i.log</FileNamePattern>
            <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                <maxFileSize>100MB</maxFileSize>
            </timeBasedFileNamingAndTriggeringPolicy>
        </rollingPolicy>
        <encoder>
            <charset>UTF-8</charset>
            <pattern>${LOG_PATTERN}</pattern>
        </encoder>
    </appender>


    <springProfile name="default">
        <root level="info">
            <appender-ref ref="console"/>
        </root>
        <logger name="org.schhx.springbootlearn" level="debug"/>
    </springProfile>

    <springProfile name="dev,test,prod">
        <root level="info">
            <appender-ref ref="file-error"/>
            <appender-ref ref="file-info"/>
        </root>
    </springProfile>

</configuration>

完整示例

github

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末肾扰,一起剝皮案震驚了整個(gè)濱河市畴嘶,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌集晚,老刑警劉巖窗悯,帶你破解...
    沈念sama閱讀 221,576評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異偷拔,居然都是意外死亡蒋院,警方通過查閱死者的電腦和手機(jī)亏钩,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,515評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來欺旧,“玉大人姑丑,你說我怎么就攤上這事〈怯眩” “怎么了栅哀?”我有些...
    開封第一講書人閱讀 168,017評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)称龙。 經(jīng)常有香客問我留拾,道長(zhǎng),這世上最難降的妖魔是什么鲫尊? 我笑而不...
    開封第一講書人閱讀 59,626評(píng)論 1 296
  • 正文 為了忘掉前任间驮,我火速辦了婚禮,結(jié)果婚禮上马昨,老公的妹妹穿的比我還像新娘竞帽。我一直安慰自己,他們只是感情好鸿捧,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,625評(píng)論 6 397
  • 文/花漫 我一把揭開白布屹篓。 她就那樣靜靜地躺著,像睡著了一般匙奴。 火紅的嫁衣襯著肌膚如雪堆巧。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,255評(píng)論 1 308
  • 那天泼菌,我揣著相機(jī)與錄音谍肤,去河邊找鬼。 笑死哗伯,一個(gè)胖子當(dāng)著我的面吹牛荒揣,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播焊刹,決...
    沈念sama閱讀 40,825評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼系任,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了虐块?” 一聲冷哼從身側(cè)響起俩滥,我...
    開封第一講書人閱讀 39,729評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎贺奠,沒想到半個(gè)月后霜旧,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,271評(píng)論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡儡率,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,363評(píng)論 3 340
  • 正文 我和宋清朗相戀三年挂据,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了航背。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,498評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡棱貌,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出箕肃,到底是詐尸還是另有隱情婚脱,我是刑警寧澤,帶...
    沈念sama閱讀 36,183評(píng)論 5 350
  • 正文 年R本政府宣布勺像,位于F島的核電站障贸,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏吟宦。R本人自食惡果不足惜篮洁,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,867評(píng)論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望殃姓。 院中可真熱鬧袁波,春花似錦、人聲如沸蜗侈。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,338評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽踏幻。三九已至枷颊,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間该面,已是汗流浹背夭苗。 一陣腳步聲響...
    開封第一講書人閱讀 33,458評(píng)論 1 272
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留隔缀,地道東北人题造。 一個(gè)月前我還...
    沈念sama閱讀 48,906評(píng)論 3 376
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像猾瘸,于是被迫代替她去往敵國(guó)和親晌梨。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,507評(píng)論 2 359