
Design is not just what it looks like and feels like. Design is how it works.
– Steve Jobs –
The software development approach called Domain-Driven Design, or DDD, exists to help us more readily succeed at achieving high-quality software model designs. When implemented correctly, DDD helps us reach the point where our design is exactly how the software works.
It’s a software model of the very specific business domain you are working in. Often it’s implemented as an object model, where those objects have both data and behavior with literal and accurate business meaning. Creating a unique, carefully crafted domain model at the heart of a core, strategic application or subsystem is essential to practicing DDD. With DDD your domain models will tend to be smallish, very focused. Using DDD, you never try to model the whole business enterprise with a single, large domain model. Phew, that’s good!”
Consider the people who can benefit from DDD. From Junior, Mid-level, Senior Developer, Domain Expert, Manage each of them has separated perspective. But whoever you are, here’s an important heads-up. To succeed with DDD you are going to have to learn something, and actually a lot of somethings.
The software is not about technology, but about the business.
One of the worst disconnects of a business software development effort is seen in the gap between domain experts and software developers. Domain expert are focused on delivering the business value while software developers are the technology, technical solutions. Over time this disconnect becomes costly. The translation of domain knowledge into software is lost as developers transition to other projects or leave the company.
Worse still is when the technical approach to software development actually wrongly changes the way the business functions.
DDD is an approach to developing software that focuses on these three primary aspects:
We primarily want to use DDD in the areas that are most important to the business. You don’t invest in what can be easily replaced.
Use DDD to Simplify, Not to Complicate
There are two primary pillars:
For now, think of a Bounded Context as a conceptual boundary around a whole application or finite system. The reason for this boundary is to highlight that every use of a given domain term, phrase, or sentence-the Ubiquitous Language-inside the boundary has a specific contextual meaning. Any use of the term outside that boundary could, and probably does, mean something different.
The Ubiquitous Language is a shared team language. It’s shared by domain experts and developers alike. In fact, it’s shared by everyone on the project team. No matter your role on the team, since you are on the team you use the Ubiquitous Language of the project. The Ubiquitous Language is a shared language developed by the team-a team composed of both domain experts and software developers.
Ubiquitous, but Not Universal
Some further clarification about the reach of a Ubiquitous Language is in order. There are a few basic concepts that we need to keep carefully in mind:
The value and benefits are summarized here ordered by the less technical benefits:
As we implement DDD, we will encounter challenges. There are several common challenges that we are going to face: