SlideShare a Scribd company logo
Designing Microservices
A visual language
for service description
Richard Rodger
@rjrodger
How do you decide which
microservices to build?
Requirements
Messages
Services
"Build a user registration page"
Requirements
àč a) capture user details
àč b) send confirmation email
Requirements
àč a) capture user details
àč b) send confirmation email
Messages
àč a) register-user: {name: ..., email: ...}
àč b) confirm-email: {email: ...}
Requirements
àč a) capture user details
àč b) send confirmation email
Messages
àč a) register-user: {name: ..., email: ...}
àč b) confirm-email: {email: ...}
Services
àč registration sends register-user to user
àč user sends confirm-email to mailer
user registration mailer
register-user confirm-email
When do you need an answer?
àčNow: synchronous
àčNever: asynchronous
Who does the work?
àčOne: message consumed
àčMany: message observed
micro-
service
A
micro-
service
B
solid line means synchronous
solid arrow means consumed
hexagons are microservices
synchronous/consumed
request-response
micro-
service
A
micro-
service
B
dashed line means asynchronous
empty arrow means observed
asynchronous/observed
publish-subscribe
micro-
service
A
micro-
service
B
solid line means synchronous
empty arrow means observed
synchronous/observed
sidewinder
micro-
service
A
micro-
service
B
dashed line means asynchronous
solid arrow means consumed
asynchronous/consumed
winner-take-all
Visual conventions
Service
Synchronous Message
Asynchronous Message
Consumed Message
Observed Message
"Message Abstraction Layer"
sender
receiver
Let's build a Search Engine
for Node.js modules...
Business Requirements:
àč a) search for Node.js modules
àč b) index published Node.js modules
àč c) show Node.js module details
richardrodger-designing-microservices-london-may.pdf
richardrodger-designing-microservices-london-may.pdf
Requirements
àč a) search for Node.js modules
Messages
àč role:search,cmd:search (sync+consume)
Services
àč web sends role:search,cmd:search to
search
web
search
role:search,cmd:search
Requirements
àč b) index published Node.js modules
Messages
àč role:search,cmd:insert (async+observe)
Services
àč npm sends role:search,cmd:insert to
search
web
search
npm
role:search,cmd:search
role:search,cmd:insert
Requirements
àč c) show Node.js module details
Messages
àč role:info,cmd:get (sync+consume)
Services
àč web sends role:info,cmd:get to info
web
search
npm
info
role:search,cmd:search
role:search,cmd:insert
role:info,cmd:get
Requirements
àč c) show Node.js module details
Messages
àč role:info,need:part (async+observe)
àč role:info,collect:part (async+observe)
Services
àč info sends role:info,need:part to npm,
github
àč npm, github send role:info,collect:part to
info
web
search
npm
info
github
role:search,cmd:search
role:search,cmd:insert
role:info,cmd:get
role:info,need:part
role:info,need:part
role:info,collect:part
role:info,collect:part
richardrodger-designing-microservices-london-may.pdf
Demo!
A search engine for
Node.js modules:
github.com/nodezoo
senecajs.org
bit.ly/taomicro
@taomicroservice
Thanks!
Richard Rodger
@rjrodger
richardrodger.com
senecajs.org
Thanks!
Richard Rodger
@rjrodger
richardrodger.com
senecajs.org

More Related Content

PDF
richardrodger-microservice-algebra-cluj-apr.pdf
PPTX
MongoDB Stitch Introduction
PPTX
[MongoDB.local Bengaluru 2018] Introduction to MongoDB Stitch
PPTX
MongoDB Stich Overview
PPTX
Tutorial: Building Your First App with MongoDB Stitch
PPTX
Building Your First App with MongoDB Stitch
PDF
Comet from JavaOne 2008
PPTX
pptindustrial (1).pptx
richardrodger-microservice-algebra-cluj-apr.pdf
MongoDB Stitch Introduction
[MongoDB.local Bengaluru 2018] Introduction to MongoDB Stitch
MongoDB Stich Overview
Tutorial: Building Your First App with MongoDB Stitch
Building Your First App with MongoDB Stitch
Comet from JavaOne 2008
pptindustrial (1).pptx

Similar to richardrodger-designing-microservices-london-may.pdf (20)

PDF
MongoDB Stitch Introduction
PPTX
IRREPORT.pptx
PPTX
Building Apps with MySpace SDKs
PDF
Serverless Design Patterns
PDF
Bringing Transactional Guarantees to MongoDB
PDF
Serveless design patterns
PPTX
Introducing Stitch
PDF
What we have learned about API scaling throughout Messente's international SM...
PDF
QCon London 2020: Streaming a million likes/second Real-time interactions on...
PDF
Micro-service architectures with Gilmour
PPTX
SignalR tutorial & best practices
PPTX
When the connection fails
PPTX
Nathan Winters The Future Of Email Exchange And Online Services
PDF
Codemotion 2019: A million likes/second: Real-time interactions on Live Video
PDF
HBaseCon 2015: S2Graph - A Large-scale Graph Database with HBase
PDF
Serverless Software Architecture - Gears 17
PDF
Serverless Design Patterns (London Dev Community)
PDF
[CB21] ProxyLogon is Just the Tip of the Iceberg, A New Attack Surface on Mic...
PDF
Hilfe, wir brauchen ein Frontend
PPTX
Netflix Play API: Why we built an evolutionary architecture
MongoDB Stitch Introduction
IRREPORT.pptx
Building Apps with MySpace SDKs
Serverless Design Patterns
Bringing Transactional Guarantees to MongoDB
Serveless design patterns
Introducing Stitch
What we have learned about API scaling throughout Messente's international SM...
QCon London 2020: Streaming a million likes/second Real-time interactions on...
Micro-service architectures with Gilmour
SignalR tutorial & best practices
When the connection fails
Nathan Winters The Future Of Email Exchange And Online Services
Codemotion 2019: A million likes/second: Real-time interactions on Live Video
HBaseCon 2015: S2Graph - A Large-scale Graph Database with HBase
Serverless Software Architecture - Gears 17
Serverless Design Patterns (London Dev Community)
[CB21] ProxyLogon is Just the Tip of the Iceberg, A New Attack Surface on Mic...
Hilfe, wir brauchen ein Frontend
Netflix Play API: Why we built an evolutionary architecture
Ad

