Skip to content

A curated list of Domain-Driven Design (DDD), Command Query Responsibility Segregation (CQRS), Event Sourcing, and Event Storming resources

Notifications You must be signed in to change notification settings

forkarea/awesome-ddd

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 

Repository files navigation

Awesome Domain-Driven Design Awesome

A curated list of Domain-Driven Design (DDD), Command Query Responsibility Segregation (CQRS), Event Sourcing, and Event Storming resources.

Check out my blog and weekly DDD newsletter or say hi on Twitter!

Domain-Driven Design (DDD) is an approach to software development for complex needs by connecting the implementation to an evolving model. The premise of Domain-Driven Design is the following:

  • placing the project's primary focus on the core domain and domain logic
  • basing complex designs on a model of the domain
  • initiating a creative collaboration between technical and domain experts to iteratively refine a conceptual model that addresses particular domain problems

The term was coined by Eric Evans in his book of the same title.

Command Query Responsibility Segregation (CQRS) is simply the creation of two objects where there was previously only one. The separation occurs based upon whether the methods are a command or a query (the same definition that is used by Meyer in Command and Query Separation, a command is any method that mutates state and a query is any method that returns a value).

Event Sourcing The fundamental idea of Event Sourcing is that of ensuring every change to the state of an application is captured in an event object, and that these event objects are themselves stored in the sequence they were applied for the same lifetime as the application state itself.

Event Storming is a workshop format for quickly exploring complex business domains.

Contents

Books

Training Courses

Video Collections

Community Resources

  • DDD/CQRS Google Group - An active mailing list and an excellent resource to ask questions and learn fine-grained details about DDD/CQRS.
  • Domain Driven Design Yahoo Group - This group is for discussion of the domain-driven style of designing software, and the book by Eric Evans, Domain-Driven Design: Tackling Complexity in the Heart of Business Software. Questions and discussion of the book content is welcome here, as well as sharing of experiences applying DDD, and discussions of the topic in general.
  • DDDinPHP Google Group - The place to discuss Domain-Driven Design, CQRS, Event Sourcing, Model Storming, Hexagonal Architecture, Distributed Systems, Reactive... in the context of PHP.
  • EventStormers Google+ Community - A public discussion group for everybody interested in EventStorming, and related themes.
  • DDD/CQRS/ES Slack - A slack team for those who want to chat about Domain-Driven Design, CQRS, Event Sourcing and sometimes random things. Main channel is language and framework agnostic.

Blogs

Sample Projects

Libraries and Frameworks

  • Event Store - The open-source, functional database with Complex Event Processing in JavaScript.
  • Axon Framework - The axon framework is focused on making life easier for developers that want to create a java application based on the CQRS principles.
  • MessageRouter - Quicken Loans. Described in this video: The Beating Heart of CQRS, or Actor-Based Message Routing on the CLR by Paulmichael Blasucci at the New York F# .NET User Group.
  • NEventStore - A persistence library used to abstract different storage implementations when using event sourcing as storage mechanism.
  • Projac - Yves Reynhout. Projac is a set of projection libraries that allow you to write projections targetting various backing stores.
  • Streamstone - Yevhen Bobrov. Event Store for Azure Table Storage.
  • Value - Thomas Pierrain. Help you to easily implement Value Types in your C# projects without making errors nor polluting your domain logic with boiler-plate code.
  • Cirquis - d60 A/S. d60 event sourcing + CQRS framework.
  • Its.Cqrs - Jon Sequeira. A set of libraries for CQRS and Event Sourcing, with a Domain-Driven Design flavor.
  • AggregateSource - Yves Reynhout. Lightweight infrastructure for doing eventsourcing using aggregates.
  • JESA - Yves Reynhout. Event sourced aggregates for Java.
  • EventFlow - Rasmus Mikkelsen. Async/await first CQRS+ES and DDD framework for .NET http://geteventflow.net/.
  • cqrs.js - Adriano Raiano. CQRS implementations in node.js. Includes node-eventstore, node-cqrs-domain, node-eventdenormalizer, node-cqrs-saga.
  • Eventsourcing - Business event capture and querying framework.
  • CQRS on Azure Duncan Jones. CQRS on Windows Azure.
  • SeedStack's Business Framework - a set of building blocks that enable you to code business logic according to the Domain-Driven Design (DDD) approach.
  • SqlStreamStore - Damian Hickey. .NET Stream Store library targeting SQL based implementations.
  • NServiceBus - Particular Software (Udi Dahan). The most popular service bus for .NET.
  • MassTransit - David Prothero, Chris Patterson. Distributed Application Framework for .NET.
  • Akka.NET - Akka.NET is a toolkit and runtime for building highly concurrent, distributed, and fault tolerant event-driven applications on .NET & Mono.
  • ASP.NET Boilerplate - ASP.NET MVC, Web API and ASP.NET Core based application framework to create NLayered, Domain Driven Designed web Applications implementing best practices.

Podcasts and Interviews

User Groups

License

CC0

To the extent possible under law, Nick Chamberlain has waived all copyright and related or neighboring rights to this work.

About

A curated list of Domain-Driven Design (DDD), Command Query Responsibility Segregation (CQRS), Event Sourcing, and Event Storming resources

Resources

Code of conduct

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published