可以使用不同的log4j附加目的地的不同的方法?(Possible to use different

2019-09-30 07:35发布

我有一个log4j的配置文件,它使用与特定的布局是ConsoleAppender。

我用logger.info(“一些文字”); 在我的Java代码的几个地方。

是否有可能创造另一个附加目的地的配置文件在不同的布局,并使用特定的附加目的地,无论我在代码中选择呢?

Answer 1:

是否有可能创造另一个附加目的地的配置文件在不同的布局,并使用特定的附加目的地,无论我在代码中选择呢?

是的,你可以用不同的布局创造出不同的appender和创建不同的类别为每个附加目的地。

使用类别名称来获得日志,而不是附加目的地名称。


示例:( 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


文章来源: Possible to use different log4j appenders for different methods?
标签: java log4j