Log4Net / C#-禁用默认日志记录
时间:2020-03-06 14:39:35 来源:igfitidea点击:
我在Cproject中使用log4net,在生产环境中,我想禁用所有日志记录,但是当某些操作致命时
发生错误,应该将以前的所有512条消息记录到文件中。我已经成功配置了此文件,并且工作正常。发生某些致命错误时,它将消息记录到文件中。
但是,当我从Visual Studio中运行它时,无论它是否是致命的,我都可以看到所有日志消息都写入了"输出"窗口。 (当我从Windows资源管理器运行时,我的应用程序是WinForm exe,并且看不到控制台窗口,无法看到这些消息)
有什么方法可以禁用此日志记录吗?我只需要文件中的日志,当发生一些致命错误时也是如此。
<?xml version="1.0" encoding="utf-8" ?> <configuration> <log4net debug="false"> <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender"> <file value="log.txt" /> <appendToFile value="true" /> <rollingStyle value="Size" /> <maxSizeRollBackups value="10" /> <maximumFileSize value="1MB" /> <staticLogFileName value="true" /> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" /> </layout> </appender> <appender name="BufferingForwardingAppender" type="log4net.Appender.BufferingForwardingAppender" > <bufferSize value="512" /> <lossy value="true" /> <evaluator type="log4net.Core.LevelEvaluator"> <threshold value="FATAL"/> </evaluator> <appender-ref ref="RollingFileAppender" /> </appender> <root> <level value="DEBUG" /> <appender-ref ref="BufferingForwardingAppender" /> </root> </log4net> </configuration>
这就是我在Windows Forms的静态初始化程序中配置它的方式。
static Window1() { Stream vStream = typeof(Window1).Assembly.GetManifestResourceStream("TestLogNet.log4net.config"); XmlConfigurator.Configure(vStream); BasicConfigurator.Configure(); }
我在WinForm的构造函数中初始化了logger对象
logger = LogManager.GetLogger(typeof(Window1));
[C#语言,
.NET Framework 3.5,
Visual Studio 2008,
log4net 1.2.10,
项目类型WinForms]
解决方案
如果应用程序是在发布模式下编译的,我们还在Visual Studio中看到消息吗?无论如何,log4net可能使用Debug.Write来显示错误。如果是这种情况,则这些消息不应出现在发布模式下。
删除BasicConfigurator.Configure()行。这就是该行的作用-添加一个指向Console.Out的ConsoleAppender。