NLog记录器未记录到发布版本中已配置的日志文件

时间:2020-06-03 14:01:15

标签: c# nlog

我已经设置好配置文件

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <configSections>
        <section name="nlog" type="NLog.Config.ConfigSectionHandler, NLog"/>
    </configSections>
    <nlog autoReload="true">
        <targets>
            <target name="file" type="File" fileName="${basedir}/log/${shortdate}.log" layout="${date:format=HH\:mm\:ss.fff}|${message}"/>
            <target name="file_webs" type="File" fileName="${basedir}/log/${shortdate}_webs.log" layout="${date:format=HH\:mm\:ss.fff}|${message}"/>
        </targets>
        <rules>
            <logger name="WebSocket.*" minlevel="Debug" writeTo="file_webs" final="true"/>
            <logger name="*" minlevel="Debug" writeTo="file" />
        </rules>
    </nlog>
</configuration>

记录器在每个类中的加载方式如下:

private static Logger logger = LogManager.GetCurrentClassLogger();

只要我不运行构建版本,日志就会定向到正确的文件。然后,所有日志记录都在默认日志文件中完成。 可能是什么原因?

1 个答案:

答案 0 :(得分:2)

检查以下内容:

  • 是放置在发行版输出目录中的正确配置文件。可能那里的配置文件版本不同,或者丢失了。
  • 构建后还有其他事情在运行吗?像混淆源代码的工具一样?如果是这样,这可能会弄乱您的构建中的类名称,该配置将无法重定向到正确的输出。在这种情况下,可以通过以下方式显式加载类的记录器:
private static Logger logger = LogManager.GetLogger("WebSocket.*");