A work-in-progress definition of terms that are not expressed as patterns.
A service’s reason for existing. It consists of:
A command is an operation that mutates data.
A component is a software unit that is executable or deployable. For example, a Java WAR file or executable JAR file; or an operating system executable.
Developed by the authors of Accelerate, the DORA metrics measure the performance of a software development teams:
The DORA DevOps Quick Check is a simple five question assessment of how well you are delivering software.
A variant of the monolithic architecture that is organized around subdomains (e.g. business capabilities) rather than technical layers (e.g. presentation, business logic, persistence).
An architectural style that structures the application as a single executable/deployable component. See the Monolithic architecture pattern for more details.
An architectural style that structures at application as set of loosely coupled, independently deployable components (a.k.a. services). See the Microservice architecture pattern for more details.
An operation is an invocable behavior of a service. There are two types of operations: commands and queries. An operation can be invoked by a service client either synchronously or asynchronously. It might also be invoked by the passing of time, e.g. to implement a batch job.
A pattern is a "reusable solution to a problem that occurs in particular context". Read more
A query is an operation that retrieves data.
Each service is an element of the Microservice Architecture that is:
A service has an API.
A system operation is an invocable behavior of the application. There are two types of operations: commands and queries. An operation is invoked by an application client - human via UI, or an external application - either synchronously or asynchronously. It might also be invoked by the passing of time, e.g. a batch job that is executed periodically.
In a microservice architecture, a system operation is either local or distributed. A local operation is implemented by a single service. A distributed operation is implemented by multiple collaborating services.
Microservices.io is created by Chris Richardson, software architect, creator of the original CloudFoundry.com, and author of Microservices Patterns. Chris advises organizations on modernization, architecture, and building systems that avoid becoming modern legacy systems.
Avoid the trap of creating a modern legacy system — a new architecture with the same old problems.
Contact me to discuss your modernization goals.
I am very excited to announce that the MEAP for the second edition of my book, Microservices Patterns is now available!
Learn moreGot a question about microservices?
Fill in this form. If I can, I'll write a blog post that answers your question.
I help organizations improve agility and competitiveness through better software architecture.
Learn more about my consulting engagements, and training workshops.
Chris teaches comprehensive workshops for architects and developers that will enable your organization use microservices effectively.
Avoid the pitfalls of adopting microservices and learn essential topics, such as service decomposition and design and how to refactor a monolith to microservices.
Learn moreGot a specific microservice architecture-related question? For example:
Consider signing up for a two hour, highly focussed, consulting session.
Assess your application's microservice architecture and identify what needs to be improved. Engage Chris to conduct an architect review.
Chris offers numerous other resources for learning the microservice architecture.
Want to see an example? Check out Chris Richardson's example applications. See code
My virtual bootcamp, distributed data patterns in a microservice architecture, is now open for enrollment!
It covers the key distributed data management patterns including Saga, API Composition, and CQRS.
It consists of video lectures, code labs, and a weekly ask-me-anything video conference repeated in multiple timezones.
The regular price is 395ドル/person but use coupon OFFEFKCW to sign up for 95ドル (valid until Sept 30th, 2025). There are deeper discounts for buying multiple seats.
Take a look at my Manning LiveProject that teaches you how to develop a service template and microservice chassis.
Engage Chris to create a microservices adoption roadmap and help you define your microservice architecture,
Use the Eventuate.io platform to tackle distributed data management challenges in your microservices architecture.
Eventuate is Chris's latest startup. It makes it easy to use the Saga pattern to manage transactions and the CQRS pattern to implement queries.
Join the microservices google group
Note: tagging is work-in-process
Cynefin · DDD · GitOps · Microservices adoption · ancient lore · anti-patterns · api gateway · application api · application architecture · architecting · architecture · architecture documentation · assemblage · automation · beer · books · build vs buy · containers · culture · dark energy and dark matter · decision making · deliberative design · deployment · deployment pipeline · design-time coupling · developer experience · development · devops · docker · eventuate platform · fast flow · genAI development · generative AI · glossary · health · hexagonal architecture · implementing commands · implementing queries · inter-service communication · kubernetes · loose coupling · manning publications · microservice architecture · microservice chassis · microservices adoption · microservices platforms · microservices rules · microservicesio updates · modular monolith · multi-architecture docker images · observability · pattern · pattern language · patterns · refactoring · refactoring to microservices · resilience · runtime coupling · sagas · scripting · security · service api · service architecture · service blueprint · service collaboration · service design · service discovery · service granularity · service template · socio-technical architecture · software delivery metrics · success triangle · survey · tacos · team topologies · technical debt · testing · transaction management · transactional messaging · wardley mapping