SlideShare a Scribd company logo
Event Sourcing
THE BEST, UBIQUITOUS PATTERN
YOU’VE NEVER HEARD OF
@blimpyacht
Event Sourcing + CQRS
Event Sourcing + CQRS
Event Sourcing + CQRS
5
Event Sourcing + CQRS
User: A
Balance:
427
User: B
Balance:
550
User: A
Balance:
427
User: B
Balance:
550
User: A
Balance:
427
User: B
Balance:
550
+5-5
Event Sourcing
State
+4
-2
+5
+7
-4
+9
-3
-6
+2
+1
+1
-5 t(12) = 9
Event Sourcing
+4
-2
+5
+7
-4
+9
-3
-6
+2
+1
+1
-5
t(5) = 10
Event Sourcing
+4
-2
+5
+7
-4
+9
-3
-6
+2
+1
+1
-5
t(9) = 12
Event Sourcing
+4
-2
+5
+7
-4
+9
-3
-6
+2
+1
+1
-5
Event Sourcing
a = f ’(x)
+4
-2
+5
+7
-4
+9
-3
-6
+2
+1
+1
-5
Event Sourcing
+5
-4
+5
Event Sourcing + CQRS
Res Gestae Divi Augusti
Event Sourcing + CQRS
Event Sourcing + CQRS
Event Sourcing + CQRS
Event Sourcing + CQRS
2ndaryPrimary
2ndaryPrimary
2ndaryPrimary
+4
-2
+5
+7
-4
+9
-3
-6
+2
+1
+1
-5
Event Sourcing
+4
-2
+5
+7
-4
+9
-3
-6
+2
+1
+1
-5
t(4) = 14
Event Sourcing
t(8) = 10
t(12) = 9
+4
-2
+5
+7
-4
+9
-3
-6
+2
+1
+1
-5
t(4) = 14
Event Sourcing
t(8) = 10
t(12) = 9
t’(4) = -2
t’(8) = -17
t’(12) = -22
Event Sourcing + CQRS
{
_id: {
ts: 1213084687000,
taxi: "abboip"
},
loc: {
geometry: [
-122.39488,
37.75134
]
},
fare: 0,
ts: ISODate("2008-06-10T07:58:07Z")
}
Event Sourcing + CQRS
{
_id: ObjectId("56a4215a46778b69e08ff8ff"),
taxi: "abboip",
start: ISODate("2008-05-17T14:51:10Z"),
route: {
type: "LineString",
coordinates: [
[ -122.39724, 37.74977 ],
[ -122.40619, 37.74896 ],
[ -122.41335, 37.74831 ],
[ -122.414, 37.75157 ],
[ -122.41438, 37.75552 ]
]
},
end: ISODate("2008-05-17T14:55:58Z")
}
Event Sourcing + CQRS
Data Modeling Domain Events
Domain Objects
Event Sourcing + CQRS
Accounts
Payable
Accounts
Payable
Accounts
Receivable
Accounts
Payable
Accounts
Receivable
Journal
Accounts
Payable
Accounts
Receivable
Journal
Ledger
Command Query
Responsibility
Segregation
CQRS
CRUD vs. CQRS
CRUD
CRUD vs. CQRS
WRITE
READ
CRUD vs. CQRS
CRUD equals CQRS
WRITE
READ
READ
CRUD vs. CQRS
WRITE
READ
Variant Read Models: VIEWS
READ
READ
READ
READ
WRITE
READ
Primary
READ
CRUD vs. CQRS
CRUD vs. CQRS
WRITE
READ
READ
Primary
2ndary
2ndary
Where it Gets Tricky
CRUD vs. CQRS
WRITE
READ
READ
Primary
2ndary
2ndary
CRUD vs. CQRS
WRITE
READ
READ
Primary
2ndary
2ndary
Consistent Replay
+4
-2
+5
+7
-4
+9
-3
-6
+2
+1
+1
-5
t(5) = 10 Exchange Rate
Server
10 / 0.88 = 8.82€
Consistent Replay
+4
-2
+5
+7
-4
+9
-3
-6
+2
+1
+1
-5
t(5) = 10 Exchange Rate
Server
10 / 0.87 = 8.70€
+4
-2
+5
+7
-4
+9
-3
-6
+2
+1
+1
-5
0.88
Exchange Rate
Server
Consistent Replay
Where it Gets Trickier Still
Event Sourcing + CQRS
Event Sourcing + CQRS
Event Sourcing + CQRS
Event Sourcing + CQRS
External Updates
+4
-2
+5
+7
-4
+9
-3
-6
+2
+1
+1
-5
Notification
Subscriber
Event Sourcing + CQRS
Event Sourcing + CQRS
External Updates
+4
-2
+5
+7
-4
+9
-3
-6
+2
+1
+1
-5
Notification
Subscriber
Gaining Insight
Event Sourcing + CQRS
Event Sourcing + CQRS
Event Sourcing + CQRS
Event Sourcing + CQRS
Event Sourcing + CQRS

More Related Content

