2

我做了 2 个项目来测试 .NET Framework 4.6.1 标准控制台应用程序和 .NET Standard 2.0 库上的 NLog。我的意图是将尽可能多的代码移植到 .NET Standard 2.0 以实现未来的多平台兼容性。

两者共享相同的代码,但 .NET Standard 版本会产生异常。

这是代码

Console.WriteLine("Writing log");
Logger _errorLog = LogManager.GetLogger("ErrorsLogger");
Logger _tradesLog = LogManager.GetLogger("TradesLogger");
_errorLog.Error("This is the log message!!!");
Console.WriteLine("End log");
Console.Read();

这是 App.Config

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <configSections>
    <section name="nlog" type="NLog.Config.ConfigSectionHandler, NLog"/>
  </configSections>
  <nlog xmlns="http://www.nlog-project.org/schemas/NLog.xsd"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">

    <targets>
      <target name="ErrorsLogger" xsi:type="File" fileName="ErrorsLog.txt" />
      <target name="TradesLogger" xsi:type="File" fileName="TradesLog.txt" />
    </targets>

    <rules>
      <logger name="ErrorsLogger" minlevel="Info" writeTo="ErrorsLogger" />
      <logger name="TradesLogger" minlevel="Info" writeTo="TradesLogger" />
    </rules>
  </nlog>
</configuration>

我在 .NET 4.6.1 控制台应用程序中得到了很好的日志,并生成了预期的日志文件,其中包含日志消息。

如果我通过一些 Microsoft 单元测试项目运行 .NET Standard 2.0 库,当它尝试调用 _errorLog.GetLogger 时会出现此异常

UnitTestProject.UnitTest1.TestMethod1 抛出异常:System.TypeInitializationException:'NLog.LogManager' 的类型初始化程序抛出异常。---> System.TypeInitializationException:'NLog.LogFactory' 的类型初始化程序引发了异常。---> System.MissingMethodException:找不到方法:'System.AppDomainSetup System.AppDomain.get_SetupInformation()'。

编辑: Nuget NLOG 版本:4.4.12

非静态方法中抛出的异常:

关于获得更好异常的非静态方法:

在 GetLogger("X") 级别抛出异常,这是一个非静态构造函数。初始化例程甚至在尝试记录某些内容之前就崩溃了。

此外,我在错误列表中收到警告(黄色感叹号):

警告 'configuration' 元素未声明。

添加内部日志不会产生任何输出。这是我使用的配置,从他们的内部日志指南开始:

        InternalLogger.LogLevel = LogLevel.Trace;
        InternalLogger.LogFile = @"C:\temp\int.txt";
        InternalLogger.LogToConsole = true;
        InternalLogger.LogToConsoleError = true;
        InternalLogger.LogWriter = new StringWriter(new StringBuilder());
        InternalLogger.LogToTrace = true;
        LogManager.ThrowConfigExceptions = true;
        LogManager.ThrowExceptions = true;
        Logger logger = LogManager.GetLogger("foo");

我是管理员,Visual Studio 2017 以管理员身份启动,我有权在 C:\temp 中写入,而 .NET 4.6.1 控制台应用程序能够在该文件夹中写入,并且位于同一个项目中。

内部日志文件为空,单元测试项目运行测试成功。

我不知道发生了什么。现在没有抛出错误。

欢迎任何调试问题的建议。

GitHub 上的ISSUE已打开。

这是我为您展示的测试解决方案(密码: logging123)。现在我已更新到 Nlog 4.5,您将看到 .NET 框架解决方案在尝试获取旧版本的 Nlog(我从未引用过)时抛出错误,并且 .NET Core 单元测试解决方案有效但没有产生任何文件。

4

2 回答 2

1

尽管我运行的是 .NET 4.7,但我遇到了同样的问题。我将我的 NLog 包从 4.4.12 更新到4.5.0-rc04并且它工作正常。了解它的预发布版本后,您可能需要注意将其置于实时环境中。

于 2018-01-18T11:16:44.597 回答
0

您的压缩解决方案受密码保护,所以现在只是我的猜测,但看起来您正在使用 app.config 来保存 nlog.config。

很确定 NetCoreApps 没有使用 app.config。尝试将您的 Nlog-config 放在一个名为的单独文件中nlog.config,并确保它是Copy Always(在 Visual Studio 文件属性中)。

于 2018-01-23T19:06:14.710 回答