NLog 缺少带有异步翻转文件配置的日志条目

Posted

技术标签:

【中文标题】NLog 缺少带有异步翻转文件配置的日志条目【英文标题】:NLog missing log entries with async rollover file configuration 【发布时间】:2015-10-16 07:18:04 【问题描述】:

NLog 没有使用异步滚动文件记录器配置记录每条日志消息。

以下是我的 NLog.config xml。

<?xml version="1.0" encoding="utf-8" ?>
<nlog xmlns="http://www.nlog-project.org/schemas/NLog.xsd"
      xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
      xsi:schemaLocation="http://www.nlog-project.org/schemas/NLog.xsd NLog.xsd"
      autoReload="true"
      throwExceptions="false"
      internalLogLevel="Off" internalLogFile="c:\temp\nlog-internal.log" >

  <targets async="true">
      <target name="logfile" xsi:type="File" fileName="logs/log.txt" 
              maxArchiveFiles="10" 
              archiveAboveSize="1048576" 
              archiveNumbering="Sequence" 
              concurrentWrites="true" 
              archiveFileName="logs/log.####.txt"/>
    </target>
  </targets>

  <rules>
    <logger name="*" minlevel="Debug" writeTo="logfile" />
  </rules>
</nlog>

以下是我的代码。

    private static Logger log = LogManager.GetCurrentClassLogger();
    Stopwatch sw = new Stopwatch();

    public Form1()
    
        InitializeComponent();
        LogManager.ReconfigExistingLoggers();
    

    private void button1_Click(object sender, EventArgs e)
    
        string toLog;
        sw.Start();
        for (int i = 0; i < 100000; i++)
        
            toLog = "Message:" + i.ToString();
            log.Debug(toLog);
        
        sw.Stop();
        string s = "STOP :" + sw.Elapsed.ToString();
        log.Debug(s);
    

结果我只得到一个文件,并且缺少一些日志条目。以下是生成的 log.txt 文件。

2015-10-16 12:04:08.9865|DEBUG|NLogAsync.Form1|Message:11591
2015-10-16 12:04:08.9865|DEBUG|NLogAsync.Form1|Message:11592
2015-10-16 12:04:08.9865|DEBUG|NLogAsync.Form1|Message:11593
2015-10-16 12:04:08.9865|DEBUG|NLogAsync.Form1|Message:11594
2015-10-16 12:04:09.0802|DEBUG|NLogAsync.Form1|Message:80436
2015-10-16 12:04:09.0802|DEBUG|NLogAsync.Form1|Message:80437
2015-10-16 12:04:09.0802|DEBUG|NLogAsync.Form1|Message:80438
2015-10-16 12:04:09.0802|DEBUG|NLogAsync.Form1|Message:80439

但是,当我删除 async 属性时,代码运行正常。

【问题讨论】:

【参考方案1】:

&lt;targets async="true"&gt; 只是用AsyncWrapper 目标包装所有目标的简写。 IE。你的配置相当于:

<targets>
  <target name="logfile" xsi:type="AsyncWrapper">
    <target xsi:type="File" fileName="logs/log.txt"
            maxArchiveFiles="10"
            archiveAboveSize="1048576"
            archiveNumbering="Sequence"
            concurrentWrites="true"
            archiveFileName="logs/log.####.txt"/>
  </target>
</targets>

此异步包装器将使用默认设置。对你来说最重要的是queueLimit,默认是10000,overflowAction,默认是Discard。这是什么意思?在写入线程在队列中有超过 10000 条日志消息后,所有新的日志消息都被丢弃了。因此,确保处理所有日志消息的最简单方法是将默认溢出操作值更改为Grow。但是您需要为此手动指定AsyncWrapper

<targets>
  <target name="logfile" xsi:type="AsyncWrapper" overflowAction="Grow">
    <target xsi:type="File" fileName="logs/log.txt"
            maxArchiveFiles="10"
            archiveAboveSize="1048576"
            archiveNumbering="Sequence"
            concurrentWrites="true"
            archiveFileName="logs/log.####.txt"/>
  </target>
</targets>

【讨论】:

以上是关于NLog 缺少带有异步翻转文件配置的日志条目的主要内容,如果未能解决你的问题,请参考以下文章

ASP.NET Core 使用NLog打印html格式日志

.Net -- NLog日志框架配置与使用

NLog LogException 似乎忽略了异常

在 NLog 使用 AsyncWrapper 后大部分日志丢失

NLog 基于静态变量创建日志文件

NLog 实现日志输出到文件详细步骤