Presentation: "Acknowledging CAP at the Root -- in the Domain Model"

Time: Thursday 14:50 - 15:40

Location: Grand Ballroom A

Abstract:

The techniques used to distribute software, scale it through concurrency or make it tolerant of latency are hobbled when, deep inside, the business logic is based on inappropriate assumptions of consistency. Yet it is common to do domain modeling and design business features heedless of these issues, and then patch things up after the fact with technical tricks. In DDD, we consider the the CAP tradeoffs to be central concerns of the design, and we incorporate into our domain models explicit assertions about the boundaries of consistency. When deployment reveals that additional or different CAP tradeoffs must be made, we go back to the root of the problem and modify the  domain model to reflect those tradeoffs explicitly. In this talk, I’ll discuss three DDD patterns that help us address CAP tradeoffs: Aggregates, Domain Events and Bounded Contexts. 

I will not be able to explain these patterns in depth, but I hope to give a sense of the nature of these conceptual tools and where they come into play in designing practical systems constrained by CAP.

Eric Evans, Author of Domain Driven Design

 Eric  Evans

Eric Evans is a specialist in domain modeling and design in large business systems. Since the early 1990s, he has worked on many projects developing large business systems with objects and has been deeply involved in applying Agile processes on real projects.

Out of this range of experiences emerged the synthesis of principles and techniques shared in the book "Domain-Driven Design," Addison-Wesley 2003.

Eric now leads Domain Language, Inc., a consulting group which coaches and trains teams to make their development more productive and relevant through effective application of domain modeling and design.

Software Passion: Breaking My Own Domain Models

Website: http://www.domainlanguage.com/

Books: Domain-Driven Design: Tackling Complexity in the Heart of Software