我在 ASP.Net MVC 5 应用程序中遇到异步控制器问题。
我正在使用 Entity Framework 6 Code First 方法。
我有一个方法
public async Task<ActionResult> Index()
{
using(var context = new MyDbContext())
{
var eventsTask = context.Events
.Where(e => e.Enable)
.ToListAsync();
var countTask = context.Users
.CountAsync();
await Task.WhenAll(eventsTask, countTask);
return View(new ViewModel()
{
Events = eventsTask.Result,
Count = countTask.Result
});
}
}
我这里有两个异步方法。我通过 MiniProfiler 分别测量了它们中的每一个。它们大约需要 85 毫秒。
但在我的方法中,我使用 Task.WhenAll() 运行它们。我相信它异步执行 Db 查询,并且两者都应该花费大约 85-90 毫秒。但需要~170-180。所以我让异步方法同步运行(相互跟随)。
我认为这是因为上下文。我有一个测试,当我删除上下文查询并使用 HttpClient 调用许多 api 方法时。它需要的时间等于其中更长的时间(3 个 api 调用,每个大约 500 毫秒。总共方法需要大约 600 毫秒)。我相信异步执行 EF 方法是可能的。
有谁知道解决办法
这实际上不应该起作用,而是抛出异常。我猜第一个查询在第二个查询开始之前就完成了。
EF6 不支持同一上下文上的多个异步操作。 https://stackoverflow.com/questions/24702183/does-entity-framework-support-parallel-async-queries
Either await
每个查询(因此它们不会同时运行),或者为每个查询使用不同的上下文。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)