c# - 使用多个 VS 解决方案和多个项目时的 NuGet 策略

标签 c# .net nuget

我正在寻找关于哪种方法被认为是最佳实践的一些想法。

场景: .NET SVN 存储库由多个项目组成,其中一些项目共享相同的 NuGet 包。多个解决方案文件也存在,每个文件中都有项目的子集,有些重叠。

例子:

a.sln
--> proj1 - log4net, nunit(v1.0.0)
--> proj2 - log4net, json
--> proj3 - log4net, nunit(v1.0.0)

b.sln
--> proj2 - log4net, json
--> proj4 - nunit(v1.0.0)

当开发人员打开 a.sln 并为该解决方案中的所有项目更新 nunit(v1.0.0) 包时,问题就出现了,v2 .0.0。这使得 proj4nunit 仍在 v1.0.0 上,假设所有二进制文件都复制到一个输出文件夹,首先构建的解决方案将确定哪个版本的 nunit 可用。

方法 #1: 组成一个项目,同时被a.slnb.sln 使用,其唯一目的是包含所有项目的所有NuGet 引用,并将所有文件输出到一个文件夹,比如 Externals。修改所有项目以手动引用此文件夹中的 dll

方法 #2: 更新包时要勤奋,并对每个解决方案重复该过程。

方法 #3: 创建一个包含所有项目的解决方案,避免多个解决方案。

我有强烈的偏好,但希望获得社区反馈并持开放态度。

最佳答案

  • 方法 #1 - 我看到的问题是它会强制对其他项目进行更新,从而导致潜在的编译问题。此外,您可能有一个项目更喜欢旧的 NuGet 包

  • 方法 #2 - 根据 #1,此外,除非开发人员使用其他解决方案,否则他们可能不会考虑更新它们。我们开发人员在处理错误时可能会很挑剔

  • 方法 #3 - 虽然从维护的角度来看更容易一些,但它不能保证某些项目都使用相同的 NuGet 数据包。例如nunit 的两个不同版本。在 Visual Studio 中安装和/或更新 NuGet 包时,开发人员可以覆盖哪些项目将接收包。根据项目的大小,一些开发人员可能不喜欢创建整体解决方案的想法(即使可以右键单击项目卸载项目),因为一般性能会受到影响

    <

在我看来,方法 #3 可能更容易,因为可以一步将同一包大量安装到所有项目中。 方法 #1 也很接近,但我担心您会发现您将不得不将 NuGet 包部署到其他项目中,而不管由于依赖关系 - “Type xxx is defined in an未引用的程序集。请将其添加到引用中”

不兼容的版本

This leaves proj4's nunit still on v1.0.0, and assuming all binaries are copied to one output folder, the solution that is built first will determine which version of nunit becomes available.

同意,这让我印象深刻,这是我们遇到的最终问题。即使您的团队在任何地方都使用 log4net 版本 X 受到纪律处分,您很有可能会遇到这样的情况,即使用某些第三方库也需要 log4net 但版本 Y。于是版本不兼容的问题又出现了。

应用域

如果您发现您的解决方案必须部署多个版本的第 3 方程序集,您可能需要查看子 .NET AppDomains。这个想法是,您不是将程序集部署到一个大文件夹中(旧文件可以被新文件破坏,反之亦然),而是将每个程序集部署到一个根文件夹和子文件夹中,这些程序集绑定(bind)到特定的第三方 .dll。

您需要子 AppDomain 的原因是即使其他程序集位于不同的文件夹中,每个 AppDomain 也不能多次加载一个程序集。

例如

<my app folder>
|--folder a
  |--log4net v1.dll
  |--nunit 3.dll
|--folder b
  |--log4net v2.dll
  |--nunit 4.dll

毕竟,nUnit 在运行测试时会使用子 AppDomain。

关于c# - 使用多个 VS 解决方案和多个项目时的 NuGet 策略,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33644393/

相关文章:

C# 反射 : Replace a referenced assembly

c# - Parallel.Foreach 异常和取消

c# - PCL - 对于某些目标,无法从 Func<IThing<T>> 转换为 Func<Object>

visual-studio-2017 - NuGet 包 - readme.txt 被添加到目标项目,而不是仅仅被显示

c# - 在 Dotnet Framework 4.8 客户端中使用 Core gRPC 服务器?

c# - 使用 async/await、RX 和 LINQ 进行异步消息处理

.net - 取消异步操作

.net - WPF - 控制半透明层之间的混合

visual-studio - 用于自定义项目类型的 NuGet 包管理器

visual-studio - 包还原失败/.Net Core 安装错误