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

What's hot (20)

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

Similar to Design Patterns for Docker Applications (20)

PDF
Reusable patterns for scalable APIs running on Docker @ Java2Days
Nikolay Stoitsev
 
PPTX
7 Container Design Patterns
Christian Melendez
 
PPTX
Microservices
Meysam Javadi
 
PPTX
Microservices with Docker
Venkata Naga Ravi
 
PDF
Microservices Docker @Bonn Agile
Timo Derstappen
 
PDF
Move fast and make things with microservices
Mithun Arunan
 
PDF
The Kubernetes Effect
Bilgin Ibryam
 
PPTX
Cloud design principles
Masashi Narumoto
 
PPTX
Azure architecture design patterns - proven solutions to common challenges
Ivo Andreev
 
PPTX
Going MicroServices with Net
David Revoledo
 
PPTX
Microservices and docker
Alex Ivy
 
PDF
ContainerDayVietnam2016: Become a Cloud-native Developer
Docker-Hanoi
 
PDF
Microservices for Application Modernisation
Ajay Kumar Uppal
 
PDF
Understanding Microservices
M A Hossain Tonu
 
PDF
Microservices Design Principles.pdf
Simform
 
PPTX
Building cloud native apps
Swaminathan Vetri
 
PDF
Richardrodger nodeday-2014-final
Richard Rodger
 
PDF
Richardrodger nodeday-2014-final
Richard Rodger
 
PPTX
Net core microservice development made easy with azure dev spaces
Alon Fliess
 
PPTX
Tokyo Azure Meetup #5 - Microservices and Azure Service Fabric
Tokyo Azure Meetup
 
Reusable patterns for scalable APIs running on Docker @ Java2Days
Nikolay Stoitsev
 
7 Container Design Patterns
Christian Melendez
 
Microservices
Meysam Javadi
 
Microservices with Docker
Venkata Naga Ravi
 
Microservices Docker @Bonn Agile
Timo Derstappen
 
Move fast and make things with microservices
Mithun Arunan
 
The Kubernetes Effect
Bilgin Ibryam
 
Cloud design principles
Masashi Narumoto
 
Azure architecture design patterns - proven solutions to common challenges
Ivo Andreev
 
Going MicroServices with Net
David Revoledo
 
Microservices and docker
Alex Ivy
 
ContainerDayVietnam2016: Become a Cloud-native Developer
Docker-Hanoi
 
Microservices for Application Modernisation
Ajay Kumar Uppal
 
Understanding Microservices
M A Hossain Tonu
 
Microservices Design Principles.pdf
Simform
 
Building cloud native apps
Swaminathan Vetri
 
Richardrodger nodeday-2014-final
Richard Rodger
 
Richardrodger nodeday-2014-final
Richard Rodger
 
Net core microservice development made easy with azure dev spaces
Alon Fliess
 
Tokyo Azure Meetup #5 - Microservices and Azure Service Fabric
Tokyo Azure Meetup
 
Ad

More from Nikolay Stoitsev (20)

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

Recently uploaded (20)

PPT
MergeSortfbsjbjsfk sdfik k
RafishaikIT02044
 
PDF
유니티에서 Burst Compiler+ThreadedJobs+SIMD 적용사례
Seongdae Kim
 
PDF
Build It, Buy It, or Already Got It? Make Smarter Martech Decisions
bbedford2
 
PPTX
Feb 2021 Cohesity first pitch presentation.pptx
enginsayin1
 
PDF
Odoo CRM vs Zoho CRM: Honest Comparison 2025
Odiware Technologies Private Limited
 
PDF
GetOnCRM Speeds Up Agentforce 3 Deployment for Enterprise AI Wins.pdf
GetOnCRM Solutions
 
PPTX
MailsDaddy Outlook OST to PST converter.pptx
abhishekdutt366
 
PDF
MiniTool Partition Wizard 12.8 Crack License Key LATEST
hashhshs786
 
PDF
HiHelloHR – Simplify HR Operations for Modern Workplaces
HiHelloHR
 
PPTX
Engineering the Java Web Application (MVC)
abhishekoza1981
 
PPTX
A Complete Guide to Salesforce SMS Integrations Build Scalable Messaging With...
360 SMS APP
 
PPTX
An Introduction to ZAP by Checkmarx - Official Version
Simon Bennetts
 
PPTX
Agentic Automation Journey Session 1/5: Context Grounding and Autopilot for E...
klpathrudu
 
PDF
Beyond Binaries: Understanding Diversity and Allyship in a Global Workplace -...
Imma Valls Bernaus
 
PPTX
Tally software_Introduction_Presentation
AditiBansal54083
 
PDF
Efficient, Automated Claims Processing Software for Insurers
Insurance Tech Services
 
PDF
vMix Pro 28.0.0.42 Download vMix Registration key Bundle
kulindacore
 
PDF
Capcut Pro Crack For PC Latest Version {Fully Unlocked} 2025
hashhshs786
 
PDF
Mobile CMMS Solutions Empowering the Frontline Workforce
CryotosCMMSSoftware
 
PPTX
Comprehensive Guide: Shoviv Exchange to Office 365 Migration Tool 2025
Shoviv Software
 
MergeSortfbsjbjsfk sdfik k
RafishaikIT02044
 
유니티에서 Burst Compiler+ThreadedJobs+SIMD 적용사례
Seongdae Kim
 
Build It, Buy It, or Already Got It? Make Smarter Martech Decisions
bbedford2
 
Feb 2021 Cohesity first pitch presentation.pptx
enginsayin1
 
Odoo CRM vs Zoho CRM: Honest Comparison 2025
Odiware Technologies Private Limited
 
GetOnCRM Speeds Up Agentforce 3 Deployment for Enterprise AI Wins.pdf
GetOnCRM Solutions
 
MailsDaddy Outlook OST to PST converter.pptx
abhishekdutt366
 
MiniTool Partition Wizard 12.8 Crack License Key LATEST
hashhshs786
 
HiHelloHR – Simplify HR Operations for Modern Workplaces
HiHelloHR
 
Engineering the Java Web Application (MVC)
abhishekoza1981
 
A Complete Guide to Salesforce SMS Integrations Build Scalable Messaging With...
360 SMS APP
 
An Introduction to ZAP by Checkmarx - Official Version
Simon Bennetts
 
Agentic Automation Journey Session 1/5: Context Grounding and Autopilot for E...
klpathrudu
 
Beyond Binaries: Understanding Diversity and Allyship in a Global Workplace -...
Imma Valls Bernaus
 
Tally software_Introduction_Presentation
AditiBansal54083
 
Efficient, Automated Claims Processing Software for Insurers
Insurance Tech Services
 
vMix Pro 28.0.0.42 Download vMix Registration key Bundle
kulindacore
 
Capcut Pro Crack For PC Latest Version {Fully Unlocked} 2025
hashhshs786
 
Mobile CMMS Solutions Empowering the Frontline Workforce
CryotosCMMSSoftware
 
Comprehensive Guide: Shoviv Exchange to Office 365 Migration Tool 2025
Shoviv Software
 

Design Patterns for Docker Applications