SlideShare a Scribd company logo
CQRS

& EVENT
SOURCING
I - Event sourcing
TRADITIONAL PERSISTENCE
Store only the current state
TRADITIONAL PERSISTENCE
Store only the current state
TRADITIONAL PERSISTENCE
Snapshots
EVENT SOURCING
Store the events that have led to every state
1. Created
2. Updated foo
3. Updated bar
4. Deleted
EVENT SOURCING
Benefits
Natural audit log
Ability to reconstruct a previous state
Ability to respond to bugs in state
COMMAND-QUERY SEPARATION
Command function/method
Produces state change
Has observable side-effects
Either succeeds or fails
Has a "void" return type
Throws exceptions
COMMAND
Produces a state change and emits an event
Store only the events
Reproduce the state using the events
RECONSTITUTION
Append new events
event
event
event
event
command
EVENTS
Type (class)
Object identifier
Timestamp
Any relevant data
(Playhead)
assignments/01.md
Event sourcing the `Meetup` aggregate
CQRS

& EVENT
SOURCING
II - CQRS
EVENT SOURCING
Slow on the "read" side
We need to:
1. Fetch and recreate all event objects
2. Reconstitute the object based on its events
CQRS
Helps with scaling on the read side
COMMAND-QUERY SEPARATION
Query method
Has no observable side-effects
Either succeeds or fails
Has a specific return type
Throws exceptions
COMMAND/QUERY SEPARATION
PRINCIPLE
(CQS)
Every method should be either a command method, or a query method
command(): void
query(): type
COMMAND/QUERY
RESPONSIBILITY SEGREGATION
(CQRS)
Domain objects should have either command methods, or query methods
query(): typecommand(): void
WE WANT TO PERSIST EVENTS
But we need the current state too
IF ONLY WE COULD
Tail the event log...
event
event
event
PROJECTIONS
Using events to update read models
event
READ MODELS
Are query objects
query(): type
query(): type
query(): type
READ MODELS
Are use-case specific
READ MODELS
Are easy to query
SELECT * FROM ... WHERE ...
READ MODELS
Can use polyglot persistence
assignments/02.md
Apply CQRS to the `Meetup` aggregate
assignments/03.md
Twitsup: Unfollowing
assignments/04.md
Twitsup: Mentions
assignments/05.md
Twitsup: Mentions
CQRS

& EVENT
SOURCING
III - Potential
CQRS & ES
Very useful for
Business insights
Scaling
Application integration
Microservices

More Related Content

PDF
Unidirectional Data Flow with Reactor
PDF
Advanced Application Architecture (workshop slides)
PPTX
Дерево рішень
PPTX
Fortune 500: Top 10 Retailers
PDF
PPTX
Scopus y cinhal
PDF
Georgia birds field guide
 
PPTX
Ponencia loja energia agro eco
Unidirectional Data Flow with Reactor
Advanced Application Architecture (workshop slides)
Дерево рішень
Fortune 500: Top 10 Retailers
Scopus y cinhal
Georgia birds field guide
 
Ponencia loja energia agro eco

Viewers also liked (11)

PDF
Keterkaitan Organization Development (OD) dengan Arah Strategis Perusahaan
PPTX
Actividad 1 perfiles
DOCX
Informe final
PDF
Actividad 2
PDF
IAAF WorldCrossCountry champs Kampala(uga) 2017 final entry lists
ODP
Renderizado 3D
PDF
Desplazamiento de nodos método energético y maxwell mohr
PPT
Presetacion de power point 97 2003
PPTX
Ejercicio de hipertexto
PDF
1°trabajo flores antezana rogger david
PDF
2017 3C diario di Hans
Keterkaitan Organization Development (OD) dengan Arah Strategis Perusahaan
Actividad 1 perfiles
Informe final
Actividad 2
IAAF WorldCrossCountry champs Kampala(uga) 2017 final entry lists
Renderizado 3D
Desplazamiento de nodos método energético y maxwell mohr
Presetacion de power point 97 2003
Ejercicio de hipertexto
1°trabajo flores antezana rogger david
2017 3C diario di Hans
Ad

Similar to CQRS & Event Sourcing (20)

PDF
CQRS and Event Sourcing in Action
PDF
An Introduction to event sourcing and CQRS
PDF
A visual introduction to Event Sourcing and CQRS
PDF
A Visual Introduction to Event Sourcing and CQRS by Lorenzo Nicora
PPTX
Intro to event sourcing and CQRS
PDF
Event Sourcing without any Framework
PPTX
Cqrs and Event Sourcing Intro For Developers
PPT
PPT
PDF
fram^ TechTalk #1 - CQRS and Event Sourcing (ES)
PDF
Introduction to Event Sourcing in PHP
PPTX
Cqrs and event sourcing in azure
PPTX
DDD meets CQRS and event sourcing
PDF
CQRS and Event Sourcing with PHP - shorter version
PDF
CQRS and Event Sourcing with PHP
PDF
CQRS and Event Sourcing
PPTX
Introduction to CQRS and Event Sourcing
PPTX
Spring I_O 2024 - Flexible Spring with Event Sourcing.pptx
PDF
CQRS + Event Sourcing
PDF
Developing event-driven microservices with event sourcing and CQRS (Shanghai)
CQRS and Event Sourcing in Action
An Introduction to event sourcing and CQRS
A visual introduction to Event Sourcing and CQRS
A Visual Introduction to Event Sourcing and CQRS by Lorenzo Nicora
Intro to event sourcing and CQRS
Event Sourcing without any Framework
Cqrs and Event Sourcing Intro For Developers
fram^ TechTalk #1 - CQRS and Event Sourcing (ES)
Introduction to Event Sourcing in PHP
Cqrs and event sourcing in azure
DDD meets CQRS and event sourcing
CQRS and Event Sourcing with PHP - shorter version
CQRS and Event Sourcing with PHP
CQRS and Event Sourcing
Introduction to CQRS and Event Sourcing
Spring I_O 2024 - Flexible Spring with Event Sourcing.pptx
CQRS + Event Sourcing
Developing event-driven microservices with event sourcing and CQRS (Shanghai)
Ad

More from Matthias Noback (20)

PDF
Rector fireside chat - PHPMiNDS meetup
PDF
Service abstractions - Part 1: Queries
PDF
Hexagonal Symfony - SymfonyCon Amsterdam 2019
PDF
Advanced web application architecture - PHP Barcelona
PDF
A testing strategy for hexagonal applications
PDF
Advanced web application architecture - Talk
PDF
DPC 2019, Amsterdam: Beyond design patterns and principles - writing good OO ...
PDF
Layers, ports and adapters
PDF
Beyond design principles and patterns (muCon 2019 edition)
PDF
Brutal refactoring, lying code, the Churn, and other emotional stories from L...
PDF
Advanced web application architecture Way2Web
PDF
Brutal refactoring, lying code, the Churn, and other emotional stories from L...
PDF
Beyond Design Principles and Patterns
PDF
Building Autonomous Services
PDF
Advanced Application Architecture Symfony Live Berlin 2018
PDF
Designing for Autonomy
PDF
Docker workshop
PDF
Docker swarm workshop
PDF
Docker compose workshop
PDF
Building autonomous services
Rector fireside chat - PHPMiNDS meetup
Service abstractions - Part 1: Queries
Hexagonal Symfony - SymfonyCon Amsterdam 2019
Advanced web application architecture - PHP Barcelona
A testing strategy for hexagonal applications
Advanced web application architecture - Talk
DPC 2019, Amsterdam: Beyond design patterns and principles - writing good OO ...
Layers, ports and adapters
Beyond design principles and patterns (muCon 2019 edition)
Brutal refactoring, lying code, the Churn, and other emotional stories from L...
Advanced web application architecture Way2Web
Brutal refactoring, lying code, the Churn, and other emotional stories from L...
Beyond Design Principles and Patterns
Building Autonomous Services
Advanced Application Architecture Symfony Live Berlin 2018
Designing for Autonomy
Docker workshop
Docker swarm workshop
Docker compose workshop
Building autonomous services

Recently uploaded (20)

PDF
SAP S4 Hana Brochure 3 (PTS SYSTEMS AND SOLUTIONS)
PDF
How to Migrate SBCGlobal Email to Yahoo Easily
PDF
Which alternative to Crystal Reports is best for small or large businesses.pdf
PDF
Why TechBuilder is the Future of Pickup and Delivery App Development (1).pdf
PDF
How Creative Agencies Leverage Project Management Software.pdf
PDF
T3DD25 TYPO3 Content Blocks - Deep Dive by André Kraus
PDF
Softaken Excel to vCard Converter Software.pdf
PDF
Upgrade and Innovation Strategies for SAP ERP Customers
PDF
Wondershare Filmora 15 Crack With Activation Key [2025
PPTX
CHAPTER 12 - CYBER SECURITY AND FUTURE SKILLS (1) (1).pptx
PDF
System and Network Administraation Chapter 3
PDF
Addressing The Cult of Project Management Tools-Why Disconnected Work is Hold...
PDF
Complete React Javascript Course Syllabus.pdf
PPTX
Operating system designcfffgfgggggggvggggggggg
PPTX
Agentic AI : A Practical Guide. Undersating, Implementing and Scaling Autono...
PDF
Adobe Premiere Pro 2025 (v24.5.0.057) Crack free
PDF
How to Choose the Right IT Partner for Your Business in Malaysia
PPTX
ai tools demonstartion for schools and inter college
PDF
Claude Code: Everyone is a 10x Developer - A Comprehensive AI-Powered CLI Tool
PPT
Introduction Database Management System for Course Database
SAP S4 Hana Brochure 3 (PTS SYSTEMS AND SOLUTIONS)
How to Migrate SBCGlobal Email to Yahoo Easily
Which alternative to Crystal Reports is best for small or large businesses.pdf
Why TechBuilder is the Future of Pickup and Delivery App Development (1).pdf
How Creative Agencies Leverage Project Management Software.pdf
T3DD25 TYPO3 Content Blocks - Deep Dive by André Kraus
Softaken Excel to vCard Converter Software.pdf
Upgrade and Innovation Strategies for SAP ERP Customers
Wondershare Filmora 15 Crack With Activation Key [2025
CHAPTER 12 - CYBER SECURITY AND FUTURE SKILLS (1) (1).pptx
System and Network Administraation Chapter 3
Addressing The Cult of Project Management Tools-Why Disconnected Work is Hold...
Complete React Javascript Course Syllabus.pdf
Operating system designcfffgfgggggggvggggggggg
Agentic AI : A Practical Guide. Undersating, Implementing and Scaling Autono...
Adobe Premiere Pro 2025 (v24.5.0.057) Crack free
How to Choose the Right IT Partner for Your Business in Malaysia
ai tools demonstartion for schools and inter college
Claude Code: Everyone is a 10x Developer - A Comprehensive AI-Powered CLI Tool
Introduction Database Management System for Course Database

CQRS & Event Sourcing