log4net的/ C# - 禁用默认的日志 [英] Log4Net/C# - Disable default logging

查看:164
本文介绍了log4net的/ C# - 禁用默认的日志的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我使用log4net的一个C#项目,在生产环境中,我要禁用所有日志,但是当一些致命
错误occures它应该记录所有以前的512条信息到一个file.I已成功配置这一点,这是工作的罚款。它登录到当一些致命错误occures文件的消息。



但是,当我从Visual Studio运行它,我可以看到所有的日志消息被写入到输出窗口,不管它是否是致命的或没有。 (我不能看到这些消息时,我从Windows资源管理器中运行 - 我的应用程序是一个WinForm的exe并没有控制台窗口中看到输出)



有什么办法禁用此记录?我需要我的日志只是在文件中,太当一些致命的错误occures。



<预类=郎咸平的XML prettyprint-覆盖> < ;? XML版本=1.0编码=UTF-8>?;
<结构>
< log4net的调试=假>

<追加程序名称=RollingFileAppender进行TYPE =log4net.Appender.RollingFileAppender>
<文件值=log.txt的/>
< appendToFile值=真/>
< rollingStyle值=大小/>
< maxSizeRollBackups值=10/>
< maximumFileSize值=1MB/>
< staticLogFileName值=真/>
<布局类型=log4net.Layout.PatternLayout>
< conversionPattern值=%DATE [%线程]%-5level%记录[%产权{} NDC - %讯息%换行/>
< /布局>
< /附加器>

<追加程序名称=BufferingForwardingAppenderTYPE =log4net.Appender.BufferingForwardingAppender>
< BUFFERSIZE值=512/>
将有损值=真/>
<评估TYPE =log4net.Core.LevelEvaluator>
<阈值=FATAL/>
< /评估>
<附加目的地-REF REF =RollingFileAppender进行/>
< /附加器>

<根和GT;
<电平值=DEBUG/>
<附加目的地-REF REF =BufferingForwardingAppender/>
< /根>
< / log4net的>
< /结构>



这是我如何配置它在Windows窗体的静态初始化。

 静态窗口1()
{
流VSTREAM = typeof运算(窗口1).Assembly.GetManifestResourceStream(TestLogNet.log4net.config );
XmlConfigurator.Configure(VSTREAM);
BasicConfigurator.Configure();
}

和我在winform的构造函数初始化Logger对象



  =记录器LogManager.GetLogger(typeof运算(窗口1)); 

[语言 - C#,
的.NET Framework - 3.5,
的Visual Studio 2008年,
log4net的1.2.10,
项目类型 - 的WinForms]


解决方案

删除的 BasicConfigurator.Configure()线。这就是该行不 - 增加了指向Console.Out是ConsoleAppender一个


I am using log4net in a C# project, in the production environment, I want to disable all the logging, but when some fatal error occures it should log all the previous 512 messages in to a file.I have successfully configured this, and it is working fine. It logs the messages in to a file when some fatal error occures.

But when I run it from Visual Studio, I can see all the log messages are written to the Output window, regardless of whether it is a Fatal or not. (I cant see these messages when I run from the Windows Explorer - my application is a WinForm exe and there is no Console window to see the output)

Is there any way to disable this logging? I need my logs only in file, that too when some fatal error occures.

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

And this is how I configure it in the static initializer of Windows Forms.

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

And I have the logger object initialized in the constructor of WinForm

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

[language - C#, .NET Framework - 3.5, Visual Studio 2008, log4net 1.2.10, project type - WinForms]

解决方案

Remove the BasicConfigurator.Configure() line. That's what that line does -- adds a ConsoleAppender pointing to Console.Out.

这篇关于log4net的/ C# - 禁用默认的日志的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