为什么ConsoleAppender会为名为[null]的appender抛出“没有输出流或文件集”?

时间:2011-05-30 10:13:58

标签: java log4j consoleappender

我遇到了log4j ConsoleAppender

的问题

如果我像这样初始化它:

ConsoleAppender ca = new ConsoleAppender();
ca.setLayout(new PatternLayout(PatternLayout.TTCC_CONVERSION_PATTERN));

它会出错并中断记录。

错误输出:

  

log4j:ERROR没有名为[null]的appender的输出流或文件集。

如果我像这样初始化它可以正常工作:

ConsoleAppender ca = new ConsoleAppender(new PatternLayout(PatternLayout.TTCC_CONVERSION_PATTERN));

有没有人遇到过这个问题?我无法在Bugzilla存储库中找到它,但如果它实际上是一个问题,那将是非常明显的!

也许我是looking in the wrong place?

相关代码:

import org.apache.log4j.*;

public class ConsoleAppenderIssue {
private static Logger logger = Logger.getLogger(ConsoleAppenderIssue.class);

public static void main(String [] args) {
    ConsoleAppender ca = new ConsoleAppender();
    ca.setLayout(new PatternLayout(PatternLayout.TTCC_CONVERSION_PATTERN));

    logger.addAppender(ca);

    logger.info("log something");

}

}

1 个答案:

答案 0 :(得分:16)

如果你为ConsoleAppender look at the source

,你可以看到为什么会这样
  public ConsoleAppender(Layout layout) {
    this(layout, SYSTEM_OUT);
  }

  public ConsoleAppender(Layout layout, String target) {
    setLayout(layout);
    setTarget(target);
    activateOptions();
  }

您可以看到ConsoleAppender(Layout)传递SYSTEM_OUT作为目标,并且在设置布局和目标后也会调用activateOptions

如果您自己使用setLayout,那么您还需要明确设置目标并致电activateOptions