现在我使用log4j以其简单的香草/开箱即用的形式。我在类路径中有一个log4j.properties文件,并且在Web应用程序中散布着各种记录器消息。现在我有兴趣从包“xyz”中的方法“abc”重定向日志消息,转到特定的日志文件“pqr”。我不希望包xyz中的所有记录器消息都转到“pqr”,而只是来自包中的那个方法(“abc”)。
我如何实现这一目标?
TIA 博
答案 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)
我不认为它可以那么精细。为什么不把这个方法拉到一个单独的类?