Тёмный

Clean Architecture на примере. Доступно и без кода 

StringConcat
Подписаться 1,8 тыс.
Просмотров 17 тыс.
50% 1

☝ Поваренная книга дядюшки боба: Как готовить Clean Architecture:
🎓 Курс : howto.stringconcat.ru/cleanar...
🎓 Разработка Приложений без Боли и Сожалений:
howto.stringconcat.ru/enterpr...
Подписывайся на
📧 Телеграмм-канал: t.me/stringconcat

Наука

Опубликовано:

 

22 апр 2023

Поделиться:

Ссылка:

Скачать:

Готовим ссылку...

Добавить в:

Мой плейлист
Посмотреть позже
Комментарии : 54   
@_Al_Kuznec
@_Al_Kuznec 11 месяцев назад
Ничего не поняла,что хотел сказать((( По дяде Бобу должно быть несколько конц.кругов. А где они здесь? Здесь все в куче по центру. почему и зачем не понятно((
@t0digital
@t0digital Год назад
Пуши на голубях и кофейная гуща вместо бюро кредитных историй это хорошооо😂 Рад новому отличному каналу!
@knowledgedose1956
@knowledgedose1956 5 месяцев назад
о, Алексей, доброго времени суток🖖🏻
@shortyshort183
@shortyshort183 2 месяца назад
Супер. Никак не мог структурировать правильно интерфейсы и классы. Спасибо огромное
@user-zd6di5mq9z
@user-zd6di5mq9z Год назад
Интересная серия роликов про архитектуру. Спасибо, с меня подписка.
@stringconcat
@stringconcat Год назад
Вам спасибо за интерес!
@paulkasler2173
@paulkasler2173 Год назад
Лайк поставлю, потом посмотрю , о чем то умном говорят
@burialstance
@burialstance 9 месяцев назад
😂
@meteysh
@meteysh 2 месяца назад
Охапка дров и плов готов 😂, молодец, круто объяснил. Спасибо! 🎉
@andreypozin8048
@andreypozin8048 11 месяцев назад
Дружище...почитай заново схему Дади Боба...и посмотри внимательно где находятся UseCases
@user-cc9lq6un4b
@user-cc9lq6un4b 6 месяцев назад
А почему application business layer не является отдельным сервисом? Просто сперва вы выносили Data access layer в отдельный кружок, а потом App layer как обертку бизнес логики. Как действовать, есди у меня есть приложение и сайт и у них слегка разная логика? Делать два сервиса: syte и application, которые зависят от контрактов сервиса с бизнес логикой?
@aleksandrkokin6065
@aleksandrkokin6065 Год назад
Поясните пожалуйста, если я не буду использовать Application слой, то API плагин взаимодействует напрямую с use cases? И хотелось бы поподробнее узнать про use кейсы, можно ли их называть сервисами?
@stringconcat
@stringconcat Год назад
В принципе, да у UseCase и традиционных Сервисов примерно одна и та же цель -- описывать верхнеуровнейвый бизнес-процесс. Поэтому и реализация у них очень похожа. Едиснтвенная проблема с сервисами -- зачастую они содержат несколько слабосвязных методов. Тоесть вырастает coupling на пустом месте. если я не буду использовать Application слой, то API плагин взаимодействует напрямую с use cases. Вот это не очень понял. Имеете ввиду Application Business Rules слой?
@user-ob9hg8cw1o
@user-ob9hg8cw1o Год назад
@@stringconcat Да, Application Business Rules слой
@Lapteuh
@Lapteuh Год назад
Спасибо большое! У меня пара вопросов: 1) Что делать с транзитивными зависимостями? Можно ли минуя app biz rules импортировать интерфейсы? У сложилось мнение, что так делать нельзя. Хотелось бы ваше мнение услышать. 2) Нужны ли интерфейсы в use case, если можно сразу данные передать, а вернуть события?
@stringconcat
@stringconcat Год назад
Отличные вопросы! Спасибо! 1) нет, так делать нельзя. Ибо в этом случае плагин API будет ссылаться на плагин Data Access. Но! иногда, к примеру для отчетов или еще какой тяжелой аналитики нужно выгрузить несколько тысяч записей из БД, и сделать это быстро. И столько конвертаций может быть делать накладно. Поэтому можно использовать CQRS паттерн. Но я бы в этом случае сделал отдельный модуль, независящий он Clean Architecture, скажем Analytics и в нем бы реализовал работу с хранилищем напрямую. Только стоит помнить, что у этого подхода много минусов в maintainability, главный из которых: как не дать другим разрабочтикам использовать этот шорткат, когда им захочется. Ну и конечно в начале стоит провести tradeoff анализ, чтобы понять что вы получаете и чем жертвуете. 2) Лучше чтобы интерфейсы были, в этом случае вы сможете протестировать контролеры в изоляции от бизнес-логики даже без использования моков, а просто подсунув фейковую имплементацию, ну скажем лямбду.
@serhiiboiko8957
@serhiiboiko8957 Год назад
Здравствуйте! Расскажите пожалуйста как совмещать Clean Architecture с Microservice Architecture, если это возможно. Каждый микросервис отдельно разрабатывать как Clean Architecture? Или например Core Business Rules вынести в отдельную сборку, которая будет использоваться всеми микросервисами? А Application Business Rules делать для каждого микросепрвиса свои.
@stringconcat
@stringconcat Год назад
Если кратко, то каждый микросервис -- это отдельное приложение, каждый микросервис может быть написан на разных языках и иметь разные архитектуры внутри. В том числе и Clean Architecture. На мой взгляд если вы переиспользуете business rules, то скорее всего вы разбили приложение на микросервисы не оптимально, и они тесно связаны (coupled) друг с другом. Лучше всего микросервисы разбивать по bounded Context. Один микросервис -- один Context. А один контекст -- один набор бизнес правил. Если вы смотрите на микросеривисы и видите что лучше бы вынести ядро, то я бы порекомендовал подумать над тем, а не слить ли эти микросервисы в один. Я допускаю что можно сделать библиотеку, куда вынести какие-то совсем общие типы, к примеру Count, Money и пр. Но Это все же не ядро. Спасибо за вопрос. Постараюсь записать видео на эту тему!
@serhiiboiko8957
@serhiiboiko8957 Год назад
@@stringconcat спасибо за Ваш ответ. Если можно, то хочу ещё спросить. В чистой архитектуре есть инфраструктурный слой. На сколько я понял он отвечает за работу с базами данных. С Redis. С брокерами сообщений. В Вашей схеме это Right Side. В микросервисной архитектуре есть гейтвей, который не работает напрямую с базами данных. Но он ведь тоже может быть разработан на основе чистой архитектуры. Будет ли в нём присутствовать инфраструктурный слой? Думаю что да, но отвечать он уже будет за работу с микросервисами, а не с базами данных. Правильно ли я понимаю? То же самое относится к клиентским приложениям, которые взаимодействуют со шлюзом. Инфраструктурный слой этих приложений будет отвечать за работу со шлюзом. Правильно?
@stringconcat
@stringconcat Год назад
@@serhiiboiko8957 Да, вы все правильно говорите, в случае gateway (или BFF) правые плагины будут, скажем REST клиентами к вашим микросервисам. Но, мне кажется что если BFF требует чистую архитектуру, то возможно в него попало слишком много бизнес правил. А это зачастую считается антипаттерном.
@serhiiboiko8957
@serhiiboiko8957 Год назад
@@stringconcat в моём понимании BFF является интерфейсом между клиентом и разными бизнес логиками, которые реализованы на разных микросервисах и могут предоставлять информацию в рамках своей ответственности, но BFF может консолидировать эту информацию и отдавать клиенту одним пакетом. Т.е. бизнес логика BFF сводится к консолидации полученной от микросервисов информации. Получается, что для такого случая лучне использовать Layered Architecture? Я правильно понимаю? А для клиентского приложения? Если это толстый клиент с какой-то своей бизнес логикой (например какие-то расчёты, которые выгоднее делать на клиенте чам гонять по сетке), то наверное лучше использовать Clean или Hexagonal архитектуру. А если это веб приложение и вся бизнес логика на серверах, то наверное тоже лучше использовать Layered Architecture? Я правильно понимаю? Или для таких случаев есть ещё какая-то архитектура?
@stringconcat
@stringconcat Год назад
​@@serhiiboiko8957 я ба наверное вот как определил необходимость использование CA или Hexagonal: Если в приложении есть бизнес-логика (вот прям доменная сложность), то лучше использовать CA или Hexagonal. Теперь про BFF. я встречал 2 варианта 1. Нам нужно запросить данные из микросервиса 1, и из микросервиса 2. Скомпоновать их и отдать клиенту. В этом случае я бы не разделял даже на слои, одни и те же DTO используются чтобы получить ответ от микросервисов и отдать его клиенту. Или даже map'ы, чтобы при добавлении нового поля в микросервис не сильно заморачиваться с BFF. 2. Появляются зачатки логики: Мне нужно запросить данные из микросервиса 1, и если данные содержат X, то запросить из микросервиса 2, а если Y, то из микросервиса 3. А если содержат Z, то вообще спрятать это поле. И это уже похоже на вполне себе бизнес-логику, и в этом случае да, я бы использовал CA или Hexagonal. Но на мой взгляд это запах того, что наш BFF становится слишком умным и через пол годика будет содержать очень внушительную порцию бизнес-логики. А этого бы нам хотелось избежать
@evgenasd8892
@evgenasd8892 9 месяцев назад
Да ролик понравился! А теперь попросить хочу снять о разработке через приемочное тестирование (только пример брать не правила переключения сигналов светофора, а что нибуль другое, на ваш выбор). Так называемое Atdd. В каком случае нужен приемочный тест а в каком переходим к юнит тесту, разобрать разницу, Спасибо.
@user-ob9hg8cw1o
@user-ob9hg8cw1o Год назад
это превосходно, спасибо
@channel-yg2xc
@channel-yg2xc 4 месяца назад
Спасибо за видео, интересная тема. Могли бы вы уточнить один момент: если у сегмента с бизнес-логикой в большинстве своём нет интерфейсов, может ли это быть нарушением чистой/гексагональной архитектуры при условии, что предметная область декомпозирована нормально и её реализация соответствует практикам low coupling & high cohesion? Просто складывается впечатление, что чуть ли не основной идеей описанных архитектурных подходов является выделение интерфейсов даже там, где это, казалось бы, смысла не имеет. Например, не понятна польза от интерфейсов для рядовых crud-операций или даже core бизнес логики, если в настоящее время существует единая реализация конкретного процесса, - на мой взгляд, наличие интерфейсов с единой реализацией скорее привносит сложность в проект, к тому же, если у процесса единая реализация, возникает сложность с наименованием интерфейсов и имплементаций, вроде BuisnessProcess и BuisnessProcessImpl.
@stringconcat
@stringconcat 4 месяца назад
Очень хороший вопрос! На все подряд конечно интерфейсы плодить не надо. Я выработал 2 принципа: 1) Интерфейс нужен когда нужно перепрыгнуть из внутреннего круга во внешний. Ну к примеру, если нужно вызвать хранилище из слоя Бизнес логики. Там же без интерфейса не получится, иначе Бизнесу придется зависить от слоя доступа к данным 2) Когда нам нужно несколько реализаций. При этом тесты считаются здесь тоже. К примеру у вас есть какая-то жутко сложная вычислялка процента в бизнес-логике, которая его вычисляет по многим параметрам, включая фазу Луны и индекс Доу-джонса. А вы тестируете, к примеру как вы письмо клиенту составляете автоматически, и вот эту вычислялку задействуете. Но вам абсолютно все равно какое значение она вернет. хоть 0, хоть 100500. И вот в этом случае имеет смысл заменить ее на Fake Implementation. Которая, скажем, всегда будет возвращать 15%
@herbslife-miscusi
@herbslife-miscusi Год назад
Спасибо! теперь лучше понимаю. Сам интуитивно продвигал\стоил по тем же принципам) но без четкой понятийной базы и защищать эти решения было сложно. btw, а что за программа на планшете? что за планшет?)
@stringconcat
@stringconcat Год назад
Да, понимаю, огромная проблема донести виденье для разработчиков и установить правила игры :) это ipad air последний и стандартные notes.
@donpedro2125
@donpedro2125 Месяц назад
"Миша, Вве херня, давай по новой" (с)
@bubbletubbe
@bubbletubbe 7 месяцев назад
вроде как плагины реализуют интерфейсы которые в ядре БЛ, получается что они 'одноразовые' и в другой проект их не вытащить без куска БЛ ... ну такоэ
@MrArcsinus
@MrArcsinus Год назад
По-моему, пропущен еще один важный компонент приложения: тот, в котором создадутся все инстансы юзкейсов, инстансы реализаций интерфейсов и прочие конфиги безопасности. Там где-то будет public static void main, если это Spring boot , например. И ему придется зависит от всех модулей
@stringconcat
@stringconcat Год назад
Да, дейтсвительно я его не упомянул. Сидел, смотрел на диаграмму и подумал: нет, если я сюда намалюю еще один слой, который связывает все плагины и core вместе, то всех запутаю :) придется еще один ролик выпускать. Спасибо что подсветили!
@ivan_xalie
@ivan_xalie Год назад
Если я правильно понял - то это реализация уровня (слоя?) API.
@MrArcsinus
@MrArcsinus Год назад
Я так понял, что API это REST, а он не должен зависеть от DAO и прочих плагинов.
@ivan_xalie
@ivan_xalie Год назад
@@MrArcsinus А по-моему, REST это как раз плагин
@MrArcsinus
@MrArcsinus Год назад
Именно так
@arvpro8970
@arvpro8970 7 месяцев назад
А где должен храниться bull process который выполняет таски? Грубо говоря фоновые службы
@stringconcat
@stringconcat 7 месяцев назад
Если я правильно понял, то какой нибудь Scheduler? Если так, то он концептуально не сильно отличается от какого-ниубдь контроллера: и тот и другой дергает бизнес логику. Контроллер когда его самомго кто-то подергает. А Шедулер, когда наступит определенно время. таким образом, я бы создал отдельный модуль schedule, который бы и дергал useCase
@mewforest
@mewforest 9 месяцев назад
Охуенно! То, что искал! Спасибо огромное!
@stringconcat
@stringconcat 9 месяцев назад
Рад помочь! :)
@user-zt2ob3le7e
@user-zt2ob3le7e 6 месяцев назад
Да с чего вы все решаете, что отсутствие кода это в плюс!? Наоборот, два три слайда с примерами более информативны чем растекание по древу!
@batazor
@batazor 2 месяца назад
Тут еще вопрос в сложности написания тестов, проверки ревью
@ivan_xalie
@ivan_xalie Год назад
5.46: А что не так с mockito?! :D
@stringconcat
@stringconcat Год назад
Достойно отдельного видео! Спасибо за вопрос! Сам мокито то не плох. Как обычно виновато то, как его используют. Проблема в том, что с его помошью можно протестировать вообще все что угодно, замокать любе зависимости, даже если они жестко указаны на какой-то класс. И он НЕ поощряет написание decoupled кода. Это раз. Во-вторых. Есть у вас зависимость, вы ее замокали. А потом стали использовать еще один метод из этой зависимости. И с мокито вы узнаете что нужно все моки дополнить в runtime. А если бы заменили на тестовую заглушку (рукописную), то в compile-time узнали что нужно метод имплментировать.
@user-sv7cf6ll2i
@user-sv7cf6ll2i 8 месяцев назад
Круть
@sergeyplotnikov4303
@sergeyplotnikov4303 6 месяцев назад
Без кода непонятно
@jellyfish6265
@jellyfish6265 7 месяцев назад
сорри, что это за бред? где слои?
@user-cc9lq6un4b
@user-cc9lq6un4b 6 месяцев назад
Слои то есть, просто они не нарисованы концентрическими окружностями. Сверху вниз: app layer, business, data access. То, что app layer окружает бизнес, может означать, что извне можно получить доступ только к app слою. Я так это интерпретировал.
@masserrackheim5358
@masserrackheim5358 5 месяцев назад
чувак, ты бы еще на туалетной бумаге или салфетке рисовал. вроде че то по делу говоришь, но подача это просто ппц - какие то кракозябры непонятные, генерирование текста на ходу. тебе настолько пох на твоих подписчиков что ты нормальные слайды поленился сделать?
Далее
5 Недостатков Clean Architecture
11:35
Просмотров 1,6 тыс.
1❤️#thankyou #shorts
00:21
Просмотров 45 млн
Understand Clean Architecture in 7 Minutes
7:02
Просмотров 79 тыс.
Избранное печатает...
0:11
Просмотров 115 тыс.
Неразбиваемый экран!
0:23
Просмотров 46 тыс.
keren sih #iphone #apple
0:16
Просмотров 764 тыс.
Гибкий телефон 📱
0:16
Просмотров 99 тыс.
ВСЕ МОИ ТЕЛЕФОНЫ
14:31
Просмотров 36 тыс.