Сценарии и проблемы

Версия 1.15 от Alexandr Fokin на 2024/01/04 19:19

Создание нескольких IServiceProvider.
Singleton.
  • Из одного набора IServiceCollection может быть создано несколько объектов IServiceProvider. Но у каждого из них будет свое управление и scope.
    Например если создать 2 экземпляра IServiceProvider, и от каждого из них запросить по одному ISingletonService, то мы получим 2 разных экземпляра ISingletonService.
  • Это может вызвать проблемы так, как обычно IServiceProvider формируется внутри фреймворка.
    Если самостоятельно создать экземпляр IServiceProvider, то получаем отдельное пространство и кривые объекты ISingletonService.
    (Например, если некоторые зависимости необходимы в самом процессе регистрации основного контейнера, конфигурации IServiceCollection)
    Также проблема может усугубиться, если самостоятельно созданный IServiceProvider в некоторых местах выступит в роли Factory/ServiceLocator.
  • Остро эта проблема проявляется для таких ISingletonService, у которых есть свое изменяемое состояние.
Валидация при сборке Di контейнера.services.BuildServiceProvider(
   new ServiceProviderOptions()
    {
        ValidateOnBuild = true,
        ValidateScopes = true
    }
    );