【问题标题】:Log4Net/C# - Disable default loggingLog4Net/C# - 禁用默认日志记录
【发布时间】:2012-02-01 18:33:03
【问题描述】:

我在一个 C# 项目中使用 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 窗体的静态初始化程序中配置它的方式。

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

我在 WinForm 的构造函数中初始化了记录器对象

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

[语言 - C#, .NET 框架 - 3.5, 视觉工作室 2008, log4net 1.2.10, 项目类型 - WinForms]

【问题讨论】:

  • 所有内容都输出到控制台是否重要?当然,因为您的 winforms 应用程序没有控制台,所以它只是按照您的意愿进行记录?
  • 这对性能很重要,因为所有控制台调用都是同步的。如果你有一堆后台线程在做日志记录,那么它们会受到很大的影响。
  • +1 获取有关问题的完整详细信息(有太多问题可以恢复到“帮助,它不起作用”)

标签: c# log4net


【解决方案1】:

删除BasicConfigurator.Configure() 行。这就是该行的作用——添加一个指向 Console.Out 的 ConsoleAppender。

【讨论】:

    【解决方案2】:

    如果应用程序在发布模式下编译,您是否仍会在 Visual Studio 中看到这些消息?无论如何,log4net 都可能使用 Debug.Write 来显示错误。如果是这种情况,那么这些消息不应出现在发布模式中。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2021-05-26
      • 1970-01-01
      • 1970-01-01
      • 2011-01-08
      • 1970-01-01
      相关资源
      最近更新 更多