0

是否可以确定附加程序是否被禁用(即<level value="Off">)?

我想要一个全局标志来确定我的附加程序是否已启用:

public static bool isAppenderEnabled = /*...*/;

如果启用了附加程序,那么我将记录以下内容:

if(isAppenderEnabled)
{
    MyAppender.Warn("****************************************");
    MyAppender.Warn("Warning title!");
    MyAppender.Warn(String.Format("Some warning message! A:{0}, B:{1}, C:{2}, D:{3}", 0, 1, 2, 3));
    MyAppender.Warn("****************************************");
}

拥有isAppenderEnabled标志很重要,因为当附加程序被禁用时,我会节省大量的 CPU 时间,因为我没有构建所有这些字符串。检查附加程序是否关闭的最佳/最简单方法是什么?

PS我试过了MyAppender.Logger.IsEnabledFor(log4net.Core.Level.Off);,但是,如果我将日志级别设置为Warn它总是返回true Off(基本上,它总是说记录器被禁用),所以这不起作用。

4

2 回答 2

1

推荐的做法是,不是有一个全局标志来说明是否启用了日志记录,而是测试每个调用的实际日志记录级别,例如

if (MyAppender.IsWarnEnabled)
{
    MyAppender.Warn(String.Format("Some warning message! A:{0}, B:{1}, C:{2}, D:{3}", 0, 1, 2, 3));
}

...

if (MyAppender.IsDebugEnabled)
{
    MyAppender.Debug(String.Format("Some debug info! A:{0}, B:{1}, C:{2}, D:{3}", 0, 1, 2, 3));
}

...

if (MyAppender.IsErrorsEnabled)
{
    MyAppender.Error(String.Format("Some error message! A:{0}, B:{1}, C:{2}, D:{3}", 0, 1, 2, 3));
}

此方法的优点是您可以将日志设置并保留为 Level.Error 或 Level.Fatal,而无需在警告/调试和信息消息中构造所有字符串。

话虽如此,这是您的选择。要回答您的问题,原因MyAppender.Logger.IsEnabledFor(log4net.Core.Level.Off); 不起作用,如果级别设置为 x或更高, MyAppender.Logger.IsEnabledFor(x) 将返回 true 。因此,我希望这个调用总是返回 true。

下一个级别是(AFAIK) log4net.Core.Level.Emergency ,因此可以检查,但由于该级别不常用,您也可以检查log4net.Core.Level.Fatal

MyAppender.IsFatalEnabled只是一个属性包装器MyAppender.Logger.IsEnabledFor(log4net.Core.Level.Fatal)

于 2012-09-06T10:24:39.820 回答
0

根据我对 log4net 所基于的 log4j 的理解,您可以通过调用来检查 LOGGER 是否配置为您感兴趣的级别:

logger.isEnabledFor(Priority.WARN)  // or whatever log priority you want

没有任何东西可以告诉您是否启用了附加程序。但是,您可以检查是否将给定的命名附加程序分配给您的记录器。你会检查:

if(logger.getAppender("MyAppender") == null)
于 2012-09-05T20:36:11.293 回答