3

使用下面的配置,大约一半的时间,我每一个得到两个日志,一个是空的。它们的文件名相差一秒(log.2015-03-09_11-50-25 vs log.2015-03-09_11-50-26)

我试图每次运行控制台应用程序都有一个日志。

<log4net>

  <appender name="Log" type="log4net.Appender.FileAppender">
    <file type="log4net.Util.PatternString" value="C:\env\QA\Logs\consoleapp\log.%date{yyyy-MM-dd_HH-mm-ss}.txt"/>
    <appendToFile value="true"/>
    <layout type="log4net.Layout.PatternLayout">
      <conversionPattern value="%date    %message%newline"/>
    </layout>
  </appender>

  <root>
    <level value="INFO"/>
    <appender-ref ref="Log"/>
  </root>
</log4net>

后一个日志是唯一填充/写入的日志。

为什么会这样?我如何解决它?

编辑:原来我在我的代码中实例化了第二个记录器。当实例化发生在另一秒时,会创建第二个日志。appender 工作正常。

4

2 回答 2

3

我以前见过类似的东西 - 这是由于在文件名中指定了第二个,并且写入发生在一秒结束和另一秒开始期间。

<file type="log4net.Util.PatternString" value="C:\env\QA\Logs\consoleapp\log.%date{yyyy-MM-dd_HH-mm-ss}.txt"/>

应该

<file type="log4net.Util.PatternString" value="C:\env\QA\Logs\consoleapp\log.%date{yyyy-MM-dd}.txt"/>

在我的上一份工作中,有人在日志文件名中设置了第二个说明符,生产服务器在尝试渲染日志文件夹中包含的 150,000 个文件时差点崩溃。

编辑:

如果您想每次运行编写一次,可以将以下内容添加到 log4net 配置中:

<rollingStyle value="Once" />

并且您可能需要将该appendToFile属性设置为 false。

log4net 每次运行一个文件

所以你的配置看起来像这样:

<appender name="Log" type="log4net.Appender.FileAppender">
    <file type="log4net.Util.PatternString" value="C:\env\QA\Logs\consoleapp\log.%date{yyyy-MM-dd_HH-mm-ss}.txt"/>
    <appendToFile value="false" />    
    <maxSizeRollBackups value="-1" /> <!--infinite-->
    <rollingStyle value="Once" />
    <layout type="log4net.Layout.PatternLayout">
      <conversionPattern value="%date    %message%newline"/>
    </layout>
  </appender>
于 2015-03-09T16:02:21.220 回答
1

我使用了 user1666620 的解决方案,但仍然有一个 .log.1 文件。原来我的AssemblyInfo.cs文件中有以下行:

[assembly: log4net.Config.XmlConfigurator(Watch = true)]

删除上述行解决了我的问题。顺便说一句,我的program.cs看起来像:

public static class Program
{
    static Program()
    {
        // Initialize logging
        log4net.Config.XmlConfigurator.Configure();
    }

    private static readonly ILog log =
        LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);

    ...
}
于 2015-11-11T00:27:38.323 回答