我有一个我正在处理的ASP.NET核心/ MVC核心应用程序,但是当我第一次将项目加载到Visual Studio中时,需要花费很长时间才能加载(20分钟)。
我不确定是什么导致了扩展加载时间,但它不是Visual Studio本身,因为其他项目加载速度更快,我很确定它与这个单独的项目有关,因为它曾经工作正常,并且我已经在另一台笔记本电脑上尝试过,它也花时间在那里。
我也尝试使用/ SafeMode开关启动Visual Studio,但这没有任何区别。
我正在使用Visual Studio 2015 Enterprise
以下是我的project.json的副本,以防有人可以识别它的潜在问题
{
"devDependencies": {
"gulp": "3.9.1"
},
"userSecretsId": "SP2017-5731e8a3-a3ec-4a25-bcb5-asdf2432hjk232",
"dependencies": {
"Microsoft.NETCore.App": {
"version": "1.0.1",
"type": "platform"
},
"Microsoft.ApplicationInsights.AspNetCore": "1.0.0",
"Microsoft.AspNetCore.Authentication.Cookies": "1.0.0",
"Microsoft.AspNetCore.Diagnostics": "1.0.0",
"Microsoft.AspNetCore.Diagnostics.EntityFrameworkCore": "1.0.0",
"Microsoft.AspNetCore.Identity.EntityFrameworkCore": "1.0.0",
"Microsoft.AspNetCore.Mvc": "1.0.1",
"Microsoft.AspNetCore.Razor.Tools": {
"version": "1.0.0-preview2-final",
"type": "build"
},
"Microsoft.AspNetCore.Routing": "1.0.1",
"Microsoft.AspNetCore.Server.IISIntegration": "1.0.0",
"Microsoft.AspNetCore.Server.Kestrel": "1.0.1",
"Microsoft.AspNetCore.StaticFiles": "1.0.0",
"MySql.Data.EntityFrameworkCore": "7.0.6-IR31",
"Microsoft.EntityFrameworkCore.SqlServer": "1.0.1",
"Microsoft.EntityFrameworkCore.SqlServer.Design": {
"version": "1.0.1",
"type": "build"
},
"Microsoft.EntityFrameworkCore.Tools": {
"version": "1.0.0-preview2-final",
"type": "build"
},
"Microsoft.Extensions.Configuration.EnvironmentVariables": "1.0.0",
"Microsoft.Extensions.Configuration.Json": "1.0.0",
"Microsoft.Extensions.Configuration.UserSecrets": "1.0.0",
"Microsoft.Extensions.Logging": "1.0.0",
"Microsoft.Extensions.Logging.Console": "1.0.0",
"Microsoft.Extensions.Logging.Debug": "1.0.0",
"Microsoft.Extensions.Options.ConfigurationExtensions": "1.0.0",
"Microsoft.VisualStudio.Web.BrowserLink.Loader": "14.0.0",
"Microsoft.VisualStudio.Web.CodeGeneration.Tools": {
"version": "1.0.0-preview2-final",
"type": "build"
},
"Microsoft.VisualStudio.Web.CodeGenerators.Mvc": {
"version": "1.0.0-preview2-final",
"type": "build"
},
"SendGrid.Core": "1.0.0",
"SendGrid.NetCore": "1.0.0-rtm-00002"
},
"tools": {
"BundlerMinifier.Core": "2.0.238",
"Microsoft.AspNetCore.Razor.Tools": "1.0.0-preview2-final",
"Microsoft.AspNetCore.Server.IISIntegration.Tools": "1.0.0-preview2-final",
"Microsoft.EntityFrameworkCore.Tools": "1.0.0-preview2-final",
"Microsoft.Extensions.SecretManager.Tools": "1.0.0-preview2-final",
"Microsoft.VisualStudio.Web.CodeGeneration.Tools": {
"version": "1.0.0-preview2-final",
"imports": [
"portable-net45+win8"
]
}
},
"frameworks": {
"netcoreapp1.0": {
"imports": [
"dotnet5.6",
"portable-net45+win8"
]
}
},
"buildOptions": {
"emitEntryPoint": true,
"preserveCompilationContext": true
},
"runtimeOptions": {
"configProperties": {
"System.GC.Server": true
}
},
"publishOptions": {
"include": [
"Areas/**/*.cshtml",
"wwwroot",
"**/*.cshtml",
"appsettings.json",
"appsettings.production.json",
"web.config",
"project.json"
]
},
"scripts": {
"prepublish": [ "bower install", "dotnet bundle" ],
"postpublish": [ "dotnet publish-iis --publish-folder %publish:OutputPath% --framework %publish:FullTargetFramework%" ]
}
}
编辑12 / Jan / 17 00:30 GMT:
我还应该提一下,我已经完成了将其关闭并再次打开的最爱!
这是我的project.json文件的更新副本
{
"devDependencies": {
"gulp": "3.9.1"
},
"userSecretsId": "SP2017-5731e8a3-a3ec-4a25-bcb5-asdf2432hjk232",
"dependencies": {
"Microsoft.NETCore.App": "1.1.0",
"Microsoft.AspNetCore.Razor.Tools": {
"version": "1.0.0-preview2-final",
"type": "build"
},
"Pomelo.EntityFrameworkCore.MySql": "1.1.0",
"Microsoft.EntityFrameworkCore.Tools": {
"version": "1.1.0-preview4-final",
"type": "build"
},
"Microsoft.VisualStudio.Web.CodeGeneration.Tools": {
"version": "1.0.0-preview2-final",
"type": "build"
},
"Microsoft.VisualStudio.Web.CodeGenerators.Mvc": {
"version": "1.0.0-preview2-final",
"type": "build"
},
"SendGrid.Core": "1.0.0",
"SendGrid.NetCore": "1.0.0-rtm-00002",
"BundlerMinifier.Core": "2.2.306",
"Microsoft.ApplicationInsights.AspNetCore": "1.0.2",
"Microsoft.AspNetCore.Authentication.Cookies": "1.1.0",
"Microsoft.AspNetCore.Diagnostics": "1.1.0",
"Microsoft.AspNetCore.Diagnostics.EntityFrameworkCore": "1.1.0",
"Microsoft.AspNetCore.Identity.EntityFrameworkCore": "1.1.0",
"Microsoft.AspNetCore.Mvc": "1.1.0",
"Microsoft.AspNetCore.Routing": "1.1.0",
"Microsoft.AspNetCore.Server.IISIntegration": "1.1.0",
"Microsoft.AspNetCore.Server.Kestrel": "1.1.0",
"Microsoft.AspNetCore.StaticFiles": "1.1.0",
"Microsoft.EntityFrameworkCore.SqlServer": "1.1.0",
"Microsoft.EntityFrameworkCore.SqlServer.Design": "1.1.0",
"Microsoft.Extensions.Configuration.EnvironmentVariables": "1.1.0",
"Microsoft.Extensions.Configuration.Json": "1.1.0",
"Microsoft.Extensions.Configuration.UserSecrets": "1.1.0",
"Microsoft.Extensions.Logging": "1.1.0",
"Microsoft.Extensions.Logging.Console": "1.1.0",
"Microsoft.Extensions.Logging.Debug": "1.1.0",
"Microsoft.Extensions.Options.ConfigurationExtensions": "1.1.0",
"Microsoft.VisualStudio.Web.BrowserLink.Loader": "14.1.0"
},
"tools": {
"Microsoft.AspNetCore.Razor.Tools": "1.0.0-preview2-final",
"Microsoft.AspNetCore.Server.IISIntegration.Tools": "1.0.0-preview2-final",
"Microsoft.EntityFrameworkCore.Tools": "1.0.0-preview2-final",
"Microsoft.Extensions.SecretManager.Tools": "1.0.0-preview2-final",
"Microsoft.VisualStudio.Web.CodeGeneration.Tools": {
"version": "1.0.0-preview2-final",
"imports": [
"portable-net45+win8"
]
}
},
"frameworks": {
"netcoreapp1.1": {
"dependencies": {
"Microsoft.NETCore.App": {
"type": "platform",
"version": "1.1.0"
}
},
"imports": "dnxcore50"
}
},
"buildOptions": {
"emitEntryPoint": true,
"preserveCompilationContext": true
},
"runtimeOptions": {
"configProperties": {
"System.GC.Server": true
}
},
"runtimes": {
"win10-64": {}
},
"publishOptions": {
"include": [
"Areas/**/*.cshtml",
"wwwroot",
"**/*.cshtml",
"appsettings.json",
"appsettings.production.json",
"web.config",
"project.json"
]
},
"scripts": {
"prepublish": [ "bower install", "dotnet bundle" ],
"postpublish": [ "dotnet publish-iis --publish-folder %publish:OutputPath% --framework %publish:FullTargetFramework%" ]
}
}
我想我可能会找出原因,但不知道如何解决它。
我依稀记得在添加一些bower依赖项后得到问题,这可能是原因(我已经尝试删除所有的bower依赖项
我的bower.json文件目前看起来像
{
"name": "asp.net",
"private": true,
"dependencies": {
"bootstrap": "3.3.6",
"jquery": "2.2.0",
"jquery-validation": "1.14.0",
"jquery-validation-unobtrusive": "3.2.6",
"font-awesome": "4.6.1",
"admin-lte": "*",
"material-design-icons": "2.2.3",
"startbootstrap-creative": "3.3.7"
}
}
我刚刚将其添加到我的新模板化解决方案中,并且包恢复正在花费时间。所以我想知道Visual Studio是否将打开恢复功能称为打开解决方案的一部分?
答案 0 :(得分:0)
这是一个可行的建议。
我建议将.netcore更新为1.1,因为1.0存在许多问题 通过在nuget控制台Install-Package Microsoft.NETCore.App
中运行它另一个问题可能是您正在加载失败或无法正常工作的依赖项。
例如,它可能正在加载您的发送网格,并且发送网格非常慢,这可能是原因。
尝试运行一个非常简单的应用程序,没有任何依赖关系,看看你是否得到相同的结果。
答案 1 :(得分:0)
如果您有Resharper,请尝试从VS选项菜单中暂停它,看看会发生什么。我还在使用Resharper激活的asp.net核心项目加载时间更长。使用暂停的Resharper,解决方案加载速度足够快
答案 2 :(得分:0)
如果这些不是最新的,请尝试这些更新
将您的visual studio
更新为最新的Visual Studio Update 3
将您的Visual Studio 2015 Tools
更新为最新的当前视觉效果
Studio 2015 Tools (Preview 2)
.NET Core
更新为最新的当前.NET Core 1.1 SDK
然后更新您的项目以使用最新的.Net Core SDK
作为描述here
并且还会更新nuget
中的所有包。
答案 3 :(得分:0)
事实证明,罪魁祸首实际上是在凉亭依赖中并且是
"material-design-icons": "2.2.3"
从我的bower.json文件中删除它(并从相应的wwwroot / lib文件夹中删除)之后,我的解决方案现在大约在10-15秒内加载(比20分钟快得多)。
出于兴趣,我创建了一个新的(非VS / asp.net核心文件夹),运行 bower cache clear 然后 bower.init ,然后运行 bower install material-design-icons ,仅需10分钟即可安装此1个包/依赖
原来这个软件包是43.7MB(磁盘上81.5MB),这不是我的网速(16ms ping,104.5Mbps下载,6.3Mbps上传)