SlideShare a Scribd company logo
1 of 69
Download to read offline
Event Sourcing
THE BEST, UBIQUITOUS PATTERN
YOU’VE NEVER HEARD OF
@blimpyacht
5
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
Res Gestae Divi Augusti
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
{
_id: {
ts: 1213084687000,
taxi: "abboip"
},
loc: {
geometry: [
-122.39488,
37.75134
]
},
fare: 0,
ts: ISODate("2008-06-10T07:58:07Z")
}
{
_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")
}
Data Modeling Domain Events
Domain Objects
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
External Updates
+4
-2
+5
+7
-4
+9
-3
-6
+2
+1
+1
-5
Notification
Subscriber
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

Viewers also liked

cross company code settlement.pdf
cross company code settlement.pdfcross company code settlement.pdf
cross company code settlement.pdfpuppala
 
Aprendiendo A Hacer Presentaciones
Aprendiendo A Hacer PresentacionesAprendiendo A Hacer Presentaciones
Aprendiendo A Hacer Presentacionesiespare09
 
Tagli pubblico impiego proteste lavoratori
Tagli pubblico  impiego proteste lavoratoriTagli pubblico  impiego proteste lavoratori
Tagli pubblico impiego proteste lavoratoriredazione gioianet
 
NYC utility cuts power to more households in Sandy's aftermath
NYC utility cuts power to more households in Sandy's aftermathNYC utility cuts power to more households in Sandy's aftermath
NYC utility cuts power to more households in Sandy's aftermathfrantcaldwell
 
Configuracion 1°e
Configuracion 1°e Configuracion 1°e
Configuracion 1°e ferjkl
 
Kelompok Penanggulangan Darurat Bencana Berbasis pada Masyarakat
Kelompok Penanggulangan Darurat Bencana Berbasis pada MasyarakatKelompok Penanggulangan Darurat Bencana Berbasis pada Masyarakat
Kelompok Penanggulangan Darurat Bencana Berbasis pada MasyarakatMutia Rizqa Ofir
 
Estadística y diabetes. Tarea.
Estadística y diabetes. Tarea.Estadística y diabetes. Tarea.
Estadística y diabetes. Tarea.Mariana Gómez
 
Επαναληπτική δοκιμασία, Α τάξη: Το κοχύλι
Επαναληπτική δοκιμασία, Α τάξη: Το κοχύλιΕπαναληπτική δοκιμασία, Α τάξη: Το κοχύλι
Επαναληπτική δοκιμασία, Α τάξη: Το κοχύλιΣπύρος Κυριαζίδης
 
Transporte de hacienda, ferias ganaderas y Bienestar Animal
Transporte de hacienda,  ferias ganaderas y Bienestar AnimalTransporte de hacienda,  ferias ganaderas y Bienestar Animal
Transporte de hacienda, ferias ganaderas y Bienestar AnimalLeopoldo Estol
 
Présentation arabe
Présentation arabe Présentation arabe
Présentation arabe Hamza Soldi
 
Diabetes Mellitus tipo 2
Diabetes Mellitus tipo 2Diabetes Mellitus tipo 2
Diabetes Mellitus tipo 2Alonso Custodio
 

Viewers also liked (18)

Herramientas de gestión de la influencia y la reputación on lune
Herramientas de gestión de la influencia y la reputación on luneHerramientas de gestión de la influencia y la reputación on lune
Herramientas de gestión de la influencia y la reputación on lune
 
cross company code settlement.pdf
cross company code settlement.pdfcross company code settlement.pdf
cross company code settlement.pdf
 
Ilgiornaledinapoli
IlgiornaledinapoliIlgiornaledinapoli
Ilgiornaledinapoli
 
Aprendiendo A Hacer Presentaciones
Aprendiendo A Hacer PresentacionesAprendiendo A Hacer Presentaciones
Aprendiendo A Hacer Presentaciones
 
Tagli pubblico impiego proteste lavoratori
Tagli pubblico  impiego proteste lavoratoriTagli pubblico  impiego proteste lavoratori
Tagli pubblico impiego proteste lavoratori
 
NYC utility cuts power to more households in Sandy's aftermath
NYC utility cuts power to more households in Sandy's aftermathNYC utility cuts power to more households in Sandy's aftermath
NYC utility cuts power to more households in Sandy's aftermath
 
