문제:
비동기 Entity Framework 데이터베이스 호출은 동기식 Entity Framework 데이터베이스 호출에 비해 성능이 상당히 느리며 실행 시간이 10배 증가하는 경우가 많습니다. 다음 예를 고려해보세요:
<code class="language-csharp">// Retrieve albums var albums = await this.context.Albums .Where(x => x.Artist.ID == artist.ID) .ToListAsync();</code>
근본 원인:
이 성능 문제는 EF 6 비동기 구현의 결함으로 인해 발생합니다. 이진 열이 포함된 테이블을 처리할 때 EF는 보다 효율적인 순차 액세스(CommandBehavior.SequentialAccess) 대신 비순차 데이터 검색(CommandBehavior.Default)을 잘못 사용합니다.
향후 EF 버전에서는 이 문제가 해결될 것으로 예상되지만 해결 방법은 TaskCompletionSource<T>
을 사용하여 비동기 메서드 내에서 동기 작업을 수동으로 래핑하는 것입니다. 이는 EF의 비효율적인 비동기 구현을 우회합니다.
비동기 Entity Framework 작업의 성능 저하는 비동기 프로그래밍에 내재된 것이 아니라 EF 6 구현의 특정 버그입니다. 수동 비동기 래퍼를 사용하면 이러한 성능 병목 현상을 효과적으로 완화하고 애플리케이션 응답성을 향상시킬 수 있습니다.
위 내용은 내 Entity Framework 비동기 작업이 동기 작업보다 10배 느린 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!