bin*_*lon 13 java logging log4j
是否可以在运行时检索log4j中配置的所有appender的列表?
我会更多地充实这个场景.鉴于以下配置,我将如何检索所有appender(stdout和altstdout)?
log4j.rootLogger=error, stdout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.altstdout=org.apache.log4j.ConsoleAppender
log4j.appender.altstdout.layout=org.apache.log4j.PatternLayout
# Pattern to output the caller's file name and line number.
log4j.appender.stdout.layout.ConversionPattern=%5p [%t] (%F:%L) - %m%n
log4j.appender.altstdout.layout.ConversionPattern=%5p [%t] (%F:%L) - %m%n
Run Code Online (Sandbox Code Playgroud)
And*_*390 15
如果要访问为所有记录器配置的所有appender,则必须执行以下操作
for (Enumeration loggers=LogManager.getCurrentLoggers(); loggers.hasMoreElements(); ) {
Logger logger = (Logger) loggers.nextElement();
for (Enumeration appenders=logger.getAllAppenders(); appenders.hasMoreElements(); ) {
Appender appender = (Appender) appenders.nextElement();
...
Run Code Online (Sandbox Code Playgroud)
我不知道为什么log4j没有像LogManager.getAllAppenders()那样的方法,但它看起来很
不利.
| 归档时间: |
|
| 查看次数: |
14175 次 |
| 最近记录: |