logback配置說明

1、配置示例與說明安全

<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="false">
  <!--定義日誌文件的存儲地址 勿在 LogBack 的配置中使用相對路徑-->
  <property name="LOG_HOME" value="/home" />
  <!-- 控制檯輸出 -->
  <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
    <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
    <!--格式化輸出:%d表示日期,%thread表示線程名,%-5level:級別從左顯示5個字符寬度%msg:日誌消息,%n是換行符-->
      <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
    </encoder>
  </appender>
  <!-- 按照天天生成日誌文件 -->
  <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
    <!--日誌文件輸出的文件名-->
      <FileNamePattern>${LOG_HOME}/TestWeb.log.%d{yyyy-MM-dd}.log</FileNamePattern>
      <!--日誌文件保留天數-->
      <MaxHistory>30</MaxHistory>
    </rollingPolicy>
    <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
      <!--格式化輸出:%d表示日期,%thread表示線程名,%-5level:級別從左顯示5個字符寬度%msg:日誌消息,%n是換行符-->
      <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
    </encoder>
    <!--日誌文件最大的大小-->
    <triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy">
      <MaxFileSize>10MB</MaxFileSize>
    </triggeringPolicy>
  </appender>

  <!-- 日誌輸出級別 -->
  <root level="INFO">
    <appender-ref ref="STDOUT" />
  </root>
</configuration>

 

2、配置說明app

一、子節點<appender>spa

負責寫日誌的組件,它有兩個必要屬性name和class。name指定appender名稱,class指定appender的全限定名線程

1)ConsoleAppender 把日誌輸出到控制檯,有如下子節點:
 <encoder>:對日誌進行格式化。(具體參數稍後講解 )
 <target>:字符串System.out(默認)或者System.err(區別很少說了)debug

2)FileAppender:把日誌添加到文件,有如下子節點:
 <file>:被寫入的文件名,能夠是相對目錄,也能夠是絕對目錄,若是上級目錄不存在會自動建立,沒有默認值。
 <append>:若是是 true,日誌被追加到文件結尾,若是是 false,清空現存文件,默認是true。
 <encoder>:對記錄事件進行格式化。(具體參數稍後講解 )
 <prudent>:若是是 true,日誌會被安全的寫入文件,即便其餘的FileAppender也在向此文件作寫入操做,效率低,默認是 false。日誌

3)RollingFileAppender:滾動記錄文件,先將日誌記錄到指定文件,當符合某個條件時,將日誌記錄到其餘文件code

還有SocketAppender、SMTPAppender、DBAppender、SyslogAppender、SiftingAppender,並不經常使用,這裏就不詳解了xml

二、子節點<loger>blog

用來設置某一個包或具體的某一個類的日誌打印級別、以及指定<appender>。<loger>僅有一個name屬性,一個可選的level和一個可選的addtivity屬性。
能夠包含零個或多個<appender-ref>元素,標識這個appender將會添加到這個loger事件

三、子節點<root>

它也是<loger>元素,可是它是根loger,是全部<loger>的上級。只有一個level屬性,由於name已經被命名爲"root",且已是最上級了。level: 用來設置打印級別,大小寫無關:TRACE, DEBUG, INFO, WARN, ERROR, ALL和OFF,不能設置爲INHERITED或者同義詞NULL。 默認是DEBUG。

相關文章
相關標籤/搜索