如何在log4j2中配置null appender

时间:2015-08-27 16:23:13

标签: java log4j log4j2 appender

Log4j 1. *有一个null appender class,但我找不到log4j中的等价物2.是否有一个?如何在log4j2.xml中配置null appender?

3 个答案:

答案 0 :(得分:4)

从Log4j2版本2.7开始有一个NullAppender类。早期的版本没有它。它在配置文件中使用的名称是“Null”。它可以像这样添加到Appenders列表中:

<Appenders>
  <Null name="arbritrary_name" />
</Appenders>

答案 1 :(得分:3)

使用CountingNoOp appender。

<Appenders>
  <CountingNoOp name="DEV_NULL" />
</Appenders>

答案 2 :(得分:2)

NullAppendar基本上是Appender界面的(几乎)empty implementation,使用AppenderSkeleton作为基类。在Log4j2中执行相同操作很简单,但是您需要一些样板代码才能使其工作,请参阅custom appenders上的Apache文档。

@Plugin(name = "NullAppender", category = "Core", elementType = "appender", printObject = true)
public class NullAppender extends AbstractAppender {

    private static final long serialVersionUID = -701612541126635333L;

    private NullAppender(String name, Filter filter, Layout<? extends Serializable> layout) {
        super(name, filter, layout);    
    }

    @Override
    public void append(LogEvent event) {
        // do exactly nothing
    }

    // blatantly stolen from the Apache doc, all errors (C) by me
    @PluginFactory
    public static NullAppender createAppender(@PluginAttribute("name") String name,
                                              @PluginElement("Layout") Layout layout,
                                              @PluginElement("Filters") Filter filter) {

        if (name == null) {
            LOGGER.error("No name provided for NullAppender");
            return null;
        }

        if (layout == null) {
            layout = PatternLayout.createDefaultLayout();
        }
        return new NullAppender(name, filter, layout);
    }

}