PDF
MongoDB, Event Sourcing & Spark
Bryan Reinero
 
PDF
MongoDB + Spark
Bryan Reinero
 
PPTX
Mongo db &_spark
Bryan Reinero
 
PDF
Apache spark session
knowbigdata
 
PDF
Sqrrl October Webinar: Data Modeling and Indexing
Sqrrl
 
KEY
Hive vs Pig for HadoopSourceCodeReading
Mitsuharu Hamba
 
PDF
Big Data Analytics with Google BigQuery, by Javier Ramirez, datawaki, at Span...
javier ramirez
 
PDF
Big Data with BigQuery, presented at DevoxxUK 2014 by Javier Ramirez from teo...
javier ramirez
 
MongoDB, Event Sourcing & Spark
Bryan Reinero
 
MongoDB + Spark
Bryan Reinero
 
Mongo db &_spark
Bryan Reinero
 
Apache spark session
knowbigdata
 
Sqrrl October Webinar: Data Modeling and Indexing
Sqrrl
 
Hive vs Pig for HadoopSourceCodeReading
Mitsuharu Hamba
 
Big Data Analytics with Google BigQuery, by Javier Ramirez, datawaki, at Span...
javier ramirez
 
Big Data with BigQuery, presented at DevoxxUK 2014 by Javier Ramirez from teo...
javier ramirez
 

Viewers also liked (18)

PDF
Herramientas de gestión de la influencia y la reputación on lune
Consultores Quantumleap & Partners (CQLP)
 
PDF
cross company code settlement.pdf
puppala
 
PDF
Ilgiornaledinapoli
mimmoannunziata
 
PPT
Aprendiendo A Hacer Presentaciones
iespare09
 
PDF
Tagli pubblico impiego proteste lavoratori
redazione gioianet
 
PDF
NYC utility cuts power to more households in Sandy's aftermath
frantcaldwell
 
PDF
Jessenia resume pdf
Jessenia Garcia
 
PPS
Maximum Double Suites
SuporteaoCorretor
 
PDF
Configuracion 1°e
ferjkl
 
PDF
High School Reference
Neville Phillips
 
PPT
Kelompok Penanggulangan Darurat Bencana Berbasis pada Masyarakat
Mutia Rizqa Ofir
 
PPT
Estadística y diabetes. Tarea.
Mariana Gómez
 
PDF
Επαναληπτική δοκιμασία, Α τάξη: Το κοχύλι
Σπύρος Κυριαζίδης
 
PPT
Transporte de hacienda, ferias ganaderas y Bienestar Animal
Leopoldo Estol
 
PPTX
Organigrama actualizado
ComunicacionesPDB
 
PDF
Présentation arabe
Hamza Soldi
 
PPTX
Insulinoterapia
Alonso Custodio
 
PDF
Diabetes Mellitus tipo 2
Alonso Custodio
 
Herramientas de gestión de la influencia y la reputación on lune
Consultores Quantumleap & Partners (CQLP)
 
cross company code settlement.pdf
puppala
 
Ilgiornaledinapoli
mimmoannunziata
 
Aprendiendo A Hacer Presentaciones
iespare09
 
Tagli pubblico impiego proteste lavoratori
redazione gioianet
 
NYC utility cuts power to more households in Sandy's aftermath
frantcaldwell
 
Jessenia resume pdf
Jessenia Garcia
 
Maximum Double Suites
SuporteaoCorretor
 
Configuracion 1°e
ferjkl
 
High School Reference
Neville Phillips
 
Kelompok Penanggulangan Darurat Bencana Berbasis pada Masyarakat
Mutia Rizqa Ofir
 
Estadística y diabetes. Tarea.
Mariana Gómez
 
Επαναληπτική δοκιμασία, Α τάξη: Το κοχύλι
Σπύρος Κυριαζίδης
 
Transporte de hacienda, ferias ganaderas y Bienestar Animal
Leopoldo Estol
 
Organigrama actualizado
ComunicacionesPDB
 
Présentation arabe
Hamza Soldi
 
Insulinoterapia
Alonso Custodio
 
Diabetes Mellitus tipo 2
Alonso Custodio
 
Ad

Similar to Event Sourcing + CQRS (12)

PPTX
Event sourcing
Bryan Reinero
 
PDF
Big Data Day LA 2015 - Event Sourcing: The Best Ubiquitous Pattern You've Nev...
Data Con LA
 
PDF
Grade 5 adding fractions mixed numbers
Essa Kathleen Yanson
 
PDF
math worsheet
Zoe Hope
 
PDF
01 primeras-sumas-abn
Lupita Lanz
 
PPTX
Number facts 1 10
sharmapruthviraj
 
DOCX
Math worksheet4
Ric Dagdagan
 
PPT
The Properties of Mathematics
arinedge
 
PPT
1 8 Properties
Kathy Favazza
 
PDF
2 mates
Luz Milagro
 
PDF
Introduction to machine learning algorithms
bigdata trunk
 
Event sourcing
Bryan Reinero
 