Jessenia resume pdf
Jessenia resume  pdfJessenia resume  pdf
Jessenia resume pdf
 
Maximum Double Suites
Maximum Double SuitesMaximum Double Suites
Maximum Double Suites
 
Configuracion 1°e
Configuracion 1°e Configuracion 1°e
Configuracion 1°e
 
High School Reference
High School ReferenceHigh School Reference
High School Reference
 
Kelompok Penanggulangan Darurat Bencana Berbasis pada Masyarakat
Kelompok Penanggulangan Darurat Bencana Berbasis pada MasyarakatKelompok Penanggulangan Darurat Bencana Berbasis pada Masyarakat
Kelompok Penanggulangan Darurat Bencana Berbasis pada Masyarakat
 
Estadística y diabetes. Tarea.
Estadística y diabetes. Tarea.Estadística y diabetes. Tarea.
Estadística y diabetes. Tarea.
 
Επαναληπτική δοκιμασία, Α τάξη: Το κοχύλι
Επαναληπτική δοκιμασία, Α τάξη: Το κοχύλιΕπαναληπτική δοκιμασία, Α τάξη: Το κοχύλι
Επαναληπτική δοκιμασία, Α τάξη: Το κοχύλι
 
Transporte de hacienda, ferias ganaderas y Bienestar Animal
Transporte de hacienda,  ferias ganaderas y Bienestar AnimalTransporte de hacienda,  ferias ganaderas y Bienestar Animal
Transporte de hacienda, ferias ganaderas y Bienestar Animal
 
Organigrama actualizado
Organigrama actualizadoOrganigrama actualizado
Organigrama actualizado
 
Présentation arabe
Présentation arabe Présentation arabe
Présentation arabe
 
Insulinoterapia
InsulinoterapiaInsulinoterapia
Insulinoterapia
 
Diabetes Mellitus tipo 2
Diabetes Mellitus tipo 2Diabetes Mellitus tipo 2
Diabetes Mellitus tipo 2
 

Similar to Event Sourcing + CQRS

Big Data Day LA 2015 - Event Sourcing: The Best Ubiquitous Pattern You've Nev...
Big Data Day LA 2015 - Event Sourcing: The Best Ubiquitous Pattern You've Nev...Big Data Day LA 2015 - Event Sourcing: The Best Ubiquitous Pattern You've Nev...
Big Data Day LA 2015 - Event Sourcing: The Best Ubiquitous Pattern You've Nev...Data Con LA
 
Grade 5 adding fractions mixed numbers
Grade 5 adding fractions mixed numbersGrade 5 adding fractions mixed numbers
Grade 5 adding fractions mixed numbersEssa Kathleen Yanson
 
math worsheet
math worsheetmath worsheet
math worsheetZoe Hope
 
01 primeras-sumas-abn
01 primeras-sumas-abn01 primeras-sumas-abn
01 primeras-sumas-abnLupita Lanz
 
The Properties of Mathematics
The Properties of MathematicsThe Properties of Mathematics
The Properties of Mathematicsarinedge
 
Introduction to machine learning algorithms
Introduction to machine learning algorithmsIntroduction to machine learning algorithms
Introduction to machine learning algorithmsbigdata trunk
 

Similar to Event Sourcing + CQRS (12)

Event sourcing
Event sourcingEvent sourcing
Event sourcing
 
Big Data Day LA 2015 - Event Sourcing: The Best Ubiquitous Pattern You've Nev...
Big Data Day LA 2015 - Event Sourcing: The Best Ubiquitous Pattern You've Nev...Big Data Day LA 2015 - Event Sourcing: The Best Ubiquitous Pattern You've Nev...
Big Data Day LA 2015 - Event Sourcing: The Best Ubiquitous Pattern You've Nev...
 
Grade 5 adding fractions mixed numbers
Grade 5 adding fractions mixed numbersGrade 5 adding fractions mixed numbers
Grade 5 adding fractions mixed numbers
 
math worsheet
math worsheetmath worsheet
math worsheet
 
01 primeras-sumas-abn
01 primeras-sumas-abn01 primeras-sumas-abn
01 primeras-sumas-abn
 
Math 5
Math 5 Math 5
Math 5
 
Number facts 1 10
Number facts 1   10Number facts 1   10
Number facts 1 10
 
Math worksheet4
Math worksheet4Math worksheet4
Math worksheet4
 
