我的Buildprocess工作正常,但是一个非常小的项目需要将近3秒钟。
我怎样才能加快构建过程?
日志文件很大,可以发布它。随意询问有关记录器输出的问题,然后我会发布所请求的部分。
C#构建项目的方法
private void CompileCode()
{
using (var buildManager = new BuildManager())
{
var result = buildManager.Build(this.CreateBuildParameters(), this.CreateBuildRequest());
if (result.OverallResult == BuildResultCode.Failure)
{
// Error handling
var stringbuilder = new StringBuilder();
using (var reader = new StreamReader(NameDebuggerLogFile))
{
stringbuilder.Append(reader.ReadToEnd());
}
throw new CompilerException(stringbuilder.ToString());
}
}
}
private BuildParameters CreateBuildParameters()
{
var projectCollection = new ProjectCollection();
var buildLogger = new FileLogger { Verbosity = LoggerVerbosity.Detailed, Parameters = "logfile=" + NameDebuggerLogFile };
var buildParameters = new BuildParameters(projectCollection) { Loggers = new List<ILogger>() { buildLogger } };
return buildParameters;
}
private BuildRequestData CreateBuildRequest()
{
var globalProperties = new Dictionary<string, string>();
var buildRequest = new BuildRequestData(FolderPath + NameProjectFile, globalProperties, null, new[] { "Build" }, null, BuildRequestDataFlags.ReplaceExistingProjectInstance);
return buildRequest;
}
用于构建过程的项目文件
<?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="4.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<Import Project="$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props" Condition="Exists('$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props')" />
<PropertyGroup>
<AssemblyName>GeneratedFlexForm</AssemblyName>
<OutputPath>DLL</OutputPath>
<OutputType>Library</OutputType>
<DebugType>none</DebugType>
<DebugSymbols>false</DebugSymbols>
<Optimize>false</Optimize>
</PropertyGroup>
<ItemGroup>
<Reference Include="System" />
<Reference Include="System.Xml" />
<Reference Include="System.Xml.Linq" />
<Reference Include="System.ServiceModel" />
<Reference Include="System.Runtime.Serialization" />
<Reference Include="System.Web" />
<Reference Include="System.Web.Services" />
<Reference Include="System.Drawing" />
<Reference Include="System.Design" />
<Reference Include="System.Data" />
<Reference Include="System.Core" />
<Reference Include="System.Management" />
<Reference Include="System.Configuration" />
<Reference Include="System.Xaml">
<RequiredTargetFramework>4.0</RequiredTargetFramework>
</Reference>
<Reference Include="WindowsBase" />
<Reference Include="PresentationCore" />
<Reference Include="PresentationFramework" />
<!--<Reference Include="FlexForms.Core" />-->
<Reference Include="FlexForms.Core, Version=1.0.0.0, Culture=neutral, processorArchitecture=MSIL">
<SpecificVersion>False</SpecificVersion>
<HintPath>Library\FlexForms.Core.dll</HintPath>
</Reference>
<Reference Include="Gizmox.WebGUI.Forms">
<SpecificVersion>False</SpecificVersion>
<HintPath>Library\Gizmox.WebGUI.Forms.dll</HintPath>
</Reference>
<Reference Include="Gizmox.WebGUI.Common">
<SpecificVersion>False</SpecificVersion>
<HintPath>Library\Gizmox.WebGUI.Common.dll</HintPath>
</Reference>
<Reference Include="FlexForms.ServiceProviders">
<SpecificVersion>False</SpecificVersion>
<HintPath>Library\FlexForms.ServiceProviders.dll</HintPath>
</Reference>
</ItemGroup>
<ItemGroup>
<Page Include="FlexForm.xaml">
<Generator>MSBuild:Compile</Generator>
<DependentUpon>RadioButtonValueConverter.cs</DependentUpon>
<SubType>Designer</SubType>
</Page>
<Compile Include="FlexForm.xaml.cs">
<DependentUpon>FlexForm.xaml</DependentUpon>
<SubType>Code</SubType>
</Compile>
<Compile Include="UserCode.cs">
<SubType>Code</SubType>
</Compile>
<Compile Include="RadioButtonValueConverter.cs">
<SubType>Code</SubType>
</Compile>
<Resource Include="datacontext.xml"/>
</ItemGroup>
<Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
</Project>
构建期间收集的记录器输出(由于文件大小而只是最后一行)
完成构建项目“projectfile.csproj”。
构建成功。 0警告 0错误
时间流逝00:00:02.68
修改
我希望我能在这里引用 Seva Titov :
构建WPF非常棘手,例如重新编译XAML文件 两次(见MSDN)。您只能使用csc.exe轻松复制它。如果 你的项目中有XAML,你必须使用MSBuild。 - Seva Titov
这就是为什么我必须坚持使用MSBuild。
无论如何,我有一些改善表现的想法:
问题1: 这是我的日志文件的一个片段,它表示MSBuild会在解析依赖项的同时管理.winmd,.dll和.exe文件。
AllowedAssemblyExtensions: .winmd .dll .exe
由于我只有.dll文件,我想禁用MSBuild考虑.winmd文件,这几乎是我所有的依赖项。 (以下示例)
主要参考“PresentationCore,Version = 4.0.0.0,Culture = neutral, 公钥= 31bf3856ad364e35" 。 已解决的文件路径为“C:\ Program Files(x86)\ Reference Assemblies \ Microsoft \ Framework.NETFramework \ v4.0 \ PresentationCore.dll”。 在搜索路径位置“{TargetFrameworkDirectory}”中找到参考。 对于SearchPath“{TargetFrameworkDirectory}”。 考虑“C:\ Program Files(x86)\ Reference Assemblies \ Microsoft \ Framework.NETFramework \ v4.0 \ PresentationCore.winmd”, 但它不存在。
解决方案:1 我不得不修改我的CreateBuildRequest()方法:
private BuildRequestData CreateBuildRequest()
{
var globalProperties = new Dictionary<string, string>();
// Related to idea 1
globalProperties.Add("ExpandSDKAllowedReferenceExtensions", ".dll");
globalProperties.Add("AllowedReferenceAssemblyFileExtensions", ".dll");
globalProperties.Add("AllowedReferenceRelatedFileExtensions", string.Empty);
// Related to idea 2
globalProperties.Add("BuildProjectReferences", "false");
globalProperties.Add("BuildInParallel", "true");
var buildRequest = new BuildRequestData(FolderPath + NameProjectFile, globalProperties, "4.0", new[] { "Build" }, null, BuildRequestDataFlags.IgnoreExistingProjectState);
return buildRequest;
}
EDIT2: 创意2: 有没有人知道如何包含/ maxcpucount或/ m开关来并行构建我的项目? 它在MSDN page上进行了解释,但我无法弄清楚如何将其应用于上面列出的项目文件
解决方案2: 请参阅解决方案1 ,但它没有太大变化。
EDIT3: 经过几个小时的游戏,我想我将不得不放弃。我看到的唯一选择是减少一般的依赖性。但我稍后会再回来。
有点不相干:
> Task Performance Summary:
> 0 ms CreateItem 1 calls
> 0 ms AssignCulture 1 calls
> 0 ms CallTarget 2 calls
> 0 ms FindAppConfigFile 1 calls
> 0 ms Delete 4 calls
> 0 ms GetFrameworkPath 1 calls
> 0 ms ConvertToAbsolutePath 1 calls
> 0 ms MakeDir 1 calls
> 0 ms Message 5 calls
> 0 ms AssignTargetPath 6 calls
> 1 ms FindUnderPath 5 calls
> 1 ms FileClassifier 1 calls
> 1 ms RemoveDuplicates 2 calls
> 1 ms CreateCSharpManifestResourceName 1 calls
> 1 ms ReadLinesFromFile 1 calls
> 15 ms ResolveAssemblyReference 1 calls
> 21 ms ResourcesGenerator 1 calls
> 56 ms Copy 2 calls
> 299 ms GenerateTemporaryTargetAssembly 1 calls
> 502 ms Csc 2 calls
> 725 ms MarkupCompilePass1 1 calls
> 814 ms MarkupCompilePass2 1 calls
>
> Build succeeded.
> 0 Warning(s)
> 0 Error(s)
>
> Time Elapsed 00:00:02.27
答案 0 :(得分:3)
要回答你的直接问题,你无法做很多事情来加速msbuild。如果您的机器使用SSD,我希望它运行得更快,但这可能不是您正在寻找的那种解决方案。
我能想到的另一件事就是完全停止使用msbuild。它所做的就是驱动C#编译器。那么为什么要烦扰msbuild呢?只需直接使用C#编译器即可。例如,通过CSharpCodeProvider
。
答案 1 :(得分:0)
我可以建议的一个简单方法是通过提供MSBuild属性来利用处理器的多个核心,如下面的命令所示:
msbuild default.msbuild /m:1
我不确定/m
属性如何在内部生效。
修改强>
据我所知,线程发生在项目外部。解决方案中的多个项目将并行运行每个项目的一个线程。因此,您可能无法将其添加为项目选项。
但是,在另一个Hanselman link中,我发现了一个hack,可以将它整合到Visual Studio中,并与解决方案编译一起运行。请检查一下。
这里它添加了MSBuild作为外部工具来运行具有此属性的解决方案。