170 похожих чатов

Ребята, перевёл проект asp.net core 2.2 на dotnet 5.0. Сразу

столкнулся со снижением производительности всех API запросов в несколько раз! Подозрения падают на Dependency Injection. Используется встроенный IServiceCollection + AutoFac для расширенного функционала. Ниже три наблюдения:

1. Есть два разных класса DbContext. При инициализации обоих используются самописные DbConnectionOptionsReader, возвращающие connection string. Но для одного этот класс зареган как AddSingleton и простой запрос на этом DbContext (контекст.таблица.Count()) занимает 0.02 сек. На другом зареган как AddScoped и там такой же запрос занимает .25 сек - в 12 раз дольше! Если для эксперимента сделать второй тоже AddSingleton - то они начинают выполняться одинаково быстро

2. Создал новый dotnet 5.0 проект, скопипастил в него всё основное из первого проекта, чисто чтобы запустить тот же пример. Так вот пример отрабатывает одинаково быстро на обоих DbContext, независимо от того как зереганы их поставщики connection string - Singleton или Scoped. Это наводит на мысль, что скорость замедляют куча регистраций классов бизнес-логики в основном проекте. Или что-то другое.

3. После перевода на dotnet 5 проект иногда стал падать с ошибкой:

Autofac.Core.DependencyResolutionException: An exception was thrown while invoking the constructor 'Void .ctor(Microsoft.EntityFrameworkCore.DbContextOptions`1[EsDb.DbContextRo])' on type 'DbContextRo'.
---> System.InvalidOperationException: An error was generated for warning 'Microsoft.EntityFrameworkCore.Infrastructure.ManyServiceProvidersCreatedWarning': More than twenty 'IServiceProvider' instances have been created for internal use by Entity Framework. This is commonly caused by injection of a new singleton service instance into every DbContext instance. For example, calling 'UseLoggerFactory' passing in a new instance each time--see https://go.microsoft.com/fwlink/?linkid=869049 for more details. This may lead to performance issues, consider reviewing calls on 'DbContextOptionsBuilder' that may require new service providers to be built. This exception can be suppressed or logged by passing event ID 'CoreEventId.ManyServiceProvidersCreatedWarning' to the 'ConfigureWarnings' method in 'DbContext.OnConfiguring' or 'AddDbContext'.

Что опять же намекает на проблему с DI, но я не понимаю причины этой ошибки. Написано, что это может быть вызвано из-за этого что мы используем Singleton'ы при создании DbContext, Но ведь, насколько я знаю, Singleton как раз и следует использовать, в этом случае экземпляр создаётся один раз на запрос, что повышает производительность, нежели чем создавать экземпляр один раз AddScoped или AddTransient. Или это намёк что вообще ничего не стоит инжектить в DbContext?

13 ответов

5 просмотров

а энтити фреймворк где зареган? внутри автофака или мс ди?

Dmitry-B. Автор вопроса
Viktor Svyatokha
а энтити фреймворк где зареган? внутри автофака ил...

DbContext зареган на IServiceCollection ServiceCollection.AddDbContext(вызов_функции_резолвящей_DbConnectionOptionsReader) ServiceCollection.AddDbContextFactory(вызов_функции_резолвящей_DbConnectionOptionsReader) DbConnectionOptionsReader тоже зареган на IServiceCollection

Dmitry B.
DbContext зареган на IServiceCollection ServiceCol...

А перекинь его на автофак и попробуй; такое ощущение, что автофак где-то лишнее создает, судя по сообщению из ошибки

Dmitry-B. Автор вопроса
Viktor Svyatokha
А перекинь его на автофак и попробуй; такое ощущен...

попробовал зарегать в автофак (убрав регистрацию из IServiceColleciton) - никак не поменяло время выполнения

контекст ты как синглетон регаешь ?

Dmitry-B. Автор вопроса

А что профайлер говорит?

Dmitry-B. Автор вопроса
Иван
А что профайлер говорит?

не проясняет ситуации, просто замедление в несколько раз и всё тут

попробуй выпилить AutoFac

Dmitry-B. Автор вопроса
Arthur Irgashev
попробуй выпилить AutoFac

у нас весомая логика связана на его ILifetimeScope и ParentScope, малой кровью не отделаешься, так что это вариант лишь на перспективу

Проблемы очевидно в DI скоупах, думаю автофак обходит дефолтную валидацию и начинается цирк с зависимостями от неправильных лайфтаймов. Два варианта есть: выпилить автофак; выпилить инъекцию DbContext, заменить ее на фабрику, надеюсь она не используется как UnitOfWork. Быстрого решения проблемы нет.

Dmitry-B. Автор вопроса
βλαδιμιρ
Проблемы очевидно в DI скоупах, думаю автофак обхо...

вот ещё сравнение вызовов на проектах без проблемы и с проблемой. Как видно, всё одинаково до GetRequiredService, дальше уже начинается сильное расхождение

Похожие вопросы

Обсуждают сегодня

А чем вам питонисты не угодили?😂
.
79
Язык Си можно выучить за день? По книжке ANSI C на 230 страниц
Vincent Vegan
29
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
Dim Dim, [02.07.2024 11:07] DB 0x62 Dim Dim, [02.07.2024 11:07] DB 0x66 Dim Dim, [02.07.2024 11:07] кто пояснит что это?
Dim Dim
14
Ошибка: segmentation fault (core dumped) Код: pastebin.com/BEsNNSSV Сообщение от компилятора: отсутствует ОС: Arch Linux Ядро: x86_64 Linux 6.9.7-arch1-1 Процессор: Intel Cele...
sec
4
Ребят, а за скок можно впарить анон чат с апишкой и веб админкой ?
Eugene Неелов
15
Добрый день, чат. Мне в очередь из других RabbitMQ по shovel валятся метрики в формате текста для Prometheus. Помогите пожалуйста подружить RabbitMQ и Prometheus, чтобы он (...
Aleksey
4
@ahndmn @ayaw0_0 здарова, на чем пишете?
Aiwan \ (•◡•) / _bot
7
Кстати, я тут еще с одной темой столкнулся, вот учу я C++, на таком то ресурсе, а остальные постоянно советуют практиковаться, что то писать, проекты, но как писать если вот т...
aaswq1
7
Ещё такой вопрос. Мне необходимо хранить пароль пользователя локально. Для этого планирую использовать ini файл. Это для автозаполнения полей логин и пароль при авторизации. Е...
Евгений
19
Карта сайта