基于SpringBoot的Logback日志輪轉(zhuǎn)配置詳解

在生產(chǎn)環(huán)境下,日志是最好的問(wèn)題調(diào)試和跟蹤方法,因此日志的地位是十分重要的。我們平時(shí)經(jīng)常使用的log4j,slf4j,logback等等,他們的配置上大同小異。這里就結(jié)合Spring Boot配置一下Logback的日志。

成都創(chuàng)新互聯(lián)公司是專業(yè)的大同網(wǎng)站建設(shè)公司,大同接單;提供網(wǎng)站制作、成都做網(wǎng)站,網(wǎng)頁(yè)設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行大同網(wǎng)站開發(fā)網(wǎng)頁(yè)制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來(lái)合作!

默認(rèn)最簡(jiǎn)單的配置

默認(rèn)情況下,如果對(duì)日志沒有特殊處理,可以直接基于application.properties進(jìn)行配置。

常用的參數(shù)有:

logging.level

配置日志的級(jí)別

logging.file
logging.path

這兩個(gè)參數(shù)只能配置一個(gè)生效,一個(gè)是文件(可以有絕對(duì)路徑或者相對(duì)路徑);另一個(gè)是路徑,文件的名稱會(huì)默認(rèn)為spring.log

日志默認(rèn)按照大小進(jìn)行切分,由于我這邊沒有產(chǎn)生那么大的文件,因此沒有做實(shí)驗(yàn)。

這種方法最簡(jiǎn)單,但是不能處理那種復(fù)雜的日志輪轉(zhuǎn)的機(jī)制。比如沒天一個(gè)文件這種需求,因此可以考慮使用獨(dú)立的日志文件進(jìn)行配置:

使用獨(dú)立的配置文件配置

如果有復(fù)雜的需求,可以像其他普通的web應(yīng)用一樣,配置獨(dú)立的logback.xml:

首先注意的是這個(gè)文件必須放在resources目錄下(我這邊發(fā)現(xiàn),如果通過(guò)logging.config指向另一個(gè)目錄下的logback.xml會(huì)在程序啟動(dòng)時(shí)報(bào)錯(cuò),報(bào)無(wú)法解析該xml。猜想可能是在其他目錄下的xml都被當(dāng)做spring的配置或者有xml schema信息的配置,單純的logback.xml它不認(rèn)識(shí))

基于Spring Boot的Logback日志輪轉(zhuǎn)配置詳解

然后在application.properties文件中加入:

# 配置logback
logging.config=classpath:logback-spring.xml

即可。

注意如果是logging.config=classpath:xxxx/logback-spring.xml,就不行了哈!我試過(guò)好多次!

配置的內(nèi)容基本可以參考下面的來(lái):

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
  <!-- 屬性文件 -->
  <property name="processName" value="xxx"/>
  <property name="logDir" value="/opt/logs/xxx"/>

  <!-- 默認(rèn)的控制臺(tái)日志輸出,一般生產(chǎn)環(huán)境都是后臺(tái)啟動(dòng),這個(gè)沒太大作用 -->
  <appender name="stdout" class="ch.qos.logback.core.ConsoleAppender">
    <!--<Encoding>UTF-8</Encoding>-->
    <layout class="ch.qos.logback.classic.PatternLayout">
      <pattern>%date [%thread] %-5level %logger{50}:%L - %msg%n</pattern>
    </layout>
  </appender>

  <!-- 配置文件輪轉(zhuǎn) -->
  <appender name="logfile" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <!--<Encoding>UTF-8</Encoding>-->
    <File>${logDir}/service.log</File>
    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
      <FileNamePattern>${logDir}/history/service.%d{yyyy-MM-dd}.log.gz</FileNamePattern>
      <maxHistory>30</maxHistory>
    </rollingPolicy>
    <layout class="ch.qos.logback.classic.PatternLayout">
      <pattern>%date [%thread] %-5level %logger{50}:%L - %msg%n</pattern>
    </layout>
  </appender>


  <!-- 修改其他包的日志輸出級(jí)別 -->
  <logger name="org.apache.zookeeper">
    <level value="WARN"/>
  </logger>

  <!-- root 默認(rèn)日志配置 , 注意這里的級(jí)別哈!小心生產(chǎn)環(huán)境用DEBUG,壓爆你的磁盤!-->
  <root level="INFO">
    <appender-ref ref="logfile"/>
    <appender-ref ref="stdout"/>
  </root>
</configuration>

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。

名稱欄目:基于SpringBoot的Logback日志輪轉(zhuǎn)配置詳解
地址分享:http://bm7419.com/article20/jdejco.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供云服務(wù)器、網(wǎng)站導(dǎo)航外貿(mào)網(wǎng)站建設(shè)、手機(jī)網(wǎng)站建設(shè)微信小程序、ChatGPT

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

手機(jī)網(wǎng)站建設(shè)