Log4Net/C# — отключить ведение журнала по умолчанию

StackOverflow https://stackoverflow.com/questions/126939

  •  02-07-2019
  •  | 
  •  

Вопрос

Я использую 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 для отображения ошибок.Если это так, то эти сообщения не должны появляться в режиме выпуска.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top