java appender_java – 如何在log4j中创建自己的Appender?

您应该扩展AppenderSkeleton类,(引用javadoc)“提供了常用功能的代码,例如支持阈值过滤和支持一般过滤器。

如果你读了AppenderSkeleton的代码,你会看到它处理几乎所有的,只留下你:

> protected void append(LoggingEvent event)

> public void close()

> public boolean requiresLayout()

核心方法是追加。记住,你不需要在其中实现过滤逻辑,因为它已经实现在doAppend,反过来调用append。

这里我做了一个(相当无用的)类,将日志条目存储在ArrayList中,就像演示一样。

public /*static*/ class MyAppender extends AppenderSkeleton {

ArrayList eventsList = new ArrayList();

@Override

protected void append(LoggingEvent event) {

eventsList.add(event);

}

public void close() {

}

public boolean requiresLayout() {

return false;

}

}

好吧,让我们来测试一下:

public static void main (String [] args) {

Logger l = Logger.getLogger("test");

MyAppender app = new MyAppender();

l.addAppender(app);

l.warn("first");

l.warn("second");

l.warn("third");

l.trace("fourth shouldn't be printed");

for (LoggingEvent le: app.eventsList) {

System.out.println("***" + le.getMessage());

}

}

你应该有“第一”,“第二”,“第三”印刷;不应该打印第四条消息,因为根记录器的日志级别是调试,而事件级别是跟踪。这证明了AbstractSkeleton为我们正确实现了“级别管理”。所以这绝对是似乎要走的路…现在的问题:为什么你需要一个自定义appender,而有很多内置的日志几乎任何目的地? (btw一个好的地方开始与log4j:http://logging.apache.org/log4j/1.2/manual.html)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值