我使用Log4Net作为我们应用程序的日志记录机制.我们的配置包含在配置文件中,在我们的代码中,我们以编程方式调用我们要调用的几个记录器(主要使用FileAppenders)中的哪一个.最近我意识到我们的一个日志文件没有被填充,我跟踪它的字符串不匹配,在我们的配置文件中的名称和我们在代码中以编程方式调用的名称之间.因为LogManager找不到指定的记录器,所以返回了root,这对于我们的配置而言没有设置为有意义地记录在任何地方.
我的问题是,有没有办法设置log4net以允许使用特定的记录器,但如果找不到指定的记录器,这将回退到一般记录器?
例如,使用这样的配置文件
<configuration>
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net" />
</configSections>
<log4net>
<root>
<level value="ALL" />
<appender-ref ref="ConsoleAppender" />
</root>
<logger name="TestFileLogger">
<level value="ALL" />
<appender-ref ref="TestFileAppender" />
</logger>
<appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
<layout type="log4net.Layout.PatternLayout">
<param name="ConversionPattern" value="%d [%t] %-5p [%x] - %m%n" />
</layout>
</appender>
<appender name="TestFileAppender" type="log4net.Appender.RollingFileAppender">
<param name="File" value="TestLog" />
<param name="DatePattern" value=".yyyyMMdd".log"" />
<param name="AppendToFile" value="true" />
</appender>
</log4net>
</configuration>
并在C#中调用记录器就像这样
var fileLogger = LogManager.GetLogger("TestFileLogger");
fileLogger.Info("This logs appropriately.");
var bogusLogger = LogManager.GetLogger("Bogus");
bogusLogger.Info("This should go to a general log. Bogus is not a recognized appender");
有没有一种方法可以将消息从bogusLogger记录到某种常规日志文件中?我最初的想法是创建一个通用文件appender,它是根节点的一部分,但这非常嘈杂,因为所有日志消息都将路由到此文件.有没有办法只路由未在另一个日志文件中捕获的邮件?
解决方法:
您可以使用LogManager.Exists(“Bogus”)来确定是否应使用伪记录器或默认实现.
您可以在LogManager上创建一个可以为您处理它的扩展方法.