簡體   English   中英

可以對不同的方法使用不同的log4j追加器嗎?

[英]Possible to use different log4j appenders for different methods?

我有一個log4j配置文件,它使用具有特定布局的ConsoleAppender。

我使用logger.info(“ some text”); 在我的Java代碼中的幾個地方。

是否可以在配置文件中創建其他布局不同的附加程序,並在代碼中的任意位置使用特定的附加程序?

是否可以在配置文件中創建其他布局不同的附加程序,並在代碼中的任意位置使用特定的附加程序?

是的,您可以創建具有不同布局的其他附加程序,並為每個附加程序創建不同的類別。

使用類別名稱而不是附加名稱來獲取記錄器。


示例:( log4j.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">

<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">

    <appender name="stdout1" class="org.apache.log4j.ConsoleAppender">
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="[%.4t] %-5p %c{1} - %m%n" />
        </layout>
    </appender>

    <appender name="stdout2" class="org.apache.log4j.ConsoleAppender">
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="%d [%.4t] %-5p %c{1} - %m%n" />
        </layout>
    </appender>

    <category name="category1">
        <priority value="INFO" />
        <appender-ref ref="stdout1" />
    </category>

    <category name="category2">
        <priority value="DEBUG" />
        <appender-ref ref="stdout2" />
    </category>

</log4j:configuration>

Java代碼:( 根據類別名稱獲取記錄器

org.apache.log4j.Logger.getLogger("category1").warn("debug msg for stdout1 appender");
org.apache.log4j.Logger.getLogger("category2").info("info msg for stdout2 appender");

輸出:

[main] WARN  category1 - warn msg for stdout1 appender
2014-05-09 02:46:29,216 [main] INFO  category2 - info msg for stdout2 appender

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM