Cloud Native
Reactive
Microservices
Architecture
Patterns for resiliency and scalability
Renato Cordeiro Ferreira
2020
RENATO CORDEIRO FERREIRA
Principal Machine Learning Engineer at Elo7
Focused in creating intelligent systems architectures
and bring machine learning into production
Master in Computer Science at USP
Studying software engineering and data science
Starting my PhD at USP
Future thesis about intelligent systems
Co-founder of CodeLab
Inter-university extension group focused on stimulating the technological innovation in universities
Cloud Native Reactive Microservices Architecture creates systems that scale
Cloud Native Applications
Reactive Applications
Microservices Architecture
Microservices Architectures
Organizations which design
systems... are constrained to
produce designs which are
copies of the communication structures of these organizations
Conway's Law
https://twitter.com/conways_law
Microservices are small, autonomous services that work together
Sam Newman, Building Microservices
The microservice architectural style is an approach to developing a single application as a suite of small services, each running in its own process and communicating with lightweight mechanisms, often an HTTP resource API
James Lewis & Martin Fowler
Domain-driven design. Continuous delivery. On-demand virtualization. Infrastructure automation. Small autonomous teams. Systems at scale. Microservices have emerged from this world. They weren’t invented or described before the fact; they emerged as a trend, or a pattern, from real-world use. But they exist only because of all that has gone before.
Sam Newman, Building Microservices
Microservices-Based Architecture is a simple concept: it advocates creating a system from a collection of small, isolated services, each of which owns their data, and is independently isolated, scalable and resilient to failure. Services integrate with other services in order to form a cohesive system that’s far more flexible than the typical enterprise systems we build today.
Jonas Bonér, Reactive Microservices Architecture
Microservices-Based Architecture is a simple concept: it advocates creating a system from a collection of small, isolated services, each of which owns their data, and is independently isolated, scalable and resilient to failure. Services integrate with other services in order to form a cohesive system that’s far more flexible than the typical enterprise systems we build today.
Jonas Bonér, Reactive Microservices Architecture
Rails
Django
Laravel
Angular + Express
React + Flask
Vue + Koa
Multiple languages
and databases (polyglote)
MVC
SPA + Microframework
How to do it?
Cloud Native Applications
A cloud native application is engineered to run on a platform
and is designed for resiliency,
agility, operability, and observability
Cloud native Infrastructure: Patterns for Scalable Infrastructure and Applications in a Dynamic Environment
Embrace failures instead
of trying to prevent them
(take advantage of the dynamic nature of running on a cloud platform)
Resiliency
Allow for fast deployments
and quick iterations
(the same idea behind the agile software development movement)
Agility
Add control of application life cycles from inside of it
(instead of relying on external processes
and monitors)
Operability
Provide information to know about the application state
(add ways of querying the current state
of a given application)
Observability
Reactive Applications
We believe that a coherent approach to systems architecture is needed, and we believe that all necessary aspects are already recognised individually: we want systems that are Responsive, Resilient, Elastic and Message Driven. We call these Reactive Systems
Reactive Manifesto
https://reactivemanifesto.org
The system responds in a
timely manner if at all possible
(establish reliable upper bounds to deliver
a consistent quality of service)
Responsive
The system stays responsive
in the face of failure
(resilience is achieved by replication, containment, isolation and delegation)
Resilient
The system stays responsive under varying workload.
(react to changes in the input rate by
increasing or decreasing resources)
Elastic
The system relies on async message-passing
(that ensures loose coupling, isolation and location transparency)
Observability
Source: https://dzone.com/articles/microservices-with-cqrs-and-event-sourcing
Source: https://dzone.com/articles/microservices-with-cqrs-and-event-sourcing
Source: https://dzone.com/articles/microservices-with-cqrs-and-event-sourcing
Learning more
Cloud Native Reactive Microservices Architecture creates systems that scale
Cloud Native Applications
Reactive Applications
Microservices Architecture
There is no silver bullet: choose the architecture that best suits you!
Cloud Native
Reactive
Microservices
Architecture
Patterns for resiliency and scalability
Renato Cordeiro Ferreira
2020