Полностью поддерживаю совет для новичков. Что не нужно пытаться выстраивать какую то "чистую архитектуру" не разобравшись с интсрументами. Сначала нужно поднабить шишек, попробовать сделать пару тройку проектиков. А затем уже можно попробовать применять те или иный концепции из мира проектирования ПО :)
@vector7932 Жыл бұрын
Tools -> Architecture diagram. Dependency rule (в юз кейса интерфейс IRepository) и Data flow (По интерфейсу обращаемся к DBRepository по интерефейсу) это просто абсолютно разные вещи. Юз кейсы не знают, что мы обращаемся именно к DB, поэтому депенденси рул не нарушается. А с точки зрения голых данных мы уходим в инфраструктуру. В общем тут лучше 1 пример, вместо 1000 слов. Ключевая проблема обсуждений архитектуры, много слов и правил и ни одного боевого примера) Спасибо за пример в этом видео
@Excalib Жыл бұрын
Спасибо, согласен, отлично замечание! (у меня эта диаграмма чуток по-другому называется) ibb.co/rHzrg6Q (моя диаграмма)
@vasinas81 Жыл бұрын
Работаю давно по такой схеме и такой архитектуре. Теперь на вопрос "зачем так сложно?" буду давать ссылку на это видео. Спасибо автору))
@МаксимВеснин-и6э10 ай бұрын
Спасибо тебе, друг! 8 лет разработки, но до меня не доходило до конца
@Excalib10 ай бұрын
Как я тебя понимаю:)))
@zmqpkyfАй бұрын
как по мне чистая архитектура тесно связана с ддд впринципе, отсюда выходит что слой enterprice это доменные модели, слой use cases служит в простонародье как application, все остальное уже (controllers, gateways, presenters) является слоем UI, все остальное это зависимости
@perwyj Жыл бұрын
Удивительно, что столь полезное видео, имеет так мало просмотров🤔 Спасибо большое за годный контент!
@Excalib Жыл бұрын
Спасибо!
@sergbo31146 ай бұрын
12:20 Ну это можно сказать проще. Вызывать и зависеть, это разные вещи. Например интрефейсы и DI по сути обрывают классовые зависимости, но оставляют вызовы.
@nouchance Жыл бұрын
Spasibo bratan ❤
@zdludz11 ай бұрын
Cпасибо большое за видео!! Можешь пожалуйста снять видео про библиотеку AutoMapper?
@Excalib11 ай бұрын
Думаю сниму)
@zdludz11 ай бұрын
@@Excalib спасибо большое!
@sergeysaviiskyi7329 Жыл бұрын
Мужик, спасибо большое! Одно из лучших объяснений на русском!
@НикитаКопылов-у9л Жыл бұрын
однозначно лайк, броу!
@Excalib Жыл бұрын
сяп!
@arvpro8970 Жыл бұрын
Добрый день. А где и как хранить фоновые службы? Например какая та очередь задач, скажем bull. Для каждой очереди свой процессор, который выполняет что-то. Как вызывать фоновые службы чтобы они начали работать и запускали use cases? Понятно с API вызов идет напрямую. А без вызова как?
@Excalib Жыл бұрын
Добрый! Не очень понимаю что такое хранить фоновые службы, я бы вообще делал фоновые службы как отдельный сервис или хотя бы запускаемый проект, просто чтоб было удобно масштабировать
@arvpro8970 Жыл бұрын
@@Excalib например мы кладем задачу отправки email, и отправка происходит воркером. Вот фоновый сервис
@clutchmeisteryo9831 Жыл бұрын
В каком слое хранить Dto и конфигурацию маппера?
@Excalib Жыл бұрын
Смотря для какого слоя созданы дто и для какого слоя созданы правила маппинга, например если Dto аля GetUserRequest, то такая dto создана для слоя UI, тогда эта дтоха будет лежать в UI слое в проекте Web, и конфигурация для маппинга этой сущности тоже там же, а если это бизнесовая дтоха например для маппинга из Application слоя в Domain, то хранится она должна в Application и конфигурация тоже
@scc-6 Жыл бұрын
Мне бы асп.Кор понять, для начала((
@СергейДовгалев-ц1щ Жыл бұрын
поймешь. Не все сразу.
@LAV4519 ай бұрын
Не уверен что интерфейс должен находится хрен знает где от свое реализации. Обычно разработчик пишет компонент и представляет интерфейс для всех желающих написать своё расширение. А теперь представь что ты в своём проекте написал какой-то интерфейс и предлагаешь разработчику стороннего проекта его имплеминтировать в своём проекте. Культурный просто промолчит, а я бы послал куда подальше. Вот компонент, вот интерфейс. Тебя ведь никто не заставляет его имплементировать, мы просто указываешь его в своих зависимостях. Короче, пересмотри ещё раз своё видео и обрати внимание на слои, зависимость между ними и как эта зависимость реализуется в коде. Дизлайк. Бред полный!
@Excalib9 ай бұрын
Спасибо, ваше мнение очень ценно!
@АлексейМиллер-щ7ч7 ай бұрын
тут скорее имеется в виду, что интерфейс определяет контракт для работы с ядром. Т.е. в ядре есть какая-то логика, и она допустим хочет уведомлять по почте, и она внешнему миру говорит, что я буду дергать кого-то кто на вход получит тело, тему, получателей. А далее в инфраструктуре реализуется некий отправлятор почты, который в свою очередь может использовать внешние компоненты с каким-то интерфейсом и реализация непосредственной отправки может меняться, но ядру приложения этого знать не надо, и свой интерфейс менять не надо.
@LAV4517 ай бұрын
Я ошибочно подогнал что если мы используем луковичную архитектуру то каждый слой представляет из себя самостоятельный модуль, но на практике оказалось что все слои объеденяются в модуль и логически связанны между собой.
@АлексейМиллер-щ7ч7 ай бұрын
Можно делить на dll, можно не делить. Я бы делил.
@Excalib7 ай бұрын
:D
@whisper399 Жыл бұрын
а просто тыкнуть в браузере перевести на русский не? а не объясняться пол видоса, что плохо знаешь английский
@Excalib Жыл бұрын
я просто русский тоже плохо знаю
@whisper399 Жыл бұрын
@@Excalib "смешно", ха-ха-ха
@xelaksal669010 ай бұрын
Зачем ты до человека доебался? Он тебе что-то сделал плохое? Более того он тебе видео снял, чтобы ты лучше разобрался, а ты неблагодарный токсичный чел. Не надо так. Если хочешь посоветовать или обратить внимание на что-то - делай это тактично. Иначе ты просто обесцениваешь весь видос и делаешь неприятно автору.