Chapter 7. Building Evolvable Architectures
Until now, weâve addressed the two primary aspects of evolutionary architectureââmechanics and structureââseparately. Now we have enough context to tie them together.
Many of the concepts we discussed arenât new ideas but rather old ideas viewed through a new lens. For example, testing has existed for years, but not with the fitness function emphasis on architectural verification. Continuous Delivery defined the idea of deployment pipelines. Evolutionary architecture shows architects how to add governance to that automation.
Many organizations pursue Continuous Delivery practices as a way to increase engineering efficiency for software development, a worthy goal in itself. However, weâre taking the next step, using those capabilities to create something more sophisticatedââarchitectures that evolve with the real world.
So how can developers take advantage of these techniques on projects, both existing and new?
Principles of Evolutionary Architecture
Overarching both mechanics and structure in evolutionary architecture are five general principles. Letâs look at them now.
Last Responsible Moment
The agile development world has long extolled the virtues of last responsible moment: delaying decisions as long as you can, but no longer. Making decisions too early tends toward overengineering, and too late leads to failure to meet architectural goals.
The goal isnât to unnecessarily delay. Rather, if an architect can ...
Get Building Evolutionary Architectures, 2nd Edition now with the O’Reilly learning platform.
O’Reilly members experience books, live events, courses curated by job role, and more from O’Reilly and nearly 200 top publishers.