log4j2自定義appender及rollover原理簡(jiǎn)析

  1. 附上兩個(gè)appender配置:RollingRandomAccessFileAppender和自定義的LogStoreAppender
<appenders>
    <RollingRandomAccessFile name="UPDATE_FILE" immediateFlush="true"
                             fileName="${LOG_HOME}/update.log"
                             filePattern="${LOG_HOME}/update.log.%d{yyyy-MM-dd}">
      <PatternLayout>
        <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %class{36} %L %M - %msg%xEx%n</pattern>
      </PatternLayout>
      <Policies>
        <TimeBasedTriggeringPolicy/>
      </Policies>
    </RollingRandomAccessFile>

    <LogStoreAppender name="ARTS_FILE" immediateFlush="true"
                             fileName="${LOG_HOME}/arts.log"
                             filePattern="${LOG_HOME}/arts.log.%d{yyyy-MM-dd}">
      <PatternLayout>
        <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %class{36} %L %M - %msg%xEx%n</pattern>
      </PatternLayout>
      <Policies>
        <TimeBasedTriggeringPolicy/>
      </Policies>
    </LogStoreAppender>
  </appenders>
  1. 自定義appender方式
    log4j2自定義appener可以直接類似RollingRandomAccessFileAppender,去 extends AbstractOutputStreamAppender<RollingRandomAccessFileManager>
    然后只需要在start()和append()中實(shí)現(xiàn)自己的邏輯。
  2. rollover源碼
    注意下面RollingRandomAccessFileAppender類中的append()中調(diào)用manager.checkRollover(event);去主動(dòng)check是否需要rollover


    image.png

    image.png

    我們使用的是TimeBasedTriggeringPolicy


    image.png
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容