2

我已经研究了几天这个问题没有答案。有对错误代码的引用,但我相信 BC2000 用于所有“编译器初始化”错误,无论潜在问题如何。

我有一个 VS 解决方案,可以在我们的开发环境中使用 MSBuild 12.0 编译得很好。但是,当尝试在我们的 Win 2008 R2 SP1 构建机器中使用 MSBuild 12.0 进行编译时,我们会遇到致命错误。

为 MSBuild 执行的命令是:

"C:\Program Files (x86)\MSBuild\12.0\Bin\MSBuild.exe" "path\to\solution.sln" /target:Clean;Build /verbosity:normal /toolsversion:12.0 /nologo /property:WarningLevel="2" /property:Configuration="Release"

收到的错误是:

vbc: Error: Fatal error BC2000 : compiler initialization failed unexpectedly: Project already has a reference to assembly Microsoft.VisualBasic. A second reference to 'path\to\dotnet4\System.dll' cannot be added. (Fatal error BC2000)

这类似于这个问题。但是,我们没有使用它们的设置,因为我们没有使用 Mono。

有问题的项目只有一个对 Microsoft.VisualBasic 程序集的引用。此外,正在执行的 vbc 命令在 dev 和 build 机器中是相似的,它们只引用一次提到的程序集。

开发和构建机器相同:

  • .NET 框架版本:4.6.1
  • 正在使用的 MSBuild:12.0

不同的:

  • 开发机器有 VS 2010 或 VS 2013。
  • 构建机器没有安装VS。
  • 构建机器还安装了 MS Visual C++ Build Tools 2015。

有没有人遇到过这个问题?关于如何解决它的任何想法?谢谢。

4

1 回答 1

1

在开发机器上运行构建时,我检查了 vbc 命令(很大,所以我不会发布),它链接到以下文件夹中的 Microsoft.VisualBasic.dll:

C:\Program Files (x86)\Reference Assemblies\Microsoft\Framework\.NETFramework\v4.0

我注意到这个文件夹在构建机器中不可用,因为它没有 .Net Framework 4 SDK。所以我安装了“Microsoft Windows SDK for Windows 7 and .NET Framework 4”(是的,即使构建机器是 Win 2008 R2)并且它工作正常。

现在,要安装该 SDK,我必须先卸载 .Net Framework,因为它是较新的版本,然后安装 .Net Framework 4,然后安装提到的 SDK,然后再次更新到 .Net Framework 4.6.1。

所以,总结一下:

  1. 在构建机器中执行 MSBuild 并将输出重定向到日志文件
  2. 打开日志文件并检查失败的vbc命令
  3. 在开发机器中执行 MSBuild 并将输出重定向到日志文件
  4. 打开日志文件并找到步骤 2 中标识的命令
  5. 检查有问题的程序集(来自错误)的位置
  6. 如果是和我开头说的类似的目录,那么可能需要安装上述版本的.Net Framework的SDK。就我而言,该目录具有 v4.0,因此它适用于 .Net Fw 4.0。

希望这可以帮助其他人。

于 2016-01-20T20:16:06.877 回答