Aprenda DDD (Domain Driven Design) do jeito certo

แชร์
ฝัง
  • เผยแพร่เมื่อ 18 ม.ค. 2025

ความคิดเห็น • 114

  • @fernandorotermund5793
    @fernandorotermund5793 3 ปีที่แล้ว +74

    Melhor explicação que já vi até agora nesses últimos anos. O pessoal por ai filosofa demais e não da para entender nada, você foi inclivel.

  • @andarilho_games
    @andarilho_games ปีที่แล้ว +1

    Melhor explicação de DDD que já vi. A única que consegui entender com facilidade. Excelente!

  • @inocencio.cardoso
    @inocencio.cardoso ปีที่แล้ว +12

    Sem exageros, de todos os vídeos que encontrei no TH-cam sobre DDD, este é de longe o melhor! 💡💡

  • @giulianabezerra
    @giulianabezerra 2 ปีที่แล้ว +2

    Esse vídeo é perfeito para quem nunca entendeu DDD, sempre achou algo abstrato demais, e nunca conseguiu implementar na prática. Parabéns pelas explicações!

  • @thiagoladainha3787
    @thiagoladainha3787 11 หลายเดือนก่อน +1

    Sensacional, parabéns. Muito conteúdo mas explicado de forma muito didática. Muito Obrigado

  • @johnatasrabelo7088
    @johnatasrabelo7088 3 ปีที่แล้ว +2

    Melhor canal de conteúdos de tecnologia backend, frontend , arquitetura e Devops. Fã demais !

  • @Matt_McFly_85
    @Matt_McFly_85 ปีที่แล้ว +2

    Excelente conteúdo! Acabei de começar a trabalhar como Dev e o sênior pediu que eu estudasse sobre DDD e clean code antes de começar a codificar. Fora aprender React e Node (eu venho do Java kkk).

  • @edipocdf
    @edipocdf ปีที่แล้ว +1

    Cara, que vídeo sensacional, explica tudo muito bem de maneira progressiva do inicio ao fim. Por mais que falem que se mais usa em apps grandes, da perfeitamente pra usar os mesmos princípios em modelagens de programas bem mais simples, ajudando assim a documentar melhor o fluxo.

  • @yuri901000
    @yuri901000 2 ปีที่แล้ว

    Esse canal é top, melhor qualidade de conteúdo de desenvolvimento de software do TH-cam.

  • @ronaldoriosespindola3716
    @ronaldoriosespindola3716 ปีที่แล้ว +3

    Caraio mano. Nunca vi uma didática tão perfeita sobre um tema que pra mim parecia absurdo. O pessoal enfeita demais tornando tudo romantizado e você conseguiu tornar prática essa teoria e trazer mais pra realidade. Muito bom mano. Parabéns!

  • @setplayer7
    @setplayer7 10 หลายเดือนก่อน +1

    Excelente vídeo. Parabéns!

  • @Katho20
    @Katho20 ปีที่แล้ว +1

    Super Concreto Will, a partir daí surgem algumas duvidas e estou pensando em como aplicar isso aqui em Portugal para os sistemas do governo para agregar valor, tanto no negocio quanto no desenvolvimento. Mas como aqui quase 100% dos projetos são monolitos, vou tentar abstrair para iniciar algo com DDD.
    Valeu a aula Will.... vc é o kara!

  • @SergioRamos_2023
    @SergioRamos_2023 2 ปีที่แล้ว

    Melhor explicação sobre DDD até agora. PArabens !!! Simples e direta...exemplificando de forma clara.

  • @joaopauloantoniazzidemorae5334
    @joaopauloantoniazzidemorae5334 2 ปีที่แล้ว

    Show de explicação sobre DDD!! PARABÉNS Wesley!!!

  • @charluz
    @charluz ปีที่แล้ว

    Obrigado pelo conhecimento compartilhado, foi uma excelente explicação.

  • @antoniomarcos5664
    @antoniomarcos5664 ปีที่แล้ว +2

    Weslley, que conteúdo! Quem já conhecia mas não havia consolidado o entendimento, agora conseguiu consolidar. Parabéns pela apresentação e clareza na transmissão do conhecimento. Eu gostaria de saber como aplicar a segunda parte, onde teríamos os microsserviços e se possível sob uma arquitetura Hexagonal ( ports and adapters).

  • @felipechaves1596
    @felipechaves1596 4 ปีที่แล้ว +7

    Esse video é sensacional, acredito que deveria ser legendado em inglês para aumentar seu alcance. Eu com certeza indicaria para amigos aqui (moro fora do país)

  • @rotognin
    @rotognin 3 ปีที่แล้ว +2

    Finalmente!! Finalmente entendi esse tal de DDD, que não significa Discagem Direta à Distância (os mais antigos devem se lembrar dos "orelhões" azuis rsrsrs)

  • @analuciabolico
    @analuciabolico ปีที่แล้ว

    Bha muito top essa explicacao, gosto muito dos teus videos. A didatica é sensacional!! Parabens

  • @franciscosilva3034
    @franciscosilva3034 2 ปีที่แล้ว

    Muito boa a explicação Wesley.

  • @luccasmachado7618
    @luccasmachado7618 2 ปีที่แล้ว

    Obrigado pela aula, resumiu completamente o livro sem deixar faltar nenhum detalhe.

  • @eduardogomes25
    @eduardogomes25 2 ปีที่แล้ว

    Essa explicação salvou minha vida no trabalho!! Valew Weslley!!!!

  • @davirocha-di9531
    @davirocha-di9531 2 ปีที่แล้ว

    Obrigado pelo conteúdo! Deus abençoe.

  • @alexsandropires2438
    @alexsandropires2438 4 ปีที่แล้ว +1

    Muito obrigado Wesley, muito progresso pra vc, pois vc passa isto pra gente...VIDA LONGA.

  • @RaynerGS
    @RaynerGS 2 ปีที่แล้ว +3

    Formei em 98 em Ciência da Computação com ênfase em análise de sistemas, minha carreira foi focada em Redes, especialização, mestrado e doutorado, depois de uns 20 anos estou voltando para o desenvolvimento de sistemas e é incrível como que DDD é muito parecido com que utilizamos na década de 90 com o DFD, DER e MER. Mesmos objetivos, montar o dicionário de dados, criar contextos e montar a relação entre eles!

    • @zdeicidaz
      @zdeicidaz 5 หลายเดือนก่อน

      Agora eu te pergunto, você que já viu e passou por todas essas techs, qual a diferença e porque diabos reinventar a roda, se já existiu um modelo com as mesma caracteristicas ?

  • @wedersoncabral737
    @wedersoncabral737 ปีที่แล้ว

    Vídeo muito bem explicado, parabéns!!

  • @neuroatletica6410
    @neuroatletica6410 3 ปีที่แล้ว

    Melhor vídeo que ja assisti sobre o assunto. Sensacional!

  • @wagnersodre4417
    @wagnersodre4417 2 ปีที่แล้ว

    Conceito explicado bem e de forma simples. Parabéns!!!

  • @dayvitrsiqueira6772
    @dayvitrsiqueira6772 2 ปีที่แล้ว

    A melhor aula sobre DDD que já vi.

  • @pgnt
    @pgnt 3 ปีที่แล้ว

    Muito bom quando alguém que sabe o que está falando também sabe falar. DDD desmistificado em 1h. Parabéns e obrigado!

  • @gabrieldasilvacaetano8979
    @gabrieldasilvacaetano8979 2 ปีที่แล้ว

    Grande aula! 👏👏

  • @silvio_bassi
    @silvio_bassi ปีที่แล้ว

    Melhor explicação de DDD!

  • @hanterique
    @hanterique 2 ปีที่แล้ว

    Excelente explicação! Aprendi bastante. Obrigado por compartilhar 👍

  • @luizqueirozneto847
    @luizqueirozneto847 2 ปีที่แล้ว

    Aula top! Parabéns! Gratidão!

  • @karinaoliveira1552
    @karinaoliveira1552 3 ปีที่แล้ว

    Melhor explicação que encontrei sobre DDD, obrigada!

  • @afso1
    @afso1 4 ปีที่แล้ว +5

    Parabéns por mais esse conteúdo Weslley, você consegue simplificar muito os assuntos. Gostaria que, se possível, você fizesse um vídeo sobre single sign on em microserviços. Grande abraço!

  • @geovanefreitasacetech
    @geovanefreitasacetech 4 ปีที่แล้ว +2

    Obrigado Weslley pelo esclarecimento, estava com muitas dúvidas e este seu vídeo me ajudou a ter uma base de como funciona o DDD.

  • @desenvolvedorti175
    @desenvolvedorti175 3 ปีที่แล้ว

    parabens! um dos melhores resumos sobre ddd que assisti. Obrigado.

  • @diegoharrison98
    @diegoharrison98 4 ปีที่แล้ว

    Irei começar um projeto aplicando DDD, realmente esclareceu muita coisa, ótimo vídeo, parabéns!

  • @eliabekun
    @eliabekun 2 ปีที่แล้ว

    Fantástico! Parabéns por essa aula!

  • @hqm2370
    @hqm2370 4 ปีที่แล้ว

    uau! you are amazing !! your speech is so clear and easy to understand the subject.

  • @devquicktips5059
    @devquicktips5059 4 ปีที่แล้ว

    Até que enfim alguém explicando DDD de verdade e não só copia e cola código

  • @leandrosoares6
    @leandrosoares6 4 ปีที่แล้ว +2

    Perfeito o vídeo Weslley. Acredito eu que apesar de termos o privilégio de ter tantos conteúdos técnicos legais na nossa área assim de forma gratuita, vejo que ainda há um desequilíbrio do que é mais importante na construção de um sistema. A gente inicia a carreira de certa forma orientado à tecnologias específicas, linguagens específicas sendo que toda a parte de modelagem é deixada de lado. Infelizmente pra mim toda aquela teoria bacana aprendida na universidade nas disciplinas de Engenharia de Software no final das contas, quando vamos pro mercado vemos que são secundárias. Um exemplo que vale pra mim pelo menos é que no meu atual emprego a primeira coisa que questionei em relação aos sistemas à qual seria responsável era se tinha algum documento de especificação de requisitos, diagrama de classes, etc... Só nada. Mas o foco recente no mercado em cima do DDD me deu uma certa esperança quanto à isso.

  • @frankwillianvalentim6520
    @frankwillianvalentim6520 3 ปีที่แล้ว

    Perfeito ... Parabéns pelo trabalho realizado.

  • @thalesfarias3888
    @thalesfarias3888 3 ปีที่แล้ว

    Melhor aula e explicação, parabéns

  • @Garibeiro1993
    @Garibeiro1993 3 ปีที่แล้ว

    Conteúdo muito bom parabéns

  • @jonnesBrown
    @jonnesBrown 2 ปีที่แล้ว

    Conteudo top demais

  • @gabrielhitsu
    @gabrielhitsu 4 ปีที่แล้ว

    Muito bacana, eu estava começando a procurar conteúdos do DDD procurando códigos rs... e seu vídeo abriu meus olhos... vlw

  • @nivaldobrasil
    @nivaldobrasil 3 ปีที่แล้ว

    muito bom.. parabéns

  • @GeorgeWurthmann
    @GeorgeWurthmann 2 ปีที่แล้ว

    Que explicação maravilhosa! Obrigado!!! 🚀🚀🚀

  • @alchemistdrops
    @alchemistdrops 4 ปีที่แล้ว +1

    Woow awesome class my friend really love it

  • @JonatanEdOrtiz
    @JonatanEdOrtiz ปีที่แล้ว

    Explicação top!

  • @lucianoferreira8620
    @lucianoferreira8620 3 ปีที่แล้ว

    Ótima explicação!

  • @thiagofernandesdonasciment9755
    @thiagofernandesdonasciment9755 3 ปีที่แล้ว

    show. parabens!

  • @CarlosChagasOficial
    @CarlosChagasOficial 4 ปีที่แล้ว +1

    Muito legal amigo tamos juntos valeu é nós

  • @clebiovieira
    @clebiovieira 3 ปีที่แล้ว

    Parbéns. Tua linguagem vai direto ao ponto.

  • @gustavo_641
    @gustavo_641 4 ปีที่แล้ว +6

    Caralho, sensacional. Tô sem palavras aqui pro tanto de informação que acabou de me bombardear

  • @mateusgff
    @mateusgff 3 ปีที่แล้ว

    Muito boa explicação!

  • @GustavoRodrigues-le3zw
    @GustavoRodrigues-le3zw 3 ปีที่แล้ว

    Excelente conteúdo!!

  • @inocencio.cardoso
    @inocencio.cardoso 24 วันที่ผ่านมา

    Uma dúvida, Júnior: sabendo que podemos ter duas classes/entidades "Cliente" em contextos diferentes, como fica o nome da tabela no banco, se ambas as entidades têm o mesmo nome? Entendo que, em microsserviços pode até funcionar, mas para Monólito que utiliza DDD no seu Domain, com um único banco?

  • @luizguilhermesilva7298
    @luizguilhermesilva7298 3 ปีที่แล้ว

    Excelente explicação! Obrigado!

  • @BrunoGambaRocha
    @BrunoGambaRocha 3 ปีที่แล้ว

    Que aula! Muito obrigado Weslley por mais este conhecimento repassado!

  • @natanmenezes6853
    @natanmenezes6853 4 ปีที่แล้ว +3

    Cara muito obrigado, excelente conteúdo, diferente de todos os outros. Parabéns!

  • @darlankenobi
    @darlankenobi 4 ปีที่แล้ว

    Muito bem explicado! Muito obrigado!

  • @ThaysBarbarafc
    @ThaysBarbarafc 4 ปีที่แล้ว

    Nossa! Parabéns pelo vídeo, uma aula incrível. Obrigada!

  • @evertonm.deoliveira3168
    @evertonm.deoliveira3168 ปีที่แล้ว

    Muito bom!!!

  • @marcosvinicio1539
    @marcosvinicio1539 4 ปีที่แล้ว

    Excelente Weslley! Muito obrigado pela ajuda!

  • @edinhobrasil06
    @edinhobrasil06 4 ปีที่แล้ว

    Aulas teóricas geralmente são chatas pra kct. Mas a sua foi MUITO BOA!!! Parabéns e muito obrigado por compartilhar este conhecimento!

  • @themodernarchitect7537
    @themodernarchitect7537 3 ปีที่แล้ว +2

    25:13 cara, eu acho interessante começar com use cases, utilizando alguns elementos de UML, e daí partir para o levantamento inicial do domínio. Use cases são um ótimo ponto de partida, e como eles são bastante extensíveis, você pode melhorá-los ao longo do projeto, à medida que a linguagem e os contextos se desenvolvem. No final eles serão um ótimo recurso visual para que qualquer desenvolvedor entenda de cara o que se espera do sistema. Sem use cases, precisamos ler user stories e montar tudo isso mentalmente.

  • @marcionp
    @marcionp 3 ปีที่แล้ว +1

    Muito bom, mas eu faria algumas observações.
    1. Na minha visão, catálogo, pagamento, lista etc. não seriam domínios. Domínio é o espaço do problema, normalmente a área onde o sistema roda a solução para o problema. Ou seja, sugiriria que o Domínio fosse o Netflix em si, já que não se trata de uma área corporativa tal como um restaurante ou uma clínica médica. A partir daí, traçaria os sub-domínios, representados por bouded contexts. E aí vem minna principal observação, os BC deveriam representar áreas de responsabilidade diferentes, ou seja, integração com parceiros, financeiro, player do cliente, player de usuário free. Esses dois últimos claramente possuiriam um núcleo compartilhando referente ao PLAYER. Mas o primeiro possuiria opções de off-line enquanto o segundo teria a incorporação de propagandas compulsórias.
    2.linguagem ubiqua nasce dos cenarios de negócio (event storming) e nao de estórias de usuário. Não se deve também restringir os termos a substantivos. Além disso, cada termo deveria ser definido (se existir) em cada contexto delimitado. Exemplo, faltou um bounded context chamado Aquisições. Assim, o termo Video para esse BC significa um produto adquirido pelo serviço de streaming, enquanto para o assinante, representa um filme ou série que ele deseja assistir. Aliás, os contextos delimitados normalmente referem-se a subdomínios do problema.
    3. Bouded context é padrão para espaço do problema e não dá solução. Então acho perigoso mencionar APIs nesse momento.

  • @2016Trabalhosonline
    @2016Trabalhosonline 3 ปีที่แล้ว

    Muito bom ! me ajudou muito!!

  • @viniciusprudencio3577
    @viniciusprudencio3577 4 ปีที่แล้ว

    Excelente conteúdo. Parabéns.

  • @luisfilipe6582
    @luisfilipe6582 3 ปีที่แล้ว

    Excelente video.
    Vi o termo diversas vezes e li artigos, ou videos, curtos sobre o assunto
    Nunca fixei o contexto 100% ate agr, quando vi o seu conteudo kkkkkkk
    Ate me senti burro quando vc disse que o DDD é facil de entender

  • @viniciusban
    @viniciusban 4 ปีที่แล้ว +4

    Excelente conteúdo. Parabéns.
    Sobre esperar ver código quando se fala de DDD, é uma questão de foco.
    DDD é uma disciplina de análise de sistemas; não de programação.

  • @eduardozaghi
    @eduardozaghi 4 ปีที่แล้ว

    Parabéns! Muito legal, obrigado!

  • @reidainutilidade8743
    @reidainutilidade8743 2 ปีที่แล้ว

    É bem interessante.

  • @BrenoMontanari
    @BrenoMontanari 4 ปีที่แล้ว

    Muito bom o conteúdo e os exemplos também, parabéns e obrigado.

  • @sobrevivendo-no-front
    @sobrevivendo-no-front 4 ปีที่แล้ว

    Incrível conteúdo, muito obrigado!

  • @viajarepreciso4929
    @viajarepreciso4929 3 ปีที่แล้ว

    Muitoo bomm

  • @flawtista
    @flawtista 3 ปีที่แล้ว

    Fiquei aqui com uma dúvida no 35:45. Se o catálogo é o domínio principal e o perfil é o auxiliar, vc disse que o perfil é quem deverá se adaptar a mudança do catálogo. No entanto, não é o que acontece na maioria dos serviços de streaming. Quando vc muda o perfil,o catálogo muda completamente. Por exemplo, quando vc muda pra um perfil infantil, a prioridade do catálogo é trazer conteúdos infantis .

    • @lisbyte_
      @lisbyte_ 2 ปีที่แล้ว

      Opa amigo, espero que consiga ajudar. A forma que os dados sao fornecidos pelo Catalogo nao muda, por exemplo, se no meu dominio de Catalogo eu exponho a funcao PegarMinhaLista, e eu mudo para o Perfil Infantil, eu nao vou alterar o PegarMinhaLista para PegarMinhaListaInfantil, vai continuar a mesma coisa por que o Catalogo nao tem que mudar sua forma de "fornecer", ja no perfil eu tenho que consumir o "PegarMinhaLista" porem os dados que eu vou obter ou a forma de tratar os dados obtidos vao ser diferentes. Espero que tenha feito sentido.

  • @TheDyarlen
    @TheDyarlen 3 ปีที่แล้ว +1

    Acho que a definicao de Servicos de Domino (Domain Services) no minuto 55:05 esta errada. Essa nao seria a definicao de Servicos de Aplicacao (Application Services)?
    Pois os Servicos de Aplicacao que consomem recursos da camada de infraestrutura. Os Servicos de Dominio deveriam conter apenas regra de negocio, e nao ter nenhuma relacao com repositorios, envio de email e etc (detalhes da infraestrutura).
    Ou isso se aplica apenas a Clean Architecture?

  • @theBoi-1983
    @theBoi-1983 4 ปีที่แล้ว

    Excelente explicação! 👏🏼👏🏼👏🏼

  • @douglaslara316
    @douglaslara316 4 ปีที่แล้ว +1

    Valeu Weslley! Agora sim não vou pererecar no DDD

  • @CarlosChagasOficial
    @CarlosChagasOficial 4 ปีที่แล้ว +1

    Boa tarde 👍👌✌

  • @ThiagoPereira-zn7ks
    @ThiagoPereira-zn7ks 4 ปีที่แล้ว

    ótima aula professor :)

  • @marlonreis2409
    @marlonreis2409 4 ปีที่แล้ว

    Mandou muito bem!

  • @thiagofelippi5969
    @thiagofelippi5969 4 ปีที่แล้ว +1

    Muito bom! Só não entendi uma coisa, a regra de negócio vai ficar na entidade ou no service? e outra coisa, o service seria equivalente a um controller?

    • @felipechaves1596
      @felipechaves1596 4 ปีที่แล้ว +2

      Pelo que entendi, a entidade você só define a estrutura e métodos de validação. Ja no serviço você constrói a entidade e implementa as regras de negócio ali. O fluxo seria Controller > Service > Entidade (constrói a entidade) > Repositório (persiste a entidade).

  • @cassiofbs
    @cassiofbs 3 ปีที่แล้ว

    aula excelente! alguem tem o link do slide?

  • @leonardolopesoliveira
    @leonardolopesoliveira 4 ปีที่แล้ว

    muito bom!

  • @alexandresimoesneves4389
    @alexandresimoesneves4389 4 ปีที่แล้ว

    Ola, boa noite.
    Eu fiquei com uma dúvida durante o slide do minuto 39 Context Map..
    Existe um limite ou um numero máximo ideal para domínios principais?
    Qual a boa pratica neste caso? Por que se num primeiro entendimento de contexto, você obter, sei lá, 8 domínios principais, acredito que há algo errado no entendimento talvez, não me parece correto eu ter muitos domínios principais, correto?
    Qual sua opinião sobre isso?

  • @brunoocastro
    @brunoocastro 3 ปีที่แล้ว

    Isso que eu chamo de aula!
    Mas essa mosquinha incomodou hein kkkkkkkkkk

  • @nan5782
    @nan5782 3 ปีที่แล้ว

    vcs usaram mvc ou ddd num sistema escolar de pequno porte?

    • @nan5782
      @nan5782 3 ปีที่แล้ว

      @@gregorifelicio6030 acredito que o nivel de aplicabilidade/aprendizado em relacao a cada um seja diferente, o que me faz pensar, qual é o "indicado" para utilizar num sistema escolar de porte pequeno.

  • @pauloceda5401
    @pauloceda5401 4 ปีที่แล้ว

    Obrigado

  • @mariadapenhadasilva9250
    @mariadapenhadasilva9250 2 ปีที่แล้ว

    Eu so quero saber hoje

  • @aldocostasantos6965
    @aldocostasantos6965 4 ปีที่แล้ว +2

    Odeio aulas teoricas, assisti a tua ate o final totalmente interessado, parabens, 1 hora gasta minha com valor agregado

  • @sarinha1153
    @sarinha1153 3 ปีที่แล้ว +1

    Então é isso? Pensei que fosse algo de outro mundo.

  • @gilvanmuniz7783
    @gilvanmuniz7783 4 ปีที่แล้ว

    Professor vc foi show, mais esqueceu de colocar seu nome no video...kkkk como vejo a implementação..

  • @mundoejava
    @mundoejava 4 ปีที่แล้ว

    Muito boa aula, ótimo trabalho.
    Pelo meu pontos de observação vc manteve o mesmo modelo teórico de tantos outros materiais na internet.
    A minha grande duvida com DDD é com a parte de entidades.
    Se vc observar na sua aula. Vc demostra duas entidates dentre os objetos agregados.
    Porem o seu repositório so considera uma (pagamento). Mesmo sabendo que em uma aplicação real, a transação e crucial para um sistema de pagamentos.
    O que vc chama de (Value object) por exemplo e uma informacao que pode ser persistida em banco de dados. Ela é de grande importancia para alguns segmentos.
    Mas no seu exemplo ela é tratada como um "tipo" simplesmente. E vc não considerou o vínculo que ela deveria ter com o assinante.
    No seu modelo, um pagamete tem relação com a assinatura, como seria este relacionamente. Se vc observar o status da assinatura pode mudar por consequecia do pagamento.
    Em DDD estes exemplos incompletos que encontramos ate mesmo no livro do Eric tornam a implementacao muito dificil. Tanto que até hj nunca vi uma implementacao de DDD que
    pudessemos considerar 100% correta. Assim como a sua que possui espaços em branco.
    Mas valeu, foi um grande trabalho e tenho certeza que demandou um esforço considerável.

  • @dom6477
    @dom6477 3 ปีที่แล้ว

    Uma coisa que não entendo é porque insistem em chamar subdomínio de domínio. Outra coisa foi como achar todos aqueles subdomínios a partir de um único caso de uso.

  • @riqpelego
    @riqpelego 3 ปีที่แล้ว

    brabo