The Properties of Mathematics
The Properties of MathematicsThe Properties of Mathematics
The Properties of Mathematics
 
1 8 Properties
1 8 Properties1 8 Properties
1 8 Properties
 
2 mates
2 mates2 mates
2 mates
 
Introduction to machine learning algorithms
Introduction to machine learning algorithmsIntroduction to machine learning algorithms
Introduction to machine learning algorithms
 

Recently uploaded

Data Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt RobisonData Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt RobisonAnna Loughnan Colquhoun
 
The Codex of Business Writing Software for Real-World Solutions 2.pptx
The Codex of Business Writing Software for Real-World Solutions 2.pptxThe Codex of Business Writing Software for Real-World Solutions 2.pptx
The Codex of Business Writing Software for Real-World Solutions 2.pptxMalak Abu Hammad
 
Breaking the Kubernetes Kill Chain: Host Path Mount
Breaking the Kubernetes Kill Chain: Host Path MountBreaking the Kubernetes Kill Chain: Host Path Mount
Breaking the Kubernetes Kill Chain: Host Path MountPuma Security, LLC
 
Tata AIG General Insurance Company - Insurer Innovation Award 2024
Tata AIG General Insurance Company - Insurer Innovation Award 2024Tata AIG General Insurance Company - Insurer Innovation Award 2024
Tata AIG General Insurance Company - Insurer Innovation Award 2024The Digital Insurer
 
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptxHampshireHUG
 
Boost Fertility New Invention Ups Success Rates.pdf
Boost Fertility New Invention Ups Success Rates.pdfBoost Fertility New Invention Ups Success Rates.pdf
Boost Fertility New Invention Ups Success Rates.pdfsudhanshuwaghmare1
 
Artificial Intelligence: Facts and Myths
Artificial Intelligence: Facts and MythsArtificial Intelligence: Facts and Myths
Artificial Intelligence: Facts and MythsJoaquim Jorge
 
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...Igalia
 
Factors to Consider When Choosing Accounts Payable Services Providers.pptx
Factors to Consider When Choosing Accounts Payable Services Providers.pptxFactors to Consider When Choosing Accounts Payable Services Providers.pptx
Factors to Consider When Choosing Accounts Payable Services Providers.pptxKatpro Technologies
 
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...Miguel Araújo
 
From Event to Action: Accelerate Your Decision Making with Real-Time Automation
From Event to Action: Accelerate Your Decision Making with Real-Time AutomationFrom Event to Action: Accelerate Your Decision Making with Real-Time Automation
From Event to Action: Accelerate Your Decision Making with Real-Time AutomationSafe Software
 
08448380779 Call Girls In Friends Colony Women Seeking Men
08448380779 Call Girls In Friends Colony Women Seeking Men08448380779 Call Girls In Friends Colony Women Seeking Men
08448380779 Call Girls In Friends Colony Women Seeking MenDelhi Call girls
 
Boost PC performance: How more available memory can improve productivity
Boost PC performance: How more available memory can improve productivityBoost PC performance: How more available memory can improve productivity
Boost PC performance: How more available memory can improve productivityPrincipled Technologies
 
A Year of the Servo Reboot: Where Are We Now?
A Year of the Servo Reboot: Where Are We Now?A Year of the Servo Reboot: Where Are We Now?
A Year of the Servo Reboot: Where Are We Now?Igalia
 
GenCyber Cyber Security Day Presentation
GenCyber Cyber Security Day PresentationGenCyber Cyber Security Day Presentation
GenCyber Cyber Security Day PresentationMichael W. Hawkins
 
Exploring the Future Potential of AI-Enabled Smartphone Processors
Exploring the Future Potential of AI-Enabled Smartphone ProcessorsExploring the Future Potential of AI-Enabled Smartphone Processors
Exploring the Future Potential of AI-Enabled Smartphone Processorsdebabhi2
 
Advantages of Hiring UIUX Design Service Providers for Your Business
Advantages of Hiring UIUX Design Service Providers for Your BusinessAdvantages of Hiring UIUX Design Service Providers for Your Business
Advantages of Hiring UIUX Design Service Providers for Your BusinessPixlogix Infotech
 
CNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of ServiceCNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of Servicegiselly40
 
