我似乎找不到这个问题的答案。
因此,在用户加载页面的前端,我们为该页面上的每个项目调用API(10个项目)。这等于10个API调用。
大多数调用都有效,但在尝试查询数据库时总会有一些调用失败,导致以下错误:
InvalidOperationException:对此启动了第二个操作 上一次操作完成前的上下文。任何实例成员 不保证是线程安全的。
现在我明白Entity Framework不是线程安全的,但我不确定如何解决这个错误。
我使用DBContext的地方总是使用内置的.net核心Ioc容器注入。
这是DI设置
services.AddScoped<IOmbiContext, OmbiContext>();
services.AddTransient<ISettingsRepository, SettingsJsonRepository>();
根据本文,我的所有存储库都设置在Transient
范围内,上下文为Scoped
:https://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
}
答案 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
}
}