Pergunta

Eu estou usando log4net em um projeto C #, no ambiente de produção, eu quero desativar toda a extração de madeira, mas quando alguns fatais occures erro ele deve registrar todas as 512 mensagens anteriores a uma file.I configurou com sucesso isso, e ele está funcionando bem. Ele registra as mensagens para um arquivo quando alguns occures erro fatal.

Mas quando eu executá-lo a partir do Visual Studio, eu posso ver todas as mensagens de log são escritos para a janela de saída, independentemente de se tratar de uma fatal ou não. (Eu não posso ver essas mensagens quando executado a partir do Windows Explorer - a minha candidatura é um exe WinForm e não há janela Console para ver a saída)

Existe alguma maneira para desativar esse logging? Eu preciso meus registros somente em arquivo, que também quando alguns occures erro fatal.

<?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>

E é assim que eu configurá-lo na estática initializer de Windows Forms.

static Window1()
    {
      Stream vStream = typeof(Window1).Assembly.GetManifestResourceStream("TestLogNet.log4net.config");
      XmlConfigurator.Configure(vStream);
      BasicConfigurator.Configure();
    }

E eu tenho o objeto logger inicializado no construtor de WinForm

logger = LogManager.GetLogger(typeof(Window1));

[língua - C #, Framework - 3,5, Visual Studio 2008, log4net 1.2.10, tipo de projeto - WinForms]

Foi útil?

Solução

Remova a BasicConfigurator.Configure () linha. Isso é o que essa linha faz -. Adiciona um apontador ConsoleAppender para Console.Out

Outras dicas

Você ainda ver as mensagens em Visual Studio se o aplicativo é compilado no modo de versão? É possível que log4net usa Debug.Write para mostrar os erros de qualquer maneira. Se for esse o caso, então essas mensagens não deve aparecer no modo de versão.

Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top