Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ddd-crew/domain-message-flow-modelling
Design & visualise the flow of commands, events, and queries between your bounded contexts
https://github.com/ddd-crew/domain-message-flow-modelling
architecture domain-driven-design software-design tactical-design-patterns
Last synced: 19 days ago
JSON representation
Design & visualise the flow of commands, events, and queries between your bounded contexts
- Host: GitHub
- URL: https://github.com/ddd-crew/domain-message-flow-modelling
- Owner: ddd-crew
- License: cc-by-sa-4.0
- Created: 2020-05-04T20:31:51.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2023-12-27T16:02:01.000Z (about 1 year ago)
- Last Synced: 2024-11-04T22:36:37.799Z (3 months ago)
- Topics: architecture, domain-driven-design, software-design, tactical-design-patterns
- Homepage:
- Size: 2.13 MB
- Stars: 368
- Watchers: 32
- Forks: 32
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-ccamel - ddd-crew/domain-message-flow-modelling - Design & visualise the flow of commands, events, and queries between your bounded contexts (Misc)
- awesome-starred - ddd-crew/domain-message-flow-modelling - Design & visualise the flow of commands, events, and queries between your bounded contexts (others)
README
# Domain Message Flow Modelling
Designing loosely-coupled systems requires more than carefully designed boundaries. Carefully defined interactions between bounded contexts is equally important.
A [bounded context](https://martinfowler.com/bliki/BoundedContext.html) is a sub-system in a software architecture aligned to a part of the domain. It can be implemented as a microservice or a module within a monolith.
A Domain Message Flow Diagram is a simple visualisation showing the flow of messages (commands, events, queries) between actors, bounded contexts, and systems, for a single scenario.
## Formats
There are 2 basic formats, but there is no formal specification so adjust the tool to suit your needs if the basic formats don't work for you.
### Separate Message & Contents
The separate message & contents format uses 2 shapes for each message: 1 for the name and order of the message and a separate box to display the contents of the message (the information it carries).
The benefit of this format is that you can focus on the flow of messages without getting bogged down by the message contents at the start.
Start by showing just the messages flowing between senders and receivers (with the order number on the message).
![Message Flow Just Messages](resources/just-messages-no-contents.jpg)
Then show the contents of each message in a separate box next to each message:
![Message Flow Messages & Contents](resources/messages-and-contents.jpg)
### Combined Message & Contents
The combined message & contents format uses a single shape to capture the message name, order, and contents.
![Example Message Flow](resources/domain-message-flow.jpg "An Example Domain Message Flow")
This format is good when you want to focus on the contents of each message from the beginning.
### Downloads
- [Domain Message Flow Modelling (miro board backup)](resources/Domain-Message-Flow-Modelling-en-v1.rtb)
## How to Use
When you have an initial cut of your architecture - you have identified candidate bounded contexts - you can begin design the message flows.
Start by creating a list of of scenarios to model. And then for each scenario create a diagram
When creating a diagram, the typical flow is:
1. Start with an actor/context/system
2. Create the message they want to send
3. Add the recipient of the message and a line connecting the sender and the receiver
4. Place the message close to the line
5. Repeat steps 1 - 4 until your scenario is completeThe message should contain 3 elements:
1. The name of the message
2. The significant data contained within the message
3. The order in which the message occurs in the flow being modelled_Note:_ In case of a query, the response is just as important as the request. The information can be seen and represented as one unit, like this
## Visualisation Tips
The number one problem with Domain Message Flow Diagrams, and diagrams in general, is too much information. [Miller's Law](https://en.wikipedia.org/wiki/Miller%27s_law) is a good heuristic to use here. Aim to have between 5 and 9 messages on your diagram.
If you find that adding the data to each message is breaking your flow of progress, you can defer the data section of each message it until you have placed all of your messages.
### Time-Dependent Messages
Sometimes messages are time-driven. E.g. scenario: cancel an online order after 5 minutes of inactivity. A visualisation like this could work fine. Important is to pay attention to the semantics: **within** or **after** or **every** 5 minutes are very different conditions.## Additional Resources
- [DDD Pattern: Library Contexts](https://medium.com/nick-tune-tech-strategy-blog/ddd-pattern-library-contexts-d6ae81f462ef)
- [Mapper Contexts & Supercontexts: Decoupling Domain-Specific and Domain-Generic Bounded Contexts](https://medium.com/nick-tune-tech-strategy-blog/mapper-contexts-supercontexts-decoupling-domain-specific-and-domain-generic-bounded-contexts-5eb6a1e7c5fc)
- [Gateway Interchange Contexts](https://medium.com/nick-tune-tech-strategy-blog/gateway-interchange-contexts-899696e67848)## Contributors
Thanks to all [existing and future contributors](https://github.com/ddd-crew/domain-message-flow-modelling/graphs/contributors) and to the following individuals who have all contributed to Domain Message Flow Modelling:
- [Kacper Gunia](https://github.com/cakper)
- [Zsofia Herendi](https://twitter.com/zherendi)
- [Nick Tune](https://github.com/ntcoding)Domain Message Flow Diagrams are heavily inspired by:
- [Simon Brown's C4 Container Diagrams](https://c4model.com/)
- [Domain Storytelling](https://domainstorytelling.org/)## Contributions and Feedback
The Domain Message Flow Modelling notation is freely available for you to use. In addition, your feedback and ideas are welcome to improve the technique or to create alternative versions.
Feel free to also send us a pull request with your examples.
[![CC BY 4.0][cc-by-shield]][cc-by]
This work is licensed under a [Creative Commons Attribution 4.0 International
License][cc-by].[![CC BY 4.0][cc-by-image]][cc-by]
[cc-by]: http://creativecommons.org/licenses/by/4.0/
[cc-by-image]: https://i.creativecommons.org/l/by/4.0/88x31.png
[cc-by-shield]: https://img.shields.io/badge/License-CC%20BY%204.0-lightgrey.svg