The debate on monoliths vs microservices as architectural patterns for modern software systems usually focuses on technological aspects, missing crucial details around organizational strategy and team dynamics.
Should we start with a monolith and extract microservices or start with microservices? How many microservices is the right number? These kinds of questions indicate a confusion that is made worse by the perceived need to adopt lots of new technology in order to make microservices work.
The false dichotomy between monoliths and microservices helps no-one. Instead, switched-on organizations start with the team cognitive load required to build and run a part of the software system. If a team is not able to fully understand the details of a service or subsystem, there is little chance of the team being able to own and support it.
The resulting team-sized services are by definition suitable in size and complexity for a single team to own, develop, and run. No longer do we care how many lines of code there are in a single service or whether it is a “monolith”: what we care about is that a team can own and run the software effectively.
Using team cognitive load as the guiding principle - assessed by the team via measures such as supportability, deployability, testability, operability, prioritization difficulties and domain complexity - organizations can optimize for sustainable ownership and evolution of software systems.
This talk draws on research and case studies from the book Team Topologies by Matthew Skelton and Manuel Pais (IT Revolution Press, 2019) together with first-hand consulting experience from the authors with organizations around the world.
2. Who am I ?
2
Independent IT organizational consultant and trainer
Ex-dev, ex-build manager, ex-tester, ex-QA lead
LinkedIn instructor on Continuous Delivery
Co-author of the book Team Topologies
4. Team Topologies
4
Organizing business and
technology teams for fast flow
Matthew Skelton & Manuel Pais
IT Revolution Press
Order via stores worldwide: teamtopologies.com/book
8. “Start with monolith and
extract microservices.”
- Tammer Saleh
8
https://www.infoq.com/presentations/cloud-anti-patterns
9. “Don’t start with a
monolith when your goal is
a microservices
architecture”
- Stefan Tilkov
9
http://martinfowler.com/articles/dont-start-monolith.html
10. “If you can't build a
monolith, what makes you
think microservices are
the answer?”
- Simon Brown
10
http://www.codingthearchitecture.com/2014/07/06/distributed_big_balls_of_mud.html
12. “Software that
fits in your head”
- Daniel Terhorst-North
12
https://speakerdeck.com/tastapod/microservices-software-that-fits-in-your-head?slide=62
56. “...trend analysis, simulations, rapid
prototyping, scenario planning,
gaming, environmental scanning
… give clues to the context and
competitive environment.”
- Dr. Naomi Stanford,
“Guide to Organisation Design” (The Economist)
64
83. Do we know which teams we need to
interact with? What outcomes do we
expect from the interaction?
Collaboration, X-as-a-Service, Facilitating
Team Interactions
91
85. Team Topologies
93
Organizing business and
technology teams for fast flow
Matthew Skelton & Manuel Pais
IT Revolution Press
Order via stores worldwide: teamtopologies.com/book
90. Team Topologies for PMs
98
ascent.pmi.org
self-paced 4h course
TT4PM20
20% discount code
More courses from Peter
Drucker, Jeff Gothelf &
Josh Seiden, and others