Nuget NLog 64位

问题描述

我有一个使用NLog的asp.net应用程序。我可以成功地在x32平台上运行它。但是对于x64平台,我在启动时遇到错误

BadImageFormatException无法加载文件或程序集或其依赖项之一。试图加载格式错误的程序

我认为,这是因为NLog.dll的x32版本加载了Nuget。我尝试使用Nuget for x64平台加载NLog,但始终只能获得x32。是不是意味着NLog在回购中没有x64版本的NuGet软件包? NLog仅是示例。我的应用程序依赖于许多其他软件包,例如njsonSchema.dll,System.Web.Razor.dll等。但是它们都在Nuget回购中只有x32版本,为什么?显然,它是MS的系统软件包,为什么没有x64版本? 就是说,我应该只构建asp.net应用程序的x32平台?

解决方法

我认为,这是因为x32版本的NLog.dll加载了Nuget。

好的,让我们尝试验证这个假设。首先,我使用dotnet new console创建一个新项目,然后几次构建它,dotnet builddotnet build -r win-x86dotnet build -r win-x64。然后,我使用ILSpy检查dll。对于win-x64构建,ILSpy告诉我“ //体系结构:x64”。对于win-x86构建,ILSpy告诉我“ //体系结构:x86”。而没有指定运行时的构建,ILSpy告诉我“ //体系结构:AnyCPU(首选64位)”。

现在,将NLog添加为PackageReference,然后构建,在bin目录中获得一个nlog.dll,并在ILSpy中打开它,我看到的是“ //体系结构:AnyCPU(首选64位)”。

因此,我得出的结论是NLog不是32位。

如果您没有足够的说服力,这是我的Program.Main方法:

static void Main(string[] args)
{
    var console = new NLog.Targets.ConsoleTarget();
    var config = new LoggingConfiguration();
    config.AddRule(LogLevel.Info,LogLevel.Fatal,console);
    NLog.LogManager.Configuration = config;

    var logger = NLog.LogManager.GetCurrentClassLogger();

    int bits = Environment.Is64BitProcess ? 64 : 32;
    logger.Info($"Running {bits}-bit process");
}

使用dotnet rundotnet run -r win-x86dotnet run -r winx64来运行它,我从没见过崩溃,这三个执行中的两个告诉我该过程是64位的,其中一个告诉我进程是32位的。由于我正在使用NLog将其输出到控制台,因此我有信心NLog可在两种指令集体系结构中使用。

实际上,使用dotnet build -r linux-arm构建二进制文件并将其复制到我的Raspberry Pi中,我可以在ARM CPU上运行该程序,包括nlog。

我尝试使用Nuget for x64平台加载NLog,但始终只能获得x32。是不是意味着NLog在回购中没有x64版本的NuGet软件包?

我不知道您是如何得出NLog或其他软件包仅为32位的结论。我建议您阅读StackOverflow关于如何创建minimal,reproducable examples的建议。当我这样做时,我经常会自己找到问题的解决方案。当我自己找不到解决方案时,我举了一个简单的例子,其他人可以在自己的计算机上运行以验证意外的行为,并可以帮助修改它以回答我提出的问题。无论如何,我都无法重现您遇到的问题,并且希望我的回答使您确信.NET库(为AnyCPU编译)可以在任何指令集上工作。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...