SlideShare a Scribd company logo
Design Patterns for Scalable
APIs Based on Docker
@stoitsev
docker run ufaldsg/cloud-asr-api
https://www.dockerbook.com/
Class
Object
Image
Container
Design Patterns for Docker Applications
Map/Reduce
https://www.usenix.org/node/196347
Single-node, multi-container
Application patterns
Sidecar
Web server Log server
File System
Sidecar
Application Instance
Translations
Downloader
File System
Resource Isolation
Separate development
Easy and flexible composition
Failure containment
Ambassador
Web Server Ambasador
External App
External App
External App
Ambassador
Application Hyperbahn Instance
Hyperbahn Instance
Hyperbahn Instance
Hyperbahn Instance
https://github.com/uber-archive/hyperbahn
Easy to reason about
Easy to test
Reusable
Adapter
Application Monitoring Adapter
Centralized
monitoring system
Multi-node application patterns
Leader election
App
Leader
election
container
App
Leader
election
container
App
Leader
election
container
App
Leader
election
container
Simplifies the problem
Easy testing
Work queue
Worker
Work
Execution
Worker
Work
Execution
Work Coordinator
Simplification
Scatter/gather
Merge
Execution
Work
Execution
Work
Execution
Root
Work
Execution
Design Patterns for Docker Applications
Idempotent
Pure
Composable
http://eng.uber.com/
Thanks

More Related Content

PDF
Distributed tracing for Node.js
PDF
Resillient microservices with AKS
PDF
Improve Monitoring and Observability for Kubernetes with OSS tools
PDF
TechXLR8 - XLR8 your cloud with Docker and Serverless FaaS
PDF
[Kotlin Serverless 工作坊] 單元 1 - 開發環境建置
PPTX
Serverless on Kubernetes
PDF
Improve monitoring and observability for kubernetes with oss tools
PDF
Improve monitoring and observability for kubernetes with oss tools
Distributed tracing for Node.js
Resillient microservices with AKS
Improve Monitoring and Observability for Kubernetes with OSS tools
TechXLR8 - XLR8 your cloud with Docker and Serverless FaaS
[Kotlin Serverless 工作坊] 單元 1 - 開發環境建置
Serverless on Kubernetes
Improve monitoring and observability for kubernetes with oss tools
Improve monitoring and observability for kubernetes with oss tools

What's hot (20)

PDF
Scaling .net containers with event driven workloads
PDF
Serverless Containers
PDF
Kubernetes Sealed secrets
PDF
Event driven workloads on Kubernetes with KEDA
PPTX
SFNode 01-2018 - Aquarium control
PDF
今日から始める Azure Functions 2.0
PDF
Monitoring kubernetes wwith prometheus and grafana azure singapore - 19 aug...
PDF
Managing Your Infrastructure on Azure using SaltStack
PDF
JAX 2013: Introducing Eclipse Orion
PDF
Kubernetes Native Serverless solution: Kubeless
PPTX
Дмитрий Иванов «Мое первое приложение в облаках или почему стоит использовать...
PDF
CI CD with Docker and Kubernetes
PPTX
The journey to the kubernetes metrics
PPTX
Serverless with Kubernetes
PDF
Kubernetes extensibility: crd & operators
PDF
EclipseCon-Europe 2013: Making the Eclipse IDE fun again
PDF
Event driven autoscaling with KEDA
PDF
Microservices: Lessons Learned
PPTX
How do we use Kubernetes
PDF
Zero to #Serverless in 60 seconds, anywhere
Scaling .net containers with event driven workloads
Serverless Containers
Kubernetes Sealed secrets
Event driven workloads on Kubernetes with KEDA
SFNode 01-2018 - Aquarium control
今日から始める Azure Functions 2.0
Monitoring kubernetes wwith prometheus and grafana azure singapore - 19 aug...
Managing Your Infrastructure on Azure using SaltStack
JAX 2013: Introducing Eclipse Orion
Kubernetes Native Serverless solution: Kubeless
Дмитрий Иванов «Мое первое приложение в облаках или почему стоит использовать...
CI CD with Docker and Kubernetes
The journey to the kubernetes metrics
Serverless with Kubernetes
Kubernetes extensibility: crd & operators
EclipseCon-Europe 2013: Making the Eclipse IDE fun again
Event driven autoscaling with KEDA
Microservices: Lessons Learned
How do we use Kubernetes
Zero to #Serverless in 60 seconds, anywhere
Ad

Similar to Design Patterns for Docker Applications (20)

PDF
Reusable patterns for scalable APIs running on Docker @ Java2Days
PPTX
7 Container Design Patterns
PPTX
Microservices
PPTX
Microservices with Docker
PDF
Microservices Docker @Bonn Agile
PDF
Move fast and make things with microservices
PDF
The Kubernetes Effect
PPTX
Cloud design principles
PPTX
Azure architecture design patterns - proven solutions to common challenges
PPTX
Going MicroServices with Net
PPTX
Microservices and docker
PDF
ContainerDayVietnam2016: Become a Cloud-native Developer
PDF
Microservices for Application Modernisation
PDF
Understanding Microservices
PDF
Microservices Design Principles.pdf
PPTX
Building cloud native apps
PDF
Richardrodger nodeday-2014-final
PDF
Richardrodger nodeday-2014-final
PPTX
Net core microservice development made easy with azure dev spaces
PPTX
Tokyo Azure Meetup #5 - Microservices and Azure Service Fabric
Reusable patterns for scalable APIs running on Docker @ Java2Days
7 Container Design Patterns
Microservices
Microservices with Docker
Microservices Docker @Bonn Agile
Move fast and make things with microservices
The Kubernetes Effect
Cloud design principles
Azure architecture design patterns - proven solutions to common challenges
Going MicroServices with Net
Microservices and docker
ContainerDayVietnam2016: Become a Cloud-native Developer
Microservices for Application Modernisation
Understanding Microservices
Microservices Design Principles.pdf
Building cloud native apps
Richardrodger nodeday-2014-final
Richardrodger nodeday-2014-final
Net core microservice development made easy with azure dev spaces
Tokyo Azure Meetup #5 - Microservices and Azure Service Fabric
Ad

More from Nikolay Stoitsev (20)

PDF
Building vs Buying Software
PDF
How and why to manage your manager
PDF
From programming to management
PDF
A practical introduction to observability
PDF
Building a modern SaaS in 2020
PDF
Everything You Need to Know About NewSQL in 2020
PDF
3 lessons on effective communication for engineers
PDF
ISTA 2019 - Migrating data-intensive microservices from Python to Go
PDF
Evolving big microservice architectures
PDF
The career path of software engineers and how to navigate it
PDF
Migrating a data intensive microservice from Python to Go
PDF
Using Apache Kafka from Go
PDF
Large scale stream processing with Apache Flink
PDF
Scaling big with Apache Kafka
PDF
NewSQL: what, when and how
PDF
How to read the v8 source code?
PDF
Running in multiple data centers
PDF
Distributed tracing for big systems
PDF
Everyday tools and tricks for scaling Node.js
PDF
Node.js at Uber
Building vs Buying Software
How and why to manage your manager
From programming to management
A practical introduction to observability
Building a modern SaaS in 2020
Everything You Need to Know About NewSQL in 2020
3 lessons on effective communication for engineers
ISTA 2019 - Migrating data-intensive microservices from Python to Go
Evolving big microservice architectures
The career path of software engineers and how to navigate it
Migrating a data intensive microservice from Python to Go
Using Apache Kafka from Go
Large scale stream processing with Apache Flink
Scaling big with Apache Kafka
NewSQL: what, when and how
How to read the v8 source code?
Running in multiple data centers
Distributed tracing for big systems
Everyday tools and tricks for scaling Node.js
Node.js at Uber

Recently uploaded (20)

PPTX
Reimagine Home Health with the Power of Agentic AI​
PDF
Cost to Outsource Software Development in 2025
PPTX
Operating system designcfffgfgggggggvggggggggg
PDF
System and Network Administration Chapter 2
PDF
Digital Systems & Binary Numbers (comprehensive )
PDF
Softaken Excel to vCard Converter Software.pdf
PPTX
Computer Software and OS of computer science of grade 11.pptx
PPTX
CHAPTER 2 - PM Management and IT Context
PPTX
Why Generative AI is the Future of Content, Code & Creativity?
PDF
Odoo Companies in India – Driving Business Transformation.pdf
PDF
wealthsignaloriginal-com-DS-text-... (1).pdf
PDF
Digital Strategies for Manufacturing Companies
PPTX
Agentic AI Use Case- Contract Lifecycle Management (CLM).pptx
PDF
Wondershare Filmora 15 Crack With Activation Key [2025
PPTX
Odoo POS Development Services by CandidRoot Solutions
PPTX
Agentic AI : A Practical Guide. Undersating, Implementing and Scaling Autono...
PPTX
Log360_SIEM_Solutions Overview PPT_Feb 2020.pptx
PDF
Claude Code: Everyone is a 10x Developer - A Comprehensive AI-Powered CLI Tool
PDF
Adobe Illustrator 28.6 Crack My Vision of Vector Design
PDF
Adobe Premiere Pro 2025 (v24.5.0.057) Crack free
Reimagine Home Health with the Power of Agentic AI​
Cost to Outsource Software Development in 2025
Operating system designcfffgfgggggggvggggggggg
System and Network Administration Chapter 2
Digital Systems & Binary Numbers (comprehensive )
Softaken Excel to vCard Converter Software.pdf
Computer Software and OS of computer science of grade 11.pptx
CHAPTER 2 - PM Management and IT Context
Why Generative AI is the Future of Content, Code & Creativity?
Odoo Companies in India – Driving Business Transformation.pdf
wealthsignaloriginal-com-DS-text-... (1).pdf
Digital Strategies for Manufacturing Companies
Agentic AI Use Case- Contract Lifecycle Management (CLM).pptx
Wondershare Filmora 15 Crack With Activation Key [2025
Odoo POS Development Services by CandidRoot Solutions
Agentic AI : A Practical Guide. Undersating, Implementing and Scaling Autono...
Log360_SIEM_Solutions Overview PPT_Feb 2020.pptx
Claude Code: Everyone is a 10x Developer - A Comprehensive AI-Powered CLI Tool
Adobe Illustrator 28.6 Crack My Vision of Vector Design
Adobe Premiere Pro 2025 (v24.5.0.057) Crack free