EF Core多个HTTP请求引发错误

时间:2017-08-25 12:42:50

标签: c# .net entity-framework asp.net-core entity-framework-core

我似乎找不到这个问题的答案。

因此,在用户加载页面的前端,我们为该页面上的每个项目调用API(10个项目)。这等于10个API调用。

大多数调用都有效,但在尝试查询数据库时总会有一些调用失败,导致以下错误:

  

InvalidOperationException:对此启动了第二个操作   上一次操作完成前的上下文。任何实例成员   不保证是线程安全的。

现在我明白Entity Framework不是线程安全的,但我不确定如何解决这个错误。

我使用DBContext的地方总是使用内置的.net核心Ioc容器注入。

这是DI设置

services.AddScoped<IOmbiContext, OmbiContext>();
services.AddTransient<ISettingsRepository, SettingsJsonRepository>();

根据本文,我的所有存储库都设置在Transient范围内,上下文为Scopedhttps://docs.microsoft.com/en-us/aspnet/core/data/entity-framework-6

现在我尝试将上下文更改为Transient,但仍然会发生。

我该如何避免这种情况?

更多信息

API方法:

[HttpGet("movie/info/{theMovieDbId}")]
public async Task<SearchMovieViewModel> GetExtraMovieInfo(int theMovieDbId)
{
    return await MovieEngine.LookupImdbInformation(theMovieDbId);
}

最终调用以下引发异常的地方:

public async Task<RuleResult> Execute(SearchViewModel obj)
{
    var item = await PlexContentRepository.Get(obj.CustomId); <-- Here
    if (item != null)
    {
        obj.Available = true;
        obj.PlexUrl = item.Url;
        obj.Quality = item.Quality;
    }
    return Success();
}

PlexContentRepository

public PlexContentRepository(IOmbiContext db)
{
    Db = db;
}

private IOmbiContext Db { get; }
public async Task<PlexContent> Get(string providerId)
{
   return await Db.PlexContent.FirstOrDefaultAsync(x => x.ProviderId == providerId); <-- Here
}

1 个答案:

答案 0 :(得分:-2)

如果您通常使用Entity Framework Core,则无需将数据库上下文添加为附加服务

我建议您在Startup.cs中设置DbContext,如下所示:

services.AddEntityFrameworkSqlServer()
            .AddDbContext<OmbiContext>();

接下来是API调用的Controller类,将DBContext作为构造函数参数。

public class ApiController : Controller
{
    protected OmbiContext ctx;
    public ApiController(OmbiContext dbctx)
    {
        ctx = dbctx;
    }

    public async Task<IActionResult> yourAsyncAction()
    {
        // access ctx here
    }
}