Big Data Day LA 2015 - Event Sourcing: The Best Ubiquitous Pattern You've Nev...
Data Con LA
 
Grade 5 adding fractions mixed numbers
Essa Kathleen Yanson
 
math worsheet
Zoe Hope
 
01 primeras-sumas-abn
Lupita Lanz
 
Number facts 1 10
sharmapruthviraj
 
Math worksheet4
Ric Dagdagan
 
The Properties of Mathematics
arinedge
 
1 8 Properties
Kathy Favazza
 
2 mates
Luz Milagro
 
Introduction to machine learning algorithms
bigdata trunk
 
Ad

Recently uploaded (20)

PDF
AI-Cloud-Business-Management-Platforms-The-Key-to-Efficiency-Growth.pdf
Artjoker Software Development Company
 
PDF
Event Presentation Google Cloud Next Extended 2025
minhtrietgect
 
PDF
Make GenAI investments go further with the Dell AI Factory
Principled Technologies
 
PPTX
The-Ethical-Hackers-Imperative-Safeguarding-the-Digital-Frontier.pptx
sujalchauhan1305
 
PDF
CIFDAQ's Market Wrap : Bears Back in Control?
CIFDAQ
 
PDF
The Future of Mobile Is Context-Aware—Are You Ready?
iProgrammer Solutions Private Limited
 
PDF
Data_Analytics_vs_Data_Science_vs_BI_by_CA_Suvidha_Chaplot.pdf
CA Suvidha Chaplot
 
PDF
Security features in Dell, HP, and Lenovo PC systems: A research-based compar...
Principled Technologies
 
PPTX
Dev Dives: Automate, test, and deploy in one place—with Unified Developer Exp...
AndreeaTom
 
PDF
Cloud-Migration-Best-Practices-A-Practical-Guide-to-AWS-Azure-and-Google-Clou...
Artjoker Software Development Company
 
PDF
Brief History of Internet - Early Days of Internet
sutharharshit158
 
PPTX
What-is-the-World-Wide-Web -- Introduction
tonifi9488
 
PDF
Using Anchore and DefectDojo to Stand Up Your DevSecOps Function
Anchore
 
PDF
BLW VOCATIONAL TRAINING SUMMER INTERNSHIP REPORT
codernjn73
 
PDF
Google I/O Extended 2025 Baku - all ppts
HusseinMalikMammadli
 
PDF
The Evolution of KM Roles (Presented at Knowledge Summit Dublin 2025)
Enterprise Knowledge
 
PPTX
AI in Daily Life: How Artificial Intelligence Helps Us Every Day
vanshrpatil7
 
PDF
OFFOFFBOX™ – A New Era for African Film | Startup Presentation
ambaicciwalkerbrian
 
PDF
A Strategic Analysis of the MVNO Wave in Emerging Markets.pdf
IPLOOK Networks
 
PDF
Automating ArcGIS Content Discovery with FME: A Real World Use Case
Safe Software
 
AI-Cloud-Business-Management-Platforms-The-Key-to-Efficiency-Growth.pdf
Artjoker Software Development Company
 
Event Presentation Google Cloud Next Extended 2025
minhtrietgect
 
Make GenAI investments go further with the Dell AI Factory
Principled Technologies
 
The-Ethical-Hackers-Imperative-Safeguarding-the-Digital-Frontier.pptx
sujalchauhan1305
 
CIFDAQ's Market Wrap : Bears Back in Control?
CIFDAQ
 
The Future of Mobile Is Context-Aware—Are You Ready?
iProgrammer Solutions Private Limited
 
Data_Analytics_vs_Data_Science_vs_BI_by_CA_Suvidha_Chaplot.pdf
CA Suvidha Chaplot
 
Security features in Dell, HP, and Lenovo PC systems: A research-based compar...
Principled Technologies
 
Dev Dives: Automate, test, and deploy in one place—with Unified Developer Exp...
AndreeaTom
 
Cloud-Migration-Best-Practices-A-Practical-Guide-to-AWS-Azure-and-Google-Clou...
Artjoker Software Development Company
 
Brief History of Internet - Early Days of Internet
sutharharshit158
 
What-is-the-World-Wide-Web -- Introduction
tonifi9488
 
Using Anchore and DefectDojo to Stand Up Your DevSecOps Function
Anchore
 
BLW VOCATIONAL TRAINING SUMMER INTERNSHIP REPORT
codernjn73
 
Google I/O Extended 2025 Baku - all ppts
HusseinMalikMammadli
 
The Evolution of KM Roles (Presented at Knowledge Summit Dublin 2025)
Enterprise Knowledge
 
AI in Daily Life: How Artificial Intelligence Helps Us Every Day
vanshrpatil7
 
OFFOFFBOX™ – A New Era for African Film | Startup Presentation
ambaicciwalkerbrian
 
A Strategic Analysis of the MVNO Wave in Emerging Markets.pdf
IPLOOK Networks
 
Automating ArcGIS Content Discovery with FME: A Real World Use Case
Safe Software
 

Event Sourcing + CQRS