Sponsor: Do you build complex software systems? See how NServiceBus makes it easier to design, build, and manage software systems that use message queues to achieve loose coupling. Get started for free.
Developing and thinking about features not layers is something I’ve moved towards over the last several years. I’ve mentioned it in several blog posts and I don’t think I ever explicitly created a post about it.CQRS
The real enabler has been CQRS. For those unfamiliar with CQRS or if you think it’s complicated, let me share a quote from Greg Young: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).That’s it. It’s nothing more complicated than that. I think where the confusion lies is a lot of articles, blog posts, etc where the content describes much more than CQRS. CQRS is not event sourcing. CQRS is not domain driven design. CQRS does not mean multiple data stores. CQRS does not mean using a service bus. CQRS does mean having eventual consistency. CQRS is simply the creation of two objects where there was previously only one.
Features vs Layers
For me a feature in the technical sense is a command or a query. It could also be a combination of a few put together. I often have commands and queries dictate on their own how they are layered inside. This means that an individual command decides how it may do data access. It may not be a shared concern between another command. For comparison, here’s is how I visualize the difference.Layered
data:image/s3,"s3://crabby-images/a8680/a8680bd388e7b4a2b416c48f828961f2a67cfab4" alt="Layered"
CQRS
data:image/s3,"s3://crabby-images/98376/9837687710f49f1a15bf5fe3427c7a8634baacc0" alt="Features not Layers"
There’s a typo here and I just wanted to confirm your meaning: “CQRS does imply mean eventual consistency.”
Thank you! This has been fixed.
It’s not fixed yet, came to report the same.
Ugh. Thanks. It autosaved but didn’t update the post.
And great post btw. It’s a really freeing way to think!
I believe it was you who introduced me to this idea a while back; anyway, I’ve since been won over and had a chance to start a new project building and organizing like this, and it just works so well. A whole class of annoyances don’t exist anymore – scrolling through all the views/controllers/js files just to find the single one you want, anyone?
+1. I often wonder why I followed the convention of organizing by technical concern for so long when the other approach falls more in line with how you actually develop.
Great article Derek,
Thanks! I do think a layered approach is fading away more and more. I think the shift has been to first focus on use cases/business capabilities/features rather primary focus on the technical concerns.