More from Richard Rodger (20)

PDF
Using RAG to create your own Podcast conversations.pdf
PDF
Richard_TheDev2023_pattern.pptx.pdf
PDF
richard-rodger-awssofia-microservices-2019.pdf
PDF
richardrodger-designing-microservices-london-may.pdf
PDF
richardrodger-microservice-risk-dublin-mar.pdf
PDF
richardrodger-service-discovery-waterford-feb.pdf
PDF
richardrodger-vespa-waterford-oct.pdf
PDF
Richardrodger designing-microservices-uxdx-dublin-oct
PDF
How microservices fail, and what to do about it
PDF
Rapid Digital Innovation: How Node.js Delivers
PDF
Richardrodger nodeconfeu-2014-final
PDF
Richardrodger nodeday-2014-final
PDF
Richardrodger nodeday-2014-final
PDF
Richardrodger microxchgio-feb-2015-final
PDF
Micro-services Battle Scars
PDF
Richard rodger technical debt - web summit 2013
PDF
The Seneca Pattern at EngineYard Distill 2013 Conference
PDF
Building businesspost.ie using Node.js
PDF
How to Write Big Apps (Richard Rodger NodeDublin 2012)
KEY
Richard rodger-appgen-2012-lxjs-lisbon
Using RAG to create your own Podcast conversations.pdf
Richard_TheDev2023_pattern.pptx.pdf
richard-rodger-awssofia-microservices-2019.pdf
richardrodger-designing-microservices-london-may.pdf
richardrodger-microservice-risk-dublin-mar.pdf
richardrodger-service-discovery-waterford-feb.pdf
richardrodger-vespa-waterford-oct.pdf
Richardrodger designing-microservices-uxdx-dublin-oct
How microservices fail, and what to do about it
Rapid Digital Innovation: How Node.js Delivers
Richardrodger nodeconfeu-2014-final
Richardrodger nodeday-2014-final
Richardrodger nodeday-2014-final
Richardrodger microxchgio-feb-2015-final
Micro-services Battle Scars
Richard rodger technical debt - web summit 2013
The Seneca Pattern at EngineYard Distill 2013 Conference
Building businesspost.ie using Node.js
How to Write Big Apps (Richard Rodger NodeDublin 2012)
Richard rodger-appgen-2012-lxjs-lisbon
Ad

Recently uploaded (20)

PPTX
L1 - Introduction to python Backend.pptx
PDF
How to Choose the Right IT Partner for Your Business in Malaysia
PPTX
Odoo POS Development Services by CandidRoot Solutions
PPTX
Introduction to Artificial Intelligence
PDF
Raksha Bandhan Grocery Pricing Trends in India 2025.pdf
PDF
Claude Code: Everyone is a 10x Developer - A Comprehensive AI-Powered CLI Tool
PDF
Internet Downloader Manager (IDM) Crack 6.42 Build 41
PPTX
ai tools demonstartion for schools and inter college
PDF
top salesforce developer skills in 2025.pdf
PDF
Audit Checklist Design Aligning with ISO, IATF, and Industry Standards — Omne...
PDF
medical staffing services at VALiNTRY
PPTX
Lecture 3: Operating Systems Introduction to Computer Hardware Systems
 
PPTX
Operating system designcfffgfgggggggvggggggggg
PDF
System and Network Administraation Chapter 3
PPTX
Agentic AI : A Practical Guide. Undersating, Implementing and Scaling Autono...
PPTX
ManageIQ - Sprint 268 Review - Slide Deck
PDF
2025 Textile ERP Trends: SAP, Odoo & Oracle
PDF
How Creative Agencies Leverage Project Management Software.pdf
PPTX
Transform Your Business with a Software ERP System
PPT
Introduction Database Management System for Course Database
L1 - Introduction to python Backend.pptx
How to Choose the Right IT Partner for Your Business in Malaysia
Odoo POS Development Services by CandidRoot Solutions
Introduction to Artificial Intelligence
Raksha Bandhan Grocery Pricing Trends in India 2025.pdf
Claude Code: Everyone is a 10x Developer - A Comprehensive AI-Powered CLI Tool
Internet Downloader Manager (IDM) Crack 6.42 Build 41
ai tools demonstartion for schools and inter college
top salesforce developer skills in 2025.pdf
Audit Checklist Design Aligning with ISO, IATF, and Industry Standards — Omne...
medical staffing services at VALiNTRY
Lecture 3: Operating Systems Introduction to Computer Hardware Systems
 
Operating system designcfffgfgggggggvggggggggg
System and Network Administraation Chapter 3
Agentic AI : A Practical Guide. Undersating, Implementing and Scaling Autono...
ManageIQ - Sprint 268 Review - Slide Deck
2025 Textile ERP Trends: SAP, Odoo & Oracle
How Creative Agencies Leverage Project Management Software.pdf
Transform Your Business with a Software ERP System
Introduction Database Management System for Course Database

richardrodger-designing-microservices-london-may.pdf