DDD and Microservices: At Last, Some Boundaries!

Поділитися
Вставка
  • Опубліковано 16 січ 2025

КОМЕНТАРІ • 29

  • @zhou7yuan
    @zhou7yuan 4 роки тому +15

    Why do I like microservices? [3:03]
    Services and Messages [5:15]
    Bounded Context [6:34]
    context / bounded context
    Context Map [8:03]
    A-B partners [8:32]
    bounded contexts translator [8:51]
    Asymmetrical Relationships [9:37]
    (Context Name) --(relationship)--> (Context Name)
    (point toward power)
    [10:17]
    C A -- B (ContextMap)
    C conforms A
    There are always multiple models [14:41]
    Models need to be clear, not big [15:28]
    when design of 1 component start to go wrong [17:27]
    Not all of a large system will be well designed [20:45]
    mitigation [21:25]
    Microservices as Context Boundary [22:49]
    Interchange Context [24:20]
    C,D,E -> I

  • @JosemyDuarte
    @JosemyDuarte 4 роки тому +17

    Settings -> Reproduction Speed -> 1,5X

    • @kodermail
      @kodermail 3 роки тому +3

      shift+>, shift+> )

  • @Hangar1318
    @Hangar1318 2 роки тому +5

    As someone new to DDD, I would have loved to see some concrete examples examples instead of A, B, Anti-corruption layer etc. What does it look like in practice? Is the "language" a proto or thrift schema for instance?

  • @patricknazar
    @patricknazar 5 років тому +8

    "Just because something is popular doesn't mean it's bad" Oh man this was funny to hear.

  • @tkousek1
    @tkousek1 6 років тому +3

    Thank you for this great presentation

  • @prabhusingh7481
    @prabhusingh7481 6 років тому +2

    Nice presentation

  • @thatpaulschofield
    @thatpaulschofield 2 роки тому

    I'm having a little bit of trouble how microservice E could publish microservice A's events. Only microservice A is authoritative on those events. An event only has one logical publisher that is the authority for saying that a particular event happened.

  • @pbdrus
    @pbdrus 6 років тому +2

    I'm wondering why do we need the anti-corruption layer on the A and D against the I? Despite the Eric's explanation it seems that since we have introduced the internal interaction language it becomes the part of architecture and thus our modules have to understand it without any restrictions.

    • @b1ueocean
      @b1ueocean 2 роки тому

      Decoupling.
      I was created to represent efficient messaging at interaction or interchange points but if everything consumes I without an AC (which translates internal A, D messages to I messages and I messages to internal A, D messages etc. with internal message schemas evolving independently) then I ends up in the same situation as A before I was created - becomes hard to change I without having to change conformers and/or partners as multiple interacting services are tightly coupled around messaging schemas recognised and in use across service boundaries.

  • @nexus888
    @nexus888 2 роки тому

    This is all good in theory. What we need is to see some examples of how these interchange contexts. Sorry but sounds like you are proposing something very similar to a high level enterprise canonical model for common entities. If you have multiple of these then you fragment things further and have multiple mappings depending on who you talk to in the enterprise. Try for instance and explain your context map in the context of a customer entity that has a set of fields. How is this dealt with when you have transformations that doesn’t necessarily map nicely? In that case the organisation need to agree on the definition on the customer entity at an enterprise level and the rest will have to align.

  • @chris.dillon
    @chris.dillon 7 років тому +3

    I wonder if a bunch of GraphQL endpoints would make a good "I" node for the interchange? It's pretty flexible and would handle change well. I'm sure the answer is "it depends" but GraphQL has sort of schemaless contracts and explicit attribute deprecation without API versioning problems.

    • @htondkar
      @htondkar 6 років тому

      exactly what is was thinking

    • @MaTeGames
      @MaTeGames 5 років тому

      Yes, but in case of messaging we can't use GraphQL.

    • @bartvanderwal6730
      @bartvanderwal6730 5 років тому

      @@MaTeGames Why not? Do you mean that messaging is two-directional communication and GraphQL is one way communication. E.g. post a query or a command and get the response. This just means that for two-way communication both systems have to be both a GraphQL server and a GraphQL client.

    • @alexbruns4568
      @alexbruns4568 2 роки тому +1

      GraphQL is synchronous. You’ll generally want service to communicate asynchronously to prevent things like rolling outages.

  • @AMR3230X
    @AMR3230X 5 років тому +15

    So slow it put me to sleep.

    • @inc.1424
      @inc.1424 5 років тому +3

      Yeah, a bit, but for non-native English speakers/listeners is good)

    • @gabcot03
      @gabcot03 5 років тому +4

      1.25x speed

    • @imienazwisko486
      @imienazwisko486 5 років тому +1

      @@gabcot03 I've used 1.75 XD

    • @chapultepec
      @chapultepec 4 роки тому

      I barely understand english so Im fine with Evans' slowtalk 😅

    • @sohamjoshi9527
      @sohamjoshi9527 2 роки тому

      i understand the speed was slow.. but the content is top notch isnt it ?

  • @johnnm3207
    @johnnm3207 3 роки тому

    1.5x speed is the sweet spot

  • @semremal
    @semremal 3 роки тому

    Everyone who speaks about microservices without mentioning their drawbacks deserves dislike automatically.