本文介绍了可以对不同的方法使用不同的log4j追加器吗?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我有一个log4j配置文件,它使用具有特定布局的ConsoleAppender.
I have a log4j configuration file and it uses a ConsoleAppender with a specific layout.
我用 logger.info(某些文本");在我的Java代码中的几个地方.
I use logger.info("some text"); in several places in my java code.
是否可以在配置文件中创建其他布局不同的附加程序,并在代码中选择的任意位置使用特定的附加程序?
Is it possible to create another appender with a different layout in the configuration file and use the specific appender wherever I choose in the code?
推荐答案
是的,您可以创建具有不同布局的其他附加程序,并为每个附加程序创建不同的类别.
Yes you can create different appender with a different layout and create different categories for each appender.
使用类别名称而不是附加名称来获取记录器.
示例:(log4j.xml
)
Sample: (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
这篇关于可以对不同的方法使用不同的log4j追加器吗?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!