我正在使用 log4net 登录我的应用程序。我的 FileAppender 工作正常,但 MemoryAppender 出现问题。
这是我的配置文件。
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
</configSections>
<log4net>
<appender name="LogFileAppender" type="log4net.Appender.FileAppender">
<param name="File" value="Envision.log" />
<param name="AppendToFile" value="true" />
<layout type="log4net.Layout.PatternLayout">
<param name="Header" value="" />
<param name="Footer" value="" />
<param name="ConversionPattern" value="%d [%t] %-5p %m%n" />
</layout>
</appender>
<appender name="MemoryAppender" type="log4net.Appender.MemoryAppender">
</appender>
<root>
<level value="ALL" />
<appender-ref ref="LogFileAppender" />
<appender-ref ref="MemoryAppender" />
</root>
</log4net>
</configuration>
我使用此代码来设置配置文件。
FileInfo file = new FileInfo(configPath);
log4net.Config.XmlConfigurator.Configure(file);
file = null;
就像我说的,FileAppender 很好用。但我似乎无法得到任何事件。我尝试过使用类似的东西来获取 MemoryAppender。
Hierarchy hierarchy = LogManager.GetRepository() as Hierarchy;
MemoryAppender mappender = hierarchy.Root.GetAppender("MemoryAppender") as MemoryAppender;
我试过使用:
var events = mappender.GetEvents()
记录某些内容后,事件始终为空。我尝试在代码中设置 FileAppender 和 MemoryAppender 而不是使用配置文件,我得到了相同的结果,FileAppender 工作正常,但似乎无法从 MemoryAppender 获取任何事件。好奇我是否理解 MemoryAppender 对吗?我还尝试设置一个线程来循环检查 GetEvents 是否为空,并且在注销时它总是返回为空。我尝试在 MemoryAppender 上将阈值设置为 Core.Level.All 但这并没有改变任何东西。
感谢您的任何指导。我环顾四周,从我看过的网站上看,我无法判断我在做什么不同。
即使像这样简单的事情也行不通。事件长度始终为零;
public partial class MainWindow : Window {
public MainWindow() {
InitializeComponent();
MemoryAppender appender = new MemoryAppender();
ILog logger = LogManager.GetLogger("foo");
BasicConfigurator.Configure(appender);
logger.Error("Should work");
var events = appender.GetEvents();
}
}