visual-studio - 带有调试和发布的 Nuget 包
问题描述
在我们的工作中,我们有一个开发库的团队和其他使用这些库开发项目的团队。
图书馆团队比项目团队拥有更多的经验。
我们在这里创建了这个环境:
所有的库都在 nuget 包中,在 nuget 服务器中,在 azure devops 中。我们在 Azure devops 中有源链接。
但是当我们部署这些库时,我们必须在调试或发布之间做出选择,而且我们各有利弊。
我理想的 nuget 包将同时具有调试和发布,并且会选择与运行它的项目相同的项目。
这样我就可以为项目团队进行更好的调试,并在发布时获得最大的性能。
我与https://twitter.com/rrelyea进行了交谈,他提出了一些想法,但对于其他团队来说实施起来似乎很复杂,或者管理起来很复杂。
像 2 台 nuget 服务器,一台用于调试,一台用于发布,并在机器和构建服务器上配置这些不同的服务器。
或者 2 个 nuget 包,在包的名称上带有 .debug 和 .release,并将项目配置为在每种模式下加载不同的包。
真正的问题是我需要保证所有包在两台服务器上都具有相同的 id 和版本。
没有更自动化的打包方式吗?
很简单,如果是调试就使用调试,如果是发布就使用发布。
顺便问一下,在这种情况下,调试和发布之间的性能差异有多大?
解决方案
没有更自动化的打包方式吗?
实际上,nuget 包没有让项目根据主项目的配置引用调试输出文件或发布输出文件的机制。
而且打包一个项目时,它没有同时包含Debug或Release输出文件然后让主项目-------在使用Debug时,引用nuget的Debug内容,使用Release时,请参考 nuget 的Release内容。
到目前为止,nuget还没有那么灵活,它不能做你上面提到的功能。
======================
作为建议,您应该创建项目的两个 nuget 包(Debug或Release),然后根据需要手动安装相应的包。
您可以创建一个网络标准库项目,并将这些添加到xxx.csproj
文件中:
<Project Sdk="Microsoft.NET.Sdk">
<PropertyGroup>
<TargetFramework>netstandard2.0</TargetFramework>
<RootNamespace>PackageName</RootNamespace>
<GeneratePackageOnBuild>true</GeneratePackageOnBuild>
</PropertyGroup>
<PropertyGroup Condition="'$(Configuration)'=='Debug'">
<PackageId>PackageName_Debug</PackageId> //name the nuget package which contains Debug key name
</PropertyGroup>
<PropertyGroup Condition="'$(Configuration)'=='Release'">
<PackageId>PackageName_Release</PackageId> //name the nuget package which contains Debug key name
</PropertyGroup>
<PropertyGroup>
<Version>1.0.0</Version>
<Authors>your_name</Authors>
<Company>your_company</Company>
</PropertyGroup>
<ItemGroup Condition="'$(Configuration)'=='Debug'">
<None Include="$(ProjectDir)$(OutputPath)$(AssemblyName).pdb" Pack="true" PackagePath="lib\$(TargetFramework)"></None>
<Compile Update="Class1.cs" Pack="true" PackagePath="Resource">
</Compile>
...// add any source files
</ItemGroup>
</Project>
您可以将配置切换到调试或发布来构建您的项目以在输出文件夹下生成 nupkg 文件。
注意:
1)要生成调试nuget包,您应该将pdb file
and包含source files
到nuget包中,然后您可以在主项目中对其进行调试。有一个类似的问题,其中包含有关它的详细步骤。
2)可以package_id
直接在新建的sdk格式项目中定义。您应该添加Debug
或Release
区分它们。
更多关于打包新 sdk 格式项目的信息,可以参考这个文档。
===============================
另外,如果您仍然想要初始功能(在同一个包中包含 Debug 或 Release),您可以suggest a feature
在我们的用户语音论坛上,我希望团队会仔细考虑您的想法并给出满意的答复。