Entity Framework Core: uma segunda operação iniciada neste contexto antes de uma operação anterior ser concluída
Estou trabalhando em um projeto do ASP.Net Core 2.0 usando o Entity Framework Core
<PackageReference Include="Microsoft.EntityFrameworkCore" Version="2.0.1" />
<PackageReference Include="Microsoft.EntityFrameworkCore.Tools" Version="2.0.0" PrivateAssets="All" />
<PackageReference Include="Microsoft.EntityFrameworkCore.Design" Version="2.0.0"/>
E em um dos meus métodos de lista, estou recebendo este erro:
InvalidOperationException: A second operation started on this context before a previous operation completed. Any instance members are not guaranteed to be thread safe.
Microsoft.EntityFrameworkCore.Internal.ConcurrencyDetector.EnterCriticalSection()
Este é o meu método:
[HttpGet("{currentPage}/{pageSize}/")]
[HttpGet("{currentPage}/{pageSize}/{search}")]
public ListResponseVM<ClientVM> GetClients([FromRoute] int currentPage, int pageSize, string search)
{
var resp = new ListResponseVM<ClientVM>();
var items = _context.Clients
.Include(i => i.Contacts)
.Include(i => i.Addresses)
.Include("ClientObjectives.Objective")
.Include(i => i.Urls)
.Include(i => i.Users)
.Where(p => string.IsNullOrEmpty(search) || p.CompanyName.Contains(search))
.OrderBy(p => p.CompanyName)
.ToPagedList(pageSize, currentPage);
resp.NumberOfPages = items.TotalPage;
foreach (var item in items)
{
var client = _mapper.Map<ClientVM>(item);
client.Addresses = new List<AddressVM>();
foreach (var addr in item.Addresses)
{
var address = _mapper.Map<AddressVM>(addr);
address.CountryCode = addr.CountryId;
client.Addresses.Add(address);
}
client.Contacts = item.Contacts.Select(p => _mapper.Map<ContactVM>(p)).ToList();
client.Urls = item.Urls.Select(p => _mapper.Map<ClientUrlVM>(p)).ToList();
client.Objectives = item.Objectives.Select(p => _mapper.Map<ObjectiveVM>(p)).ToList();
resp.Items.Add(client);
}
return resp;
}
Estou um pouco perdido, especialmente porque funciona quando o executo localmente, mas quando implanto no servidor de armazenamento temporário (IIS 8.5) ele recebe esse erro e estava funcionando normalmente. O erro começou a aparecer depois que eu aumentava o comprimento máximo de um dos meus modelos. Também atualizei o comprimento máximo do modelo de exibição correspondente. E existem muitos outros métodos de lista que são muito semelhantes e estão funcionando.
Eu tinha um trabalho do Hangfire em execução, mas esse trabalho não usa a mesma entidade. É tudo o que posso considerar relevante. Alguma idéia do que poderia estar causando isso?