log4net初始化

29

我努力查找了重复内容,但必须询问以下问题,无论它看起来多么基础,都要一劳永逸地澄清它!

在一个新的控制台应用程序中,使用 log4net 版本 1.2.10.0 在 VS28KSP1 上运行于 64 位 W7 上,我有以下代码:

using log4net;
using log4net.Config;

namespace ConsoleApplication1
{
    class Program
    {
        static readonly ILog _log = LogManager.GetLogger(typeof(Program));
        static void Main(string[] args)
        {
            _log.Info("Ran");
        }
    }
}

在我的app.config中,我有:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <configSections>
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
  </configSections>
  <log4net>
    <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
      <file value="Program.log" />
      <lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
      <appendToFile value="true" />
      <rollingStyle value="Size" />
      <maxSizeRollBackups value="10" />
      <maximumFileSize value="1MB" />
      <staticLogFileName value="true" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="[%username] %date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
      </layout>
    </appender>

    <root>
      <level value="DEBUG" />
      <appender-ref ref="RollingFileAppender" />
    </root>
  </log4net>

</configuration>

如果我不添加一个属性,这段代码是不会输出任何东西的:

[ assembly:XmlConfigurator ]

或者在Main()中明确初始化它:

_log.Info("This will not go to the log");
XmlConfigurator.Configure();
_log.Info("Ran");

这引发了以下问题:

  1. 我几乎可以肯定在某个log4net版本中,没有添加程序集属性或在Main方法中调用就可以正常工作。有人能确保我不是在想象吗?
  2. 有人能告诉我在文档的哪里明确说明需要使用配置节和初始化钩子吗?最好解释一下什么时候发生了改变。

我可以很容易地想象为什么会有这样的策略——通过显式的初始化步骤来避免出现意料之外的情况,只是我似乎记得这并不总是这种情况...(通常我会将配置信息放在单独的文件中,这通常会排除掉配置节的影响)

1个回答

33

根据手册中的配置页面:

可以使用程序集级别属性而不是以编程方式指定来配置log4net配置。

XmlConfiguratorAttribute: log4net.Config.XmlConfiguratorAttribute允许使用以下属性配置XmlConfigurator

  • ConfigFile ...
  • ConfigFileExtension ...

如果未指定ConfigFile或ConfigFileExtension属性,则应用程序配置文件(例如TestApp.exe.config)将用作log4net配置文件。

示例用法:

// Configure log4net using the .config file
[assembly: log4net.Config.XmlConfigurator(Watch=true)]
// This will cause log4net to look for a configuration file
// called TestApp.exe.config in the application base
// directory (i.e. the directory containing TestApp.exe)
// The config file will be watched for changes.
                        

我同意这有一些歧义,但我理解存在示例用法的意思是log4net不会在没有上述属性的情况下使用.config文件;而他们指出必须使用其中的两个属性,但没有提到完全省略该属性,这让我认为该属性(或编程调用)是要以你所期望的方式使用app.config必需的。


所有听起来都很合理。但我仍在寻找更多信息——我相信我曾经看到过一些东西被发射到日志文件中,而没有明确的XmlConfiguratorAttribute或XmlConfigurator.Configure调用。它似乎在1.2.10版本中不太一致,并且通过Reflector查看代码并没有表明为什么它会在没有标记或显式调用的情况下工作。也许我应该改用NLog,这样就不会有这些问题了:P - Ruben Bartelink
1
@Ruben - 你为什么要因为需要初始化log4net而转换到另一个框架呢? - Peter Lillevold
1
@Peter Lillevold:我没有这样的意图,不确定你从哪里得到这个想法?我只是对了解如何在没有通过属性或调用Configurator.Configure进行显式配置的情况下使其工作感兴趣...? - Ruben Bartelink
@RubenBartelink:NLog更容易配置,但最终是无用的,因为它们的大多数配置不记录日志或不能按预期工作。虽然log4net的配置很奇怪,但至少他们的东西“能用”! - Mrchief

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接