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

Всем привет! попробую обрисовать проблему. У меня есть легаси код.

web-api net core. В DI контейнере настраивается жизненных цикл объектов в том числе и объекта UoW который в себе хранит EF контекст. этот UoW реализует dispose метод ,который выставляет null внутреннему полю тип, которого EF контекст, и так же диспойзит его. То есть есть UoW объект, который реализует IDisposable. этот UoW объект передается в конструктор контроллера. в DI контейнере этот UoW объект зареган в Scoped жизнненом цикле. НООО в методе контролера два действия! 1) выполнить какие-то преобразования и сохранить это в БД через объект UoW и его Method1() , а перед этим создается ОТДЕЛЬНЫЙ ПОТОК в который передается тот же самый UoW объект, который выполняет длительную операцию (около нескольких минут) по принципу запустил и забыл в Method2() и в самом конце этого метода дергается контекст EF и пытается сохранить что-то в бд. Как ни трудно догадаться в итоге в Method2() возникает Null ref exception тк контейнер DI вызвал Dispose у объекта UoW. Я почти уверен, что в такой ситуации нельзя дергать в другом потоке объекты жизненных цикл которых настраивается для другой цели и задачи. Но тогда как лучше поступить? Но я могу ошибаться, для того и пишу вопрос. Из решений на ум приходит только создание отдельного сервиса, который будет слушать поступление новых команд на выполнение какого либо запроса (quartz, hangfire) и выполнять ту самую операцию которая лежит в Method2(), а в методе контроллера где дергался Method1() написать что-то вроде отправки команды на выполнение работы в Method2()

8 ответов

10 просмотров

на ум пришло верное решение, так и делайте. наследуете IHostedService, запускаете таску со стартом приложения и пуляете в нее Items для обработки.

_Д_- Автор вопроса
Ivan Konstantinov
на ум пришло верное решение, так и делайте. наслед...

То есть в асп нет коре есть фоновые сервисы которые слушают входящую очередь сообщений? прикольно! звучит как то что нужно! спасибо

_Д_
То есть в асп нет коре есть фоновые сервисы которы...

Оно не слушает входящую очередь по дефолту — это надо ручками написать. Но фоновые задачи есть, да.

_Д_- Автор вопроса
Ivan Konstantinov
Оно не слушает входящую очередь по дефолту — это н...

но сам факт, что можно дернуть из моего родительского метод апи этого фонового сервиса положив туда сериализованный объект над которым надо попотеть ему?

_Д_
но сам факт, что можно дернуть из моего родительск...

ога, так можно. но тут еще другой вопрос сразу учтите: 1. метод контроллера отработал и положил в очередь Item 2. в очереди уже N item-ов 3. приложение выключили (свет потух, сервак в ребут, и т.д.) что делать с объектами, которые были в очереди, но не успели обработаться?

_Д_- Автор вопроса
Ivan Konstantinov
ога, так можно. но тут еще другой вопрос сразу уч...

ну лично я бы записывал в персистентное хранилище команду на обработку вторым фоновым процессом. но это уже детали.

_Д_
ну лично я бы записывал в персистентное хранилище ...

ну просто продумайте этот момент, а так все правильно думаете — фоновый сервис и обработка отдельно от метода контроллера.

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

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

А как старый хаскел с новым стыковать ? потому как тут работает https://play.haskell.org/saved/C3xpMzcd, а вот тут https://stepik.org/lesson/7602/step/9?unit=1473 нет ошибка C...
Fedor
131
что насчет пагинга? на осдеве непонятно(
Vi Chapmann 🪙
26
Вопрос я правильно понимаю что в коде newtype ArrowMap k v = ArrowMap { getArrowMap :: k -> Maybe v } getArrowMap есть функция типа k -> Maybe v, если да, то не понимаю задач...
Fedor
64
Ребят, что лучше для реверса: гидра или ида?
En Vind Av Sorg
26
Делаю велосипед логгер. К сообщению хочу прикрутить некоторую информацию, типа, кем отправлено, какой уровень, и всякое такое. И тут подумалось мне, почему бы не хранить весь...
Serjone
24
Как Вы считаете нормально ли в двадцатых годах 21 века в ВУЗах Российской Федерации обучать студентов работе с TASM? Не слишком ли это "архаично"? (Если оффтоп или флейм для э...
Spiker01
52
Комрады, хотел уточнить. Проперть в OnDestroy юнита-хозяина по-прежнему доступна? И еще уточнение: finalization юнита наступает раньше или позже OnDestroy?
Ed Doc
48
Продолжая диалог про свифт в проде – сейчас возник вопрос в активном наборе бекендеров. В основном в нашей компании мы фанаты Java Spring и полностью ей довольны. Однако найм ...
Guseyn
27
если загрузчик efi? если сама PML4 PDPT PDT PT лежит в неудобном для меня месте?
Vi Chapmann 🪙
8
Читаю сейчас [нет, уже больше не читаю!] курсовую о Булгакове, написанную, похоже, с помощью ChatGPT. Это удивительный психоделический опыт. Текст в основном написан в стиле б...
✨ Uni [🌊 В отпуске]
1
Карта сайта