Log4Net/C# — отключить ведение журнала по умолчанию
Вопрос
Я использую log4net в проекте C# в производственной среде, я хочу отключить все журналы, но когда возникает некоторая фатальная ошибка, она должна войти в систему все предыдущие 512 сообщения в файле. Я успешно настроил это, и это работаю нормально.Он записывает сообщения в файл при возникновении фатальной ошибки.
Но когда я запускаю его из Visual Studio, я вижу, что все сообщения журнала записываются в окно вывода, независимо от того, является ли это фатальным или нет.(Я не вижу этих сообщений при запуске из проводника Windows — мое приложение представляет собой exe-файл WinForm, и нет окна консоли для просмотра результатов)
Есть ли способ отключить это ведение журнала?Мне нужны мои журналы только в файле, даже если происходит какая-то фатальная ошибка.
<?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 = LogManager.GetLogger(typeof(Window1));
Язык - C#, .NET Framework - 3.5, Visual Studio 2008, log4net 1.2.10, тип проекта - Winforms
Решение
Удалить БазовыйКонфигуратор.Настроить() линия.Вот что делает эта строка — добавляет ConsoleAppender, указывающий на Console.Out.
Другие советы
Вы по-прежнему видите сообщения в Visual Studio, если приложение скомпилировано в режиме выпуска?Вполне возможно, что log4net все равно использует Debug.Write для отображения ошибок.Если это так, то эти сообщения не должны появляться в режиме выпуска.