将log4j消息从方法重定向到不同的日志文件

时间:2010-10-01 03:36:43

标签: java logging log4j

现在我使用log4j以其简单的香草/开箱即用的形式。我在类路径中有一个log4j.properties文件,并且在Web应用程序中散布着各种记录器消息。现在我有兴趣从包“xyz”中的方法“abc”重定向日志消息,转到特定的日志文件“pqr”。我不希望包xyz中的所有记录器消息都转到“pqr”,而只是来自包中的那个方法(“abc”)。

我如何实现这一目标?

TIA 博

2 个答案:

答案 0 :(得分:2)

这是我正在使用的配置文件。这会将一些特定消息发送到文件,将其他消息发送到控制台。这可能会对你有所帮助。 这用于独立的应用程序。

<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/" debug="false">
<!-- ============================== -->
<!-- Append SQL messages to a file. -->
<!-- ============================== -->
<appender name="SQL" class="org.apache.log4j.RollingFileAppender">
    <param name="Threshold" value="TRACE" />
    <param name="File" value="sql-statement.log" />
    <param name="Append" value="true" />
    <param name="MaxFileSize" value="5000KB" />
    <param name="MaxBackupIndex" value="100" />
    <layout class="org.apache.log4j.PatternLayout">
        <param name="ConversionPattern" value="%m%n" />
    </layout>
</appender>

<!-- ============================== -->
<!-- Append messages to the console -->
<!-- ============================== -->
<appender name="CONSOLE" class="org.apache.log4j.ConsoleAppender">
    <param name="Target" value="System.out" />
    <param name="Threshold" value="DEBUG" />
    <layout class="org.apache.log4j.PatternLayout">
        <param name="ConversionPattern" value="[%p] %m%n" />
    </layout>
</appender>

<!-- =============================== -->
<!-- Application specific categories -->
<!-- =============================== -->
<category name="com.edusoft.crashtest.qsbi">
    <priority value="DEBUG" />
    <appender-ref ref="CONSOLE" />
</category>
<category name="com.edusoft.crashtest.qsbi.printer" additivity="true">
    <priority value="TRACE" />
    <appender-ref ref="SQL" />
</category>

<!-- Setup the Root category -->
<root>
    <priority value="ERROR" />
</root>

答案 1 :(得分:0)

我不认为它可以那么精细。为什么不把这个方法拉到一个单独的类?