DDD архитектура база. Domain Driven Design архитектурный подход.

Поділитися
Вставка
  • Опубліковано 29 вер 2024

КОМЕНТАРІ • 77

  • @dmitriivanov7010
    @dmitriivanov7010 11 місяців тому +1

    Вы лучший блогер по Ларавел 🎉🎉🎉
    Ролик отличный!

  • @ДиванныйВоитель
    @ДиванныйВоитель 11 місяців тому

    Огромное спасибо за ваш труд. Очень крутой материал

  • @bigl_dev
    @bigl_dev 8 місяців тому +1

    0. ни слова о том, зачем ДДД.
    1. схема с ддд в описании архитектур не верная. Репозиторий ни когда не знает ничего о вьюхах. А на схеме - знает и много.
    2. Энтити отличается от value-object тем что имеет уникальный идентификатор для каждого экземпляра и обычно экземпляры мутабельны.
    3. сила интерфейсов к репозиториям в том, что реализация этих репозиториев может быть разной, под разные хранилища. При этом доменной модели на это плевать.
    4. ни слова не сказано про DTO. А ведь именно они пробрасываются между слоями.
    5. Salary не может быть value-object. Оклад - может, зарплата - нет. Поскольку зарплата включает в себя штрафы, надбавки и т.п. И вполне себе может иметь айди.

    • @alext5030
      @alext5030 Місяць тому

      "ни слова о том, зачем ДДД." - никто из адептов этой over engineered дичи так и не смог объяснить, зачем оно нужно для бекенда сайта на PHP, когда весь смысл бекенда: получить запрос, достать данные из базы, отдать данные обратно и... забыть про все, что было сделано до следующего раза.
      Складывается такое впечатление, что у программистов какой-то лютый комплекс неполноценности. Ввиду отсутствия чего-либо фундаментального в высокоуровневом программировании, они стремятся нагородить всякой дичи, чтобы их работа выглядела более внушительно.
      С точки зрения реальных инженеров (т.е. не софтовых) это же просто преступление: (условно) вместо 3-х строительных блоков использовать 5, обернув их какой-нибудь "прогрессивной" пленкой, чтобы ценник распух, ну и потом это все каждый год будет дополнительного контроля на тему "не оплавилась ли пленка летом", что удорожает еще и эксплуатацию сооружения.

  • @hotis8
    @hotis8 11 місяців тому +14

    Тема очень не простая. Спасибо за труды конечно, но по-моему только больше запутал зрителей. Про выгоду репозиториев при runtime это что за мысль? не понятно что хотел сказать. Про единый язык, без примеров кода, не ясно для чего этот зверь вообще. Концепция DDD включает три столпа Агрегаты-Сущности-ОбъектыЗначения. Про агрегаты в видео не слова. Делаю вывод вы (автор) даже бегло с концепцией не разобрались. Про репозитории тоже всё скомкано получилось. Любой интерфейс описывает поведение, если мы его имплементируем(реализуем) значит подписываем "контракт", что от нашего объекта можно ждать соответствующего поведения. А объект не обязательно работает с базой данных, это может быть CLI, Rabbit и т.д. Но как говориться критикуешь предлагай: 1. Удалить этот ролик. 2. Записать ролик про концепцию DDD с короткими примерами кода (3-4 строки) 3. Записать ещё ролик (можно не один) про практическое применение DDD в границах фреймворка Laravel. Ещё в DDD не может быть всё свалено в одну папку src (тогда это не DDD), поскольку есть такое понятие как border context.

  • @narwhal6422
    @narwhal6422 11 місяців тому

    Можно видео-обзор для jetstream?

  • @Abdugoffor_Qodirov
    @Abdugoffor_Qodirov 5 місяців тому

    пожалуйста, сделайте 1 задание поменьше, используя DDD внутри laravel

  • @ChernayaReka
    @ChernayaReka 6 місяців тому

    Куда пропал ?

  • @antohagobet4451
    @antohagobet4451 11 місяців тому +11

    Спасибо, автору за новое видео, один из лучших блогеров по веб-разработке) при том что еще и ролики очень полезные и на актуальные темы!

  • @АлександрГлебов-г2х
    @АлександрГлебов-г2х 11 місяців тому +2

    Почему принято в корне создавать папки controllers, resourses и тд. Ведь удобнее если бы на верхнем уровне были модули, вроде users, а внутри уже контроллеры ресурсы и тд юзера. Тогда, работая с юзерами не придется искать его классы по всему проекту, а все будет рядом. И так же с классами DDD.

  • @ДенисКисляк-и2п
    @ДенисКисляк-и2п 11 місяців тому +5

    Огромное спасибо автору за данное видео! Было бы здорово увидеть написание проекта на laravel с использованием DDD.

  • @Евгений-т3ц9к
    @Евгений-т3ц9к 11 місяців тому +5

    Спасибо тебе братан! Как всегда, видео на высоте. Единственный релевантный блогер по Laravel. Не бросай своё дело!

  • @smilesrg
    @smilesrg 10 місяців тому +2

    Тема DDD не раскрыта

  • @dmitryfokin5205
    @dmitryfokin5205 7 місяців тому

    а если у человека фамилия поменяется, а нужно распечатать в старом документе старую фамилию? а если работник уволился, а потом снова устроился? а если полные тезки будут то одно велью будет или два одинаковых? - так это бред?

  • @sharpsss7666
    @sharpsss7666 11 місяців тому +1

    Привет, часто твои видосы спасают, сделай пожалуйста на nuxt js + laravel гайд с деплоем на сервер , классика laravel mysql + nuxt js для SSR пожалуйста)

  • @User-lj7gs
    @User-lj7gs 11 місяців тому +1

    Автор привет. Мне очень интересно увидить ролик на тему бек офиса и создания контент элементов. Их администрирование, заполнение и так далее. Я понимаю как это работает в cms но не на Laravel.

  • @pavelbabich4589
    @pavelbabich4589 11 місяців тому +1

    Для меня проблема это как правилньо архитектуру создавать.
    Когда в одиночку кодишь, но хочется красиво и понятно.
    Спасибо за урок

  • @RaG777
    @RaG777 7 місяців тому +2

    Здарова! Не останавливайся! Всё будет! Спасибо!

  • @KikrAzz
    @KikrAzz 9 місяців тому +1

    Спасибо автору. Но почему репозиторий описан в доменном слое. Разве домен не обязан быть в неведении относительно репозиториев?

  • @yerzhanstinger
    @yerzhanstinger Місяць тому

    Когда использовать DDD вместо MVC?

  • @spitzer4077
    @spitzer4077 11 місяців тому +1

    Было б здорово показать распаковку сути DDD в виде многошагового развития какой-то базовой рабочей версии чего-либо, да тех же воркеров.. типа вот наш концепт, а теперь давайте усложним задачу несколько раз вот так, дабы ощущить всю мощь -тёмной стороны силы- DDD, #ящетаю...

  • @olezhonnv3215
    @olezhonnv3215 11 місяців тому +1

    preg_match разве не будет ексепшны выдавать? Там надо ! вроде как поставить. Иначе на киррилицу будет эксепшны выдавать.

    • @olezhonnv3215
      @olezhonnv3215 11 місяців тому +1

      В классе Name.

    • @laravelcreative
      @laravelcreative  11 місяців тому

      Это пример, там много чего можно сделать:)

  • @svetatam
    @svetatam 11 місяців тому

    В ObjectValue выбрасывается http exception. Так не хорошо делать, перепрыгивая целый слой

  • @sergeisurin2963
    @sergeisurin2963 11 місяців тому +1

    🙏👍❗

  • @donart959
    @donart959 11 місяців тому +1

    расскажешь про постмен и подводные камни?

  • @НиколайН-т3т
    @НиколайН-т3т 11 місяців тому +2

    👍🏻 спасибо, ддд как будто какой-то порог, если его прошел и можешь объяснить что к чему то норм и даже не обязательно действительно уметь применять.
    Надеюсь на продолжение по асинхронности, cqrs, rabbit)

    • @Евгений-т3ц9к
      @Евгений-т3ц9к 11 місяців тому

      Да, согласен по реббиту надо больше) cqrs тоже было бы не плохо.

    • @laravelcreative
      @laravelcreative  11 місяців тому

      Благодарю!:) Посмотрим:)

    • @biLLie_wiLLie
      @biLLie_wiLLie 11 місяців тому +1

      @@Евгений-т3ц9к что такое cqrs?

    • @olezhonnv3215
      @olezhonnv3215 11 місяців тому +1

      ​​@@biLLie_wiLLieCommand Query Responsibility Segregation

  • @artemunix5223
    @artemunix5223 11 місяців тому +2

    о нормас давай еще

  • @michaelalexeev2347
    @michaelalexeev2347 11 місяців тому +1

    Ого спасибо! Стало понятнее про ДДД 👍 а про тестирование будут ролики? а то на многих собесах спрашивают про это.

    • @tori.archive
      @tori.archive 11 місяців тому +1

      ua-cam.com/video/leaXsWyfQRs/v-deo.html&ab_channel=LaravelCreative

  • @ivaniuk_volodymyr
    @ivaniuk_volodymyr 11 місяців тому +1

    Азиз, спасибо большое, как всегда, все четко и актуально!!!

  • @svetatam
    @svetatam 11 місяців тому +1

    Спасибо! Очень понятно преподнёс! 😊

  • @АртурПоздняк-я9х
    @АртурПоздняк-я9х 11 місяців тому +1

    Большое спасибо за видео, очень позеавательно

  • @artemunix5223
    @artemunix5223 11 місяців тому +1

    расскажи как документацию проекта делать

  • @Санечка-и6ц
    @Санечка-и6ц 10 місяців тому

    А где у вас на канале раньше были видео по тестам? Вы их закрыли, что ли? Юнит тесты и ещё, кажется, какие-то были.

  • @alexanderbashkatov5981
    @alexanderbashkatov5981 7 місяців тому

    Здравствуйте! Вот бы еще ролик как это все запустить. Те же например банальные CRUDы. Спасибо большое.

  • @artemunix5223
    @artemunix5223 11 місяців тому +1

    тоесть лучше логику в сервисы пихать ?

    • @НиколайСергеев-н1л
      @НиколайСергеев-н1л 11 місяців тому

      Ну вообще от ситуации, если логика какая то сложная, ты можешь ее вынести в доменный слой приложения, так Адель писал☝️. От случая зависит

    • @hotis8
      @hotis8 11 місяців тому

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

    • @artemunix5223
      @artemunix5223 11 місяців тому +1

      @@hotis8 а в чем разница от бизнес логики я не понял

    • @hotis8
      @hotis8 11 місяців тому

      @@artemunix5223 коротко для себя это сформулировал так - в объекте только та логика которая от бизнес-процессов не зависит.

  • @ДмитрийВладимирович-г4ц

    Может к этому видео не относится, но как на счёт урока про репликацию, master-slave в laravel для Mysql

  • @timur43378
    @timur43378 10 місяців тому

    Есть же канонический перевод - "Предметно-ориентированный дизайн". Гораздо точнее отражает суть, чем "на основе".

  • @sergeblack1777
    @sergeblack1777 11 місяців тому

    Условие в методе assertSalaryIsValid должно быть противоположным

  • @Amtes-it3cb
    @Amtes-it3cb 8 місяців тому

    Здравствуйте, посмотрел много ваших видео и хотел спросить, если посмотреть все ваши платные курсы по ларавел, можно ли уверенно идти на работу на позицию jun?

  • @laraveluz2195
    @laraveluz2195 11 місяців тому +1

    Большое спасибо

  • @biLLie_wiLLie
    @biLLie_wiLLie 11 місяців тому +1

    Автор, спасибо тебе!

  • @Abdugoffor_Qodirov
    @Abdugoffor_Qodirov 5 місяців тому

    пожалуйста это было очень нужно

  • @mihaelkirienko1471
    @mihaelkirienko1471 11 місяців тому

    Имя можно разделить на first name и last name)

    • @pavelbabich4589
      @pavelbabich4589 11 місяців тому +1

      оно в коде так и реализованно

  • @vxarlanchuk
    @vxarlanchuk 11 місяців тому

    Очень понятно разложил!

  • @gru8299
    @gru8299 11 місяців тому

    Благодарю!!! 🤝

  • @frerf6604
    @frerf6604 11 місяців тому +1

    Стоит использовать phpmyadmin?

  • @dzmitriyskarakhodau3176
    @dzmitriyskarakhodau3176 11 місяців тому

    Здравствуйте, интересует вопрос, а не хотели бы Вы, или, возможно, у Вас есть в планах, начать рассказывать про Symfony?

  • @timur43378
    @timur43378 10 місяців тому +1

    Реестр сотрудников не является адекватным примером предметной области. Для такого приложения не нужно даже городить никакое DDD.
    Достаточно интерфейса к базе данных с некоторыми проверками.
    Предметной областью может быть вся фирма, если там действительно есть сложная бизнес-логика. Иначе достаточно CRUD приложения.
    Сущность не является предметной областью.
    Короче, слышал звон да не знаю где он, из DDD тут только набор непонятых автором терминов.

  • @litvinenkow
    @litvinenkow 6 місяців тому

    никто никогда при разговоре про DDD не говорит ЗАЧЕМ и КАК с этим потом работать?
    опять одна вода и 0 путных мыслей, сколько раз еще такие ролики будут иметь место?
    нахрена к ларавелю это всё прикручивать и изобретать велосипед?
    как их между собой вязать, если в ларе модели друг к другу вяжутся нормально, как объекты в БД со связами через внешние ключи, то здесь всё, приехали ваши вэлью обжекты существубт сами по себе, как их коннектить друг к другу непонятно, вы проигрываете в скорости, во всём, все сущности у вас теперь атомарны, ни о каких джойнах теперь речи не идёт, вы просто всё разделили, запросов в БД больше, удобства меньше
    зачем здесь DTO если у вас уже и там ValueObject? хоспади, есть ощущение что вы вообще не понимаете что вы делаете и для чего, это какие-то понты без обоснования, типа смотри как могу
    никто не отвечает на эти вопросы, загадка остаётся нерешённой

    • @litvinenkow
      @litvinenkow 6 місяців тому

      ладно, в конце вроде нормально раскрыл, забираю свои выебоны обратно

    • @zxc7613
      @zxc7613 6 місяців тому

      ++. Как опытный велосипедист, всегда вижу когда педали не в ту сторону крутятся. Нужен адаптированный ДДД под прекрасные модели ларавел, может быть не очень правильный но всё же.

    • @litvinenkow
      @litvinenkow 6 місяців тому +1

      @@zxc7613 фреймворки для того, чтобы бить по рукам, но когда на уже существующие пытаются наслоить что-то еще своё, я бы пиздил еще и ногами

    • @zxc7613
      @zxc7613 6 місяців тому

      @@litvinenkow ахахахха

    • @alext5030
      @alext5030 Місяць тому +1

      Да просто Laravel, так же как и Yii(оба), заточен под Active Record, что соотвествует подходу Database First. Естественно, прикручивание этой дичи (DDD) всегда будет выглядеть, как пришивание второго хвоста и пятй ноги собаке. Было бы понятно, если бы эти любители over engineering-а создавали бы своих моностров БЕЗ фреймворков, но нет...