Understanding Discord NSFW Servers A Guide for Responsible Users.pdf
Understanding Discord NSFW Servers A Guide for Responsible Users.pdfUnderstanding Discord NSFW Servers A Guide for Responsible Users.pdf
Understanding Discord NSFW Servers A Guide for Responsible Users.pdfUK Journal
 
How to convert PDF to text with Nanonets
How to convert PDF to text with NanonetsHow to convert PDF to text with Nanonets
How to convert PDF to text with Nanonetsnaman860154
 

Recently uploaded (20)

Data Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt RobisonData Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt Robison
 
The Codex of Business Writing Software for Real-World Solutions 2.pptx
The Codex of Business Writing Software for Real-World Solutions 2.pptxThe Codex of Business Writing Software for Real-World Solutions 2.pptx
The Codex of Business Writing Software for Real-World Solutions 2.pptx
 
Breaking the Kubernetes Kill Chain: Host Path Mount
Breaking the Kubernetes Kill Chain: Host Path MountBreaking the Kubernetes Kill Chain: Host Path Mount
Breaking the Kubernetes Kill Chain: Host Path Mount
 
Tata AIG General Insurance Company - Insurer Innovation Award 2024
Tata AIG General Insurance Company - Insurer Innovation Award 2024Tata AIG General Insurance Company - Insurer Innovation Award 2024
Tata AIG General Insurance Company - Insurer Innovation Award 2024
 
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
 
Boost Fertility New Invention Ups Success Rates.pdf
Boost Fertility New Invention Ups Success Rates.pdfBoost Fertility New Invention Ups Success Rates.pdf
Boost Fertility New Invention Ups Success Rates.pdf
 
Artificial Intelligence: Facts and Myths
Artificial Intelligence: Facts and MythsArtificial Intelligence: Facts and Myths
Artificial Intelligence: Facts and Myths
 
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
 
Factors to Consider When Choosing Accounts Payable Services Providers.pptx
Factors to Consider When Choosing Accounts Payable Services Providers.pptxFactors to Consider When Choosing Accounts Payable Services Providers.pptx
Factors to Consider When Choosing Accounts Payable Services Providers.pptx
 
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
 
From Event to Action: Accelerate Your Decision Making with Real-Time Automation
From Event to Action: Accelerate Your Decision Making with Real-Time AutomationFrom Event to Action: Accelerate Your Decision Making with Real-Time Automation
From Event to Action: Accelerate Your Decision Making with Real-Time Automation
 
08448380779 Call Girls In Friends Colony Women Seeking Men
08448380779 Call Girls In Friends Colony Women Seeking Men08448380779 Call Girls In Friends Colony Women Seeking Men
08448380779 Call Girls In Friends Colony Women Seeking Men
 
Boost PC performance: How more available memory can improve productivity
Boost PC performance: How more available memory can improve productivityBoost PC performance: How more available memory can improve productivity
Boost PC performance: How more available memory can improve productivity
 
A Year of the Servo Reboot: Where Are We Now?
A Year of the Servo Reboot: Where Are We Now?A Year of the Servo Reboot: Where Are We Now?
A Year of the Servo Reboot: Where Are We Now?
 
GenCyber Cyber Security Day Presentation
GenCyber Cyber Security Day PresentationGenCyber Cyber Security Day Presentation
GenCyber Cyber Security Day Presentation
 
Exploring the Future Potential of AI-Enabled Smartphone Processors
Exploring the Future Potential of AI-Enabled Smartphone ProcessorsExploring the Future Potential of AI-Enabled Smartphone Processors
Exploring the Future Potential of AI-Enabled Smartphone Processors
 
Advantages of Hiring UIUX Design Service Providers for Your Business
Advantages of Hiring UIUX Design Service Providers for Your BusinessAdvantages of Hiring UIUX Design Service Providers for Your Business
Advantages of Hiring UIUX Design Service Providers for Your Business
 
CNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of ServiceCNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of Service
 
Understanding Discord NSFW Servers A Guide for Responsible Users.pdf
Understanding Discord NSFW Servers A Guide for Responsible Users.pdfUnderstanding Discord NSFW Servers A Guide for Responsible Users.pdf
Understanding Discord NSFW Servers A Guide for Responsible Users.pdf
 
How to convert PDF to text with Nanonets
How to convert PDF to text with NanonetsHow to convert PDF to text with Nanonets
How to convert PDF to text with Nanonets
 

Event Sourcing + CQRS