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

Sdílet
Vložit
  • čas přidán 22. 04. 2023
  • ☝ Поваренная книга дядюшки боба: Как готовить Clean Architecture:
    🎓 Курс : howto.stringconcat.ru/cleanar...
    🎓 Разработка Приложений без Боли и Сожалений:
    howto.stringconcat.ru/enterpr...
    Подписывайся на
    📧 Телеграмм-канал: t.me/stringconcat
  • Věda a technologie

Komentáře • 57

  • @_Al_Kuznec
    @_Al_Kuznec Před rokem +12

    Ничего не поняла,что хотел сказать(((
    По дяде Бобу должно быть несколько конц.кругов. А где они здесь? Здесь все в куче по центру. почему и зачем не понятно((

  • @momentgi
    @momentgi Před 3 měsíci

    Супер. Никак не мог структурировать правильно интерфейсы и классы. Спасибо огромное

  • @KJLUM.1
    @KJLUM.1 Před dnem

    Чувак спасибо за контент, все круто и подробно обьяснил но беда со звуком, слишком тихо, приходится прям прислушиваться

  • @t0digital
    @t0digital Před rokem +3

    Пуши на голубях и кофейная гуща вместо бюро кредитных историй это хорошооо😂
    Рад новому отличному каналу!

    • @knowledgedose1956
      @knowledgedose1956 Před 6 měsíci +1

      о, Алексей, доброго времени суток🖖🏻

  • @andreypozin8048
    @andreypozin8048 Před 11 měsíci +5

    Дружище...почитай заново схему Дади Боба...и посмотри внимательно где находятся UseCases

  • @nill-tu3ey
    @nill-tu3ey Před 9 dny

    Охуенно! То, что искал! Спасибо огромное!. "Миша, Вве херня, давай по новой" (с).

  • @paulkasler2173
    @paulkasler2173 Před rokem +5

    Лайк поставлю, потом посмотрю , о чем то умном говорят

  • @user-zd6di5mq9z
    @user-zd6di5mq9z Před rokem +2

    Интересная серия роликов про архитектуру. Спасибо, с меня подписка.

    • @stringconcat
      @stringconcat  Před rokem

      Вам спасибо за интерес!

  • @user-ob9hg8cw1o
    @user-ob9hg8cw1o Před rokem +2

    это превосходно, спасибо

  • @meteysh
    @meteysh Před 3 měsíci

    Охапка дров и плов готов 😂, молодец, круто объяснил. Спасибо! 🎉

  • @Lapteuh
    @Lapteuh Před rokem +3

    Спасибо большое! У меня пара вопросов:
    1) Что делать с транзитивными зависимостями? Можно ли минуя app biz rules импортировать интерфейсы? У сложилось мнение, что так делать нельзя. Хотелось бы ваше мнение услышать.
    2) Нужны ли интерфейсы в use case, если можно сразу данные передать, а вернуть события?

    • @stringconcat
      @stringconcat  Před rokem +5

      Отличные вопросы! Спасибо!
      1) нет, так делать нельзя. Ибо в этом случае плагин API будет ссылаться на плагин Data Access. Но! иногда, к примеру для отчетов или еще какой тяжелой аналитики нужно выгрузить несколько тысяч записей из БД, и сделать это быстро. И столько конвертаций может быть делать накладно. Поэтому можно использовать CQRS паттерн. Но я бы в этом случае сделал отдельный модуль, независящий он Clean Architecture, скажем Analytics и в нем бы реализовал работу с хранилищем напрямую. Только стоит помнить, что у этого подхода много минусов в maintainability, главный из которых: как не дать другим разрабочтикам использовать этот шорткат, когда им захочется. Ну и конечно в начале стоит провести tradeoff анализ, чтобы понять что вы получаете и чем жертвуете.
      2) Лучше чтобы интерфейсы были, в этом случае вы сможете протестировать контролеры в изоляции от бизнес-логики даже без использования моков, а просто подсунув фейковую имплементацию, ну скажем лямбду.

  • @channel-yg2xc
    @channel-yg2xc Před 4 měsíci +1

    Спасибо за видео, интересная тема.
    Могли бы вы уточнить один момент: если у сегмента с бизнес-логикой в большинстве своём нет интерфейсов, может ли это быть нарушением чистой/гексагональной архитектуры при условии, что предметная область декомпозирована нормально и её реализация соответствует практикам low coupling & high cohesion? Просто складывается впечатление, что чуть ли не основной идеей описанных архитектурных подходов является выделение интерфейсов даже там, где это, казалось бы, смысла не имеет. Например, не понятна польза от интерфейсов для рядовых crud-операций или даже core бизнес логики, если в настоящее время существует единая реализация конкретного процесса, - на мой взгляд, наличие интерфейсов с единой реализацией скорее привносит сложность в проект, к тому же, если у процесса единая реализация, возникает сложность с наименованием интерфейсов и имплементаций, вроде BuisnessProcess и BuisnessProcessImpl.

    • @stringconcat
      @stringconcat  Před 4 měsíci +1

      Очень хороший вопрос! На все подряд конечно интерфейсы плодить не надо. Я выработал 2 принципа:
      1) Интерфейс нужен когда нужно перепрыгнуть из внутреннего круга во внешний. Ну к примеру, если нужно вызвать хранилище из слоя Бизнес логики. Там же без интерфейса не получится, иначе Бизнесу придется зависить от слоя доступа к данным
      2) Когда нам нужно несколько реализаций. При этом тесты считаются здесь тоже. К примеру у вас есть какая-то жутко сложная вычислялка процента в бизнес-логике, которая его вычисляет по многим параметрам, включая фазу Луны и индекс Доу-джонса. А вы тестируете, к примеру как вы письмо клиенту составляете автоматически, и вот эту вычислялку задействуете. Но вам абсолютно все равно какое значение она вернет. хоть 0, хоть 100500. И вот в этом случае имеет смысл заменить ее на Fake Implementation. Которая, скажем, всегда будет возвращать 15%

  • @evgenasd8892
    @evgenasd8892 Před 9 měsíci

    Да ролик понравился! А теперь попросить хочу снять о разработке через приемочное тестирование (только пример брать не правила переключения сигналов светофора, а что нибуль другое, на ваш выбор). Так называемое Atdd. В каком случае нужен приемочный тест а в каком переходим к юнит тесту, разобрать разницу, Спасибо.

  • @user-cc9lq6un4b
    @user-cc9lq6un4b Před 7 měsíci

    А почему application business layer не является отдельным сервисом?
    Просто сперва вы выносили Data access layer в отдельный кружок, а потом App layer как обертку бизнес логики.
    Как действовать, есди у меня есть приложение и сайт и у них слегка разная логика? Делать два сервиса: syte и application, которые зависят от контрактов сервиса с бизнес логикой?

  • @user-zt2ob3le7e
    @user-zt2ob3le7e Před 6 měsíci +14

    Да с чего вы все решаете, что отсутствие кода это в плюс!? Наоборот, два три слайда с примерами более информативны чем растекание по древу!

    • @batazor
      @batazor Před 3 měsíci

      Тут еще вопрос в сложности написания тестов, проверки ревью

  • @bubbletubbe
    @bubbletubbe Před 8 měsíci

    вроде как плагины реализуют интерфейсы которые в ядре БЛ, получается что они 'одноразовые' и в другой проект их не вытащить без куска БЛ ... ну такоэ

  • @aleksandrkokin6065
    @aleksandrkokin6065 Před rokem

    Поясните пожалуйста, если я не буду использовать Application слой, то API плагин взаимодействует напрямую с use cases? И хотелось бы поподробнее узнать про use кейсы, можно ли их называть сервисами?

    • @stringconcat
      @stringconcat  Před rokem

      В принципе, да у UseCase и традиционных Сервисов примерно одна и та же цель -- описывать верхнеуровнейвый бизнес-процесс. Поэтому и реализация у них очень похожа. Едиснтвенная проблема с сервисами -- зачастую они содержат несколько слабосвязных методов. Тоесть вырастает coupling на пустом месте.
      если я не буду использовать Application слой, то API плагин взаимодействует напрямую с use cases. Вот это не очень понял. Имеете ввиду Application Business Rules слой?

    • @user-ob9hg8cw1o
      @user-ob9hg8cw1o Před rokem

      @@stringconcat Да, Application Business Rules слой

  • @mewforest
    @mewforest Před 10 měsíci +1

    Охуенно! То, что искал! Спасибо огромное!

  • @serhiiboiko8957
    @serhiiboiko8957 Před rokem +2

    Здравствуйте! Расскажите пожалуйста как совмещать Clean Architecture с Microservice Architecture, если это возможно. Каждый микросервис отдельно разрабатывать как Clean Architecture? Или например Core Business Rules вынести в отдельную сборку, которая будет использоваться всеми микросервисами? А Application Business Rules делать для каждого микросепрвиса свои.

    • @stringconcat
      @stringconcat  Před rokem +4

      Если кратко, то каждый микросервис -- это отдельное приложение, каждый микросервис может быть написан на разных языках и иметь разные архитектуры внутри. В том числе и Clean Architecture.
      На мой взгляд если вы переиспользуете business rules, то скорее всего вы разбили приложение на микросервисы не оптимально, и они тесно связаны (coupled) друг с другом. Лучше всего микросервисы разбивать по bounded Context. Один микросервис -- один Context. А один контекст -- один набор бизнес правил.
      Если вы смотрите на микросеривисы и видите что лучше бы вынести ядро, то я бы порекомендовал подумать над тем, а не слить ли эти микросервисы в один.
      Я допускаю что можно сделать библиотеку, куда вынести какие-то совсем общие типы, к примеру Count, Money и пр. Но Это все же не ядро.
      Спасибо за вопрос. Постараюсь записать видео на эту тему!

    • @serhiiboiko8957
      @serhiiboiko8957 Před rokem

      @@stringconcat спасибо за Ваш ответ. Если можно, то хочу ещё спросить. В чистой архитектуре есть инфраструктурный слой. На сколько я понял он отвечает за работу с базами данных. С Redis. С брокерами сообщений. В Вашей схеме это Right Side. В микросервисной архитектуре есть гейтвей, который не работает напрямую с базами данных. Но он ведь тоже может быть разработан на основе чистой архитектуры. Будет ли в нём присутствовать инфраструктурный слой? Думаю что да, но отвечать он уже будет за работу с микросервисами, а не с базами данных. Правильно ли я понимаю? То же самое относится к клиентским приложениям, которые взаимодействуют со шлюзом. Инфраструктурный слой этих приложений будет отвечать за работу со шлюзом. Правильно?

    • @stringconcat
      @stringconcat  Před rokem +1

      @@serhiiboiko8957 Да, вы все правильно говорите, в случае gateway (или BFF) правые плагины будут, скажем REST клиентами к вашим микросервисам.
      Но, мне кажется что если BFF требует чистую архитектуру, то возможно в него попало слишком много бизнес правил. А это зачастую считается антипаттерном.

    • @serhiiboiko8957
      @serhiiboiko8957 Před rokem

      @@stringconcat в моём понимании BFF является интерфейсом между клиентом и разными бизнес логиками, которые реализованы на разных микросервисах и могут предоставлять информацию в рамках своей ответственности, но BFF может консолидировать эту информацию и отдавать клиенту одним пакетом. Т.е. бизнес логика BFF сводится к консолидации полученной от микросервисов информации. Получается, что для такого случая лучне использовать Layered Architecture? Я правильно понимаю? А для клиентского приложения? Если это толстый клиент с какой-то своей бизнес логикой (например какие-то расчёты, которые выгоднее делать на клиенте чам гонять по сетке), то наверное лучше использовать Clean или Hexagonal архитектуру. А если это веб приложение и вся бизнес логика на серверах, то наверное тоже лучше использовать Layered Architecture? Я правильно понимаю? Или для таких случаев есть ещё какая-то архитектура?

    • @stringconcat
      @stringconcat  Před rokem +1

      ​@@serhiiboiko8957 я ба наверное вот как определил необходимость использование CA или Hexagonal: Если в приложении есть бизнес-логика (вот прям доменная сложность), то лучше использовать CA или Hexagonal.
      Теперь про BFF. я встречал 2 варианта
      1. Нам нужно запросить данные из микросервиса 1, и из микросервиса 2. Скомпоновать их и отдать клиенту. В этом случае я бы не разделял даже на слои, одни и те же DTO используются чтобы получить ответ от микросервисов и отдать его клиенту. Или даже map'ы, чтобы при добавлении нового поля в микросервис не сильно заморачиваться с BFF.
      2. Появляются зачатки логики: Мне нужно запросить данные из микросервиса 1, и если данные содержат X, то запросить из микросервиса 2, а если Y, то из микросервиса 3. А если содержат Z, то вообще спрятать это поле. И это уже похоже на вполне себе бизнес-логику, и в этом случае да, я бы использовал CA или Hexagonal. Но на мой взгляд это запах того, что наш BFF становится слишком умным и через пол годика будет содержать очень внушительную порцию бизнес-логики. А этого бы нам хотелось избежать

  • @sergeyplotnikov4303
    @sergeyplotnikov4303 Před 7 měsíci +1

    Без кода непонятно

  • @herbslife-miscusi
    @herbslife-miscusi Před rokem +3

    Спасибо! теперь лучше понимаю.
    Сам интуитивно продвигал\стоил по тем же принципам) но без четкой понятийной базы и защищать эти решения было сложно.
    btw, а что за программа на планшете? что за планшет?)

    • @stringconcat
      @stringconcat  Před rokem

      Да, понимаю, огромная проблема донести виденье для разработчиков и установить правила игры :)
      это ipad air последний и стандартные notes.

  • @donpedro2125
    @donpedro2125 Před 2 měsíci

    "Миша, Вве херня, давай по новой" (с)

  • @MrArcsinus
    @MrArcsinus Před rokem

    По-моему, пропущен еще один важный компонент приложения: тот, в котором создадутся все инстансы юзкейсов, инстансы реализаций интерфейсов и прочие конфиги безопасности. Там где-то будет public static void main, если это Spring boot , например. И ему придется зависит от всех модулей

    • @stringconcat
      @stringconcat  Před rokem +2

      Да, дейтсвительно я его не упомянул. Сидел, смотрел на диаграмму и подумал: нет, если я сюда намалюю еще один слой, который связывает все плагины и core вместе, то всех запутаю :) придется еще один ролик выпускать. Спасибо что подсветили!

    • @ivan_xalie
      @ivan_xalie Před rokem

      Если я правильно понял - то это реализация уровня (слоя?) API.

    • @MrArcsinus
      @MrArcsinus Před rokem

      Я так понял, что API это REST, а он не должен зависеть от DAO и прочих плагинов.

    • @ivan_xalie
      @ivan_xalie Před rokem +1

      @@MrArcsinus А по-моему, REST это как раз плагин

    • @MrArcsinus
      @MrArcsinus Před rokem

      Именно так

  • @arvpro8970
    @arvpro8970 Před 7 měsíci

    А где должен храниться bull process который выполняет таски?
    Грубо говоря фоновые службы

    • @stringconcat
      @stringconcat  Před 7 měsíci +2

      Если я правильно понял, то какой нибудь Scheduler?
      Если так, то он концептуально не сильно отличается от какого-ниубдь контроллера: и тот и другой дергает бизнес логику. Контроллер когда его самомго кто-то подергает. А Шедулер, когда наступит определенно время.
      таким образом, я бы создал отдельный модуль schedule, который бы и дергал useCase

  • @user-sv7cf6ll2i
    @user-sv7cf6ll2i Před 8 měsíci

    Круть

  • @ivan_xalie
    @ivan_xalie Před rokem +1

    5.46: А что не так с mockito?! :D

    • @stringconcat
      @stringconcat  Před rokem

      Достойно отдельного видео! Спасибо за вопрос! Сам мокито то не плох. Как обычно виновато то, как его используют. Проблема в том, что с его помошью можно протестировать вообще все что угодно, замокать любе зависимости, даже если они жестко указаны на какой-то класс. И он НЕ поощряет написание decoupled кода. Это раз.
      Во-вторых. Есть у вас зависимость, вы ее замокали. А потом стали использовать еще один метод из этой зависимости. И с мокито вы узнаете что нужно все моки дополнить в runtime. А если бы заменили на тестовую заглушку (рукописную), то в compile-time узнали что нужно метод имплментировать.

  • @jellyfish6265
    @jellyfish6265 Před 7 měsíci +2

    сорри, что это за бред? где слои?

    • @user-cc9lq6un4b
      @user-cc9lq6un4b Před 7 měsíci

      Слои то есть, просто они не нарисованы концентрическими окружностями. Сверху вниз: app layer, business, data access.
      То, что app layer окружает бизнес, может означать, что извне можно получить доступ только к app слою.
      Я так это интерпретировал.

  • @veryvery8430
    @veryvery8430 Před 10 dny

    а нахер тогда нам обяснение про код без кода

  • @masserrackheim5358
    @masserrackheim5358 Před 5 měsíci

    чувак, ты бы еще на туалетной бумаге или салфетке рисовал. вроде че то по делу говоришь, но подача это просто ппц - какие то кракозябры непонятные, генерирование текста на ходу. тебе настолько пох на твоих подписчиков что ты нормальные слайды поленился сделать?