Log4J2 配置文件模板及代碼說明


Log4j是Apache的著名項目,隨着Java應用的越來越廣泛,對日志性能等方面的要求也越來越高。Log4j的升級版本Log4j2在前些年發布。Log4J2的優點和好處有很多,可以自行搜索查閱相關文檔,這里提供一個配置好的模板文件,以供參考:

=========================第一版=========================

<?xml version="1.0" encoding="UTF-8"?>

<!--
    status : 這個用於設置log4j2自身內部的信息輸出,可以不設置,當設置成trace時,會看到log4j2內部各種詳細輸出
    monitorInterval : Log4j能夠自動檢測修改配置文件和重新配置本身, 設置間隔秒數。此處表示每隔600秒重讀一次配置文件
-->
<Configuration status="OFF" monitorInterval="600">

    <!--日志級別:TRACE < DEBUG < INFO < WARN < ERROR < FATAL-->
    <!--如果設置為WARN,則低於WARN的信息都不會輸出-->
    <Properties>
        <!-- 配置日志文件輸出目錄,此處為項目根目錄下的logs文件夾 -->
        <Property name="LOG_HOME">logs</Property>
        <property name="FILE_NAME">cnblogs</property>
    </Properties>

    <Appenders>
        <!--這個輸出控制台的配置-->
        <Console name="Console" target="SYSTEM_OUT">
            <!--控制台只輸出level及其以上級別的信息(onMatch),其他的直接拒絕(onMismatch)-->
            <ThresholdFilter level="ERROR" onMatch="ACCEPT" onMismatch="DENY"/>
            <!--日志輸出的格式-->
            <!--
                %d{yyyy-MM-dd HH:mm:ss, SSS} : 日志生產時間,輸出到毫秒的時間
                %-5level : 輸出日志級別,-5表示左對齊並且固定輸出5個字符,如果不足在右邊補0
                %c : logger的名稱(%logger)
                %t : 輸出當前線程名稱
                %p : 日志輸出格式
                %m : 日志內容,即 logger.info("message")
                %n : 換行符
                %C : Java類名(%F)
                %L : 行號
                %M : 方法名
                %l : 輸出語句所在的行數, 包括類名、方法名、文件名、行數
                hostName : 本地機器名
                hostAddress : 本地ip地址
             -->
            <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/>
        </Console>

        <!--
            循環日志文件:日志文件大於閥值的時候,就開始寫一個新的日志文件
            這個會打印出所有的信息,每次大小超過size,則這size大小的日志會自動存入按年份-月份建立的文件夾下面並進行壓縮,作為存檔

            fileName    : 指定當前日志文件的位置和文件名稱
            filePattern : 指定當發生Rolling時,文件的轉移和重命名規則
            SizeBasedTriggeringPolicy : 指定當文件體積大於size指定的值時,觸發Rolling
            DefaultRolloverStrategy : 指定最多保存的文件個數
            TimeBasedTriggeringPolicy : 這個配置需要和filePattern結合使用
                注意filePattern中配置的文件重命名規則是${FILE_NAME}_%d{yyyy-MM-dd}_%i,最小的時間粒度是dd,即天,
                TimeBasedTriggeringPolicy指定的size是1,結合起來就是每1天生成一個新文件
        -->

        <RollingRandomAccessFile name="INFO" fileName="logs/${FILE_NAME}.log" filePattern="log/${FILE_NAME}_%d{yyyy-MM-dd}_%i.log.gz">
            <Filters>
                <ThresholdFilter level="WARN" onMatch="DENY" onMismatch="NEUTRAL"/>
                <ThresholdFilter level="TRACE" onMatch="ACCEPT" onMismatch="DENY"/>
            </Filters>
            <PatternLayout pattern="%d{yyyy-MM-dd 'at' HH:mm:ss z} %-5level %class{36} %L %M - %msg%xEx%n"/>
            <Policies>
                <TimeBasedTriggeringPolicy interval="1"/>
                <SizeBasedTriggeringPolicy size="1MB"/>
            </Policies>
            <DefaultRolloverStrategy max="20"/>
        </RollingRandomAccessFile>

        <!--錯誤信息記錄-->
        <RollingRandomAccessFile name="ERROR" fileName="logs/${FILE_NAME}-ERROR.log" filePattern="log/${FILE_NAME}-ERROR_%d{yyyy-MM-dd}_%i.log.gz">
            <Filters>
                <ThresholdFilter level="FATAL" onMatch="DENY" onMismatch="NEUTRAL"/>
                <ThresholdFilter level="WARN" onMatch="ACCEPT" onMismatch="DENY"/>
            </Filters>
            <PatternLayout pattern="%d{yyyy-MM-dd 'at' HH:mm:ss z} %-5level %class{36} %L %M - %msg%xEx%n"/>
            <Policies>
                <TimeBasedTriggeringPolicy interval="1"/>
                <SizeBasedTriggeringPolicy size="1MB"/>
            </Policies>
            <DefaultRolloverStrategy max="20"/>
        </RollingRandomAccessFile>

        <!--系統級別的錯誤信息-->
        <RollingRandomAccessFile name="FATAL" fileName="logs/${FILE_NAME}-FATAL.log" filePattern="log/${FILE_NAME}-FATAL%d{yyyy-MM-dd}_%i.log.gz">
            <Filters>
                <ThresholdFilter level="FATAL" onMatch="ACCEPT" onMismatch="DENY"/>
            </Filters>
            <PatternLayout pattern="%d{yyyy-MM-dd 'at' HH:mm:ss z} %-5level %class{36} %L %M - %msg%xEx%n"/>
            <Policies>
                <TimeBasedTriggeringPolicy interval="1"/>
                <SizeBasedTriggeringPolicy size="1MB"/>
            </Policies>
            <DefaultRolloverStrategy max="20"/>
        </RollingRandomAccessFile>

        <!--全部日志信息:DEBUG及以上級別-->
        <RollingRandomAccessFile name="ALL" fileName="logs/${FILE_NAME}-ALL.log" filePattern="log/${FILE_NAME}-ALL%d{yyyy-MM-dd}_%i.log.gz">
            <Filters>
                <ThresholdFilter level="DEBUG" onMatch="ACCEPT" onMismatch="DENY"/>
            </Filters>
            <PatternLayout pattern="%d{yyyy-MM-dd 'at' HH:mm:ss z} %-5level %class{36} %L %M - %msg%xEx%n"/>
            <Policies>
                <TimeBasedTriggeringPolicy interval="1"/>
                <SizeBasedTriggeringPolicy size="10MB"/>
            </Policies>
            <DefaultRolloverStrategy max="20"/>
        </RollingRandomAccessFile>

        <!--配置異步寫日志-->
        <Async name="Async">
            <AppenderRef ref="ALL"/>
        </Async>

        <!--輸出到MongoDB中-->
        <NoSql name="databaseAppender">
            <MongoDb databaseName="test" collectionName="errorlog" server="localhost" port="27017" />
        </NoSql>
    </Appenders>

    <!--然后定義logger,只有定義了logger並引入的appender,appender才會生效-->
    <Loggers>
        <!--監控系統信息-->
        <Logger name="org.springframework" level="info" additivity="false">
            <AppenderRef ref="Console"/>
        </Logger>

        <!--輸出到NoSQL中-->
        <Logger name="mongoLog" level="trace" additivity="false">
            <AppenderRef ref="databaseAppender" />
        </Logger>

        <Root level="debug">
            <!-- 這兒為trace表示什么都可以打印出來了,其他幾個級別分別為:TRACE、DEBUG、INFO、WARN、ERROR和FATAL -->
            <Appender-Ref ref="Console"/>
            <Appender-Ref ref="INFO"/>
            <Appender-Ref ref="ERROR"/>
            <Appender-Ref ref="FATAL"/>
        </Root>
    </Loggers>

</Configuration>

=========================TODO=========================


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM