這篇文章主要介紹了Spring Boot Logback配置日志過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
創(chuàng)新互聯(lián)長期為成百上千客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對不同對象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺,與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為上海企業(yè)提供專業(yè)的成都網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè),上海網(wǎng)站改版等技術(shù)服務(wù)。擁有10年豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開發(fā)。
出于性能等原因,Logback 目前是springboot應(yīng)用日志的標(biāo)配; 當(dāng)然有時(shí)候在生產(chǎn)環(huán)境中也會考慮和三方中間件采用統(tǒng)一處理方式。
配置時(shí)考慮點(diǎn)
實(shí)現(xiàn)范例
如下兩個(gè)例子基本包含了上述的考慮點(diǎn):
綜合范例
application.yml
logging: level: root: debug path: C:/data/logs/springboot-logback-demo server: port: 8080 spring: application: name: springboot-logback-demo debug: false
Spring-logback.xml
<?xml version="1.0" encoding="UTF-8"?> <configuration> <!-- 日志根目錄--> <springProperty scope="context" name="LOG_HOME" source="logging.path" defaultValue="/data/logs/springboot-logback-demo"/> <!-- 日志級別 --> <springProperty scope="context" name="LOG_ROOT_LEVEL" source="logging.level.root" defaultValue="DEBUG"/> <!-- 標(biāo)識這個(gè)"STDOUT" 將會添加到這個(gè)logger --> <springProperty scope="context" name="STDOUT" source="log.stdout" defaultValue="STDOUT"/> <!-- 日志文件名稱--> <property name="LOG_PREFIX" value="spring-boot-logback" /> <!-- 日志文件編碼--> <property name="LOG_CHARSET" value="UTF-8" /> <!-- 日志文件路徑+日期--> <property name="LOG_DIR" value="${LOG_HOME}/%d{yyyyMMdd}" /> <!--對日志進(jìn)行格式化--> <property name="LOG_MSG" value="- | [%X{requestUUID}] | [%d{yyyyMMdd HH:mm:ss.SSS}] | [%level] | [${HOSTNAME}] | [%thread] | [%logger{36}] | --> %msg|%n "/> <!--文件大小,默認(rèn)10MB--> <property name="MAX_FILE_SIZE" value="50MB" /> <!-- 配置日志的滾動時(shí)間 ,表示只保留最近 10 天的日志--> <property name="MAX_HISTORY" value="10"/> <!--輸出到控制臺--> <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender"> <!-- 輸出的日志內(nèi)容格式化--> <layout class="ch.qos.logback.classic.PatternLayout"> <pattern>${LOG_MSG}</pattern> </layout> </appender> <!--輸出到文件--> <appender name="0" class="ch.qos.logback.core.rolling.RollingFileAppender"> </appender> <!-- 定義 ALL 日志的輸出方式:--> <appender name="FILE_ALL" class="ch.qos.logback.core.rolling.RollingFileAppender"> <!--日志文件路徑,日志文件名稱--> <File>${LOG_HOME}/all_${LOG_PREFIX}.log</File> <!-- 設(shè)置滾動策略,當(dāng)天的日志大小超過 ${MAX_FILE_SIZE} 文件大小時(shí)候,新的內(nèi)容寫入新的文件, 默認(rèn)10MB --> <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> <!--日志文件路徑,新的 ALL 日志文件名稱,“ i ” 是個(gè)變量 --> <FileNamePattern>${LOG_DIR}/all_${LOG_PREFIX}%i.log</FileNamePattern> <!-- 配置日志的滾動時(shí)間 ,表示只保留最近 10 天的日志--> <MaxHistory>${MAX_HISTORY}</MaxHistory> <!--當(dāng)天的日志大小超過 ${MAX_FILE_SIZE} 文件大小時(shí)候,新的內(nèi)容寫入新的文件, 默認(rèn)10MB--> <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP"> <maxFileSize>${MAX_FILE_SIZE}</maxFileSize> </timeBasedFileNamingAndTriggeringPolicy> </rollingPolicy> <!-- 輸出的日志內(nèi)容格式化--> <layout class="ch.qos.logback.classic.PatternLayout"> <pattern>${LOG_MSG}</pattern> </layout> </appender> <!-- 定義 ERROR 日志的輸出方式:--> <appender name="FILE_ERROR" class="ch.qos.logback.core.rolling.RollingFileAppender"> <!-- 下面為配置只輸出error級別的日志 --> <filter class="ch.qos.logback.classic.filter.LevelFilter"> <level>ERROR</level> <OnMismatch>DENY</OnMismatch> <OnMatch>ACCEPT</OnMatch> </filter> <!--日志文件路徑,日志文件名稱--> <File>${LOG_HOME}/err_${LOG_PREFIX}.log</File> <!-- 設(shè)置滾動策略,當(dāng)天的日志大小超過 ${MAX_FILE_SIZE} 文件大小時(shí)候,新的內(nèi)容寫入新的文件, 默認(rèn)10MB --> <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> <!--日志文件路徑,新的 ERR 日志文件名稱,“ i ” 是個(gè)變量 --> <FileNamePattern>${LOG_DIR}/err_${LOG_PREFIX}%i.log</FileNamePattern> <!-- 配置日志的滾動時(shí)間 ,表示只保留最近 10 天的日志--> <MaxHistory>${MAX_HISTORY}</MaxHistory> <!--當(dāng)天的日志大小超過 ${MAX_FILE_SIZE} 文件大小時(shí)候,新的內(nèi)容寫入新的文件, 默認(rèn)10MB--> <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP"> <maxFileSize>${MAX_FILE_SIZE}</maxFileSize> </timeBasedFileNamingAndTriggeringPolicy> </rollingPolicy> <!-- 輸出的日志內(nèi)容格式化--> <layout class="ch.qos.logback.classic.PatternLayout"> <Pattern>${LOG_MSG}</Pattern> </layout> </appender> <!-- additivity 設(shè)為false,則logger內(nèi)容不附加至root ,配置以配置包下的所有類的日志的打印,級別是 ERROR--> <logger name="org.springframework" level="ERROR" /> <logger name="org.apache.commons" level="ERROR" /> <logger name="org.apache.zookeeper" level="ERROR" /> <logger name="com.alibaba.dubbo.monitor" level="ERROR"/> <logger name="com.alibaba.dubbo.remoting" level="ERROR" /> <!-- ${LOG_ROOT_LEVEL} 日志級別 --> <root level="${LOG_ROOT_LEVEL}"> <!-- 標(biāo)識這個(gè)"${STDOUT}"將會添加到這個(gè)logger --> <appender-ref ref="${STDOUT}"/> <!-- FILE_ALL 日志輸出添加到 logger --> <appender-ref ref="FILE_ALL"/> <!-- FILE_ERROR 日志輸出添加到 logger --> <appender-ref ref="FILE_ERROR"/> </root> </configuration>
Profile 相關(guān)的配置可以參考:
<?xml version="1.0" encoding="UTF-8"?> <configuration> <include resource="org/springframework/boot/logging/logback/base.xml" /> <!-- roll by day --> <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender"> <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> <fileNamePattern>logs/springboot-logback-demo.%d{yyyy-MM-dd}.log</fileNamePattern> <maxHistory>30</maxHistory> </rollingPolicy> <encoder> <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{35} - %msg%n</pattern> </encoder> </appender> <!-- dev --> <logger name="org.springframework.web" level="INFO"/> <root level="INFO"> <appender-ref ref="FILE" /> </root> <!-- test or production --> <springProfile name="test,prod"> <logger name="org.springframework.web" level="INFO"/> <logger name="com.pdai.springboot" level="INFO"/> <root level="INFO"> <appender-ref ref="FILE" /> </root> </springProfile> </configuration>
參考文檔
Logback官網(wǎng)
https://logback.qos.ch/manual/layouts.html#conversionWord
Logback官網(wǎng) 文檔
https://logback.qos.ch/manual/index.html
Logback中Encoder Pattern
<encoder> <pattern>%d{HH:mm:ss} [%thread][%X{traceId}] %-5level %logger{36} - %msg%n</pattern> </encoder>
https://logback.qos.ch/manual/layouts.html#conversionWord
代碼示例
@See https://github.com/realpdai/springboot-logback-demo
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。
當(dāng)前標(biāo)題:SpringBootLogback配置日志過程解析
文章URL:http://www.rwnh.cn/article40/gposho.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站營銷、響應(yīng)式網(wǎng)站、商城網(wǎng)站、網(wǎng)站策劃、網(wǎng)站排名、自適應(yīng)網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)