SlideShare una empresa de Scribd logo
1 de 11
Descargar para leer sin conexión
Event Sourcing
@derek_comartin
CodeOpinion.com
Agenda
● Typical Data Persistence
● Overview
● Events
● Why?
● Queries
● Drawbacks
Typical Data Persistence
● Maintain current state
● Concurrent users, data update conflicts.
● Auditing
Overview
● Old concept
● Using already (transaction log)
● Capture Intent
● Event = State Change
● Sequence of Events
● Append Only
Events
● Describes state change
● Past tense
● Source of truth
● Audit log
Event Stream
Started Shopping
Added T-Shirt
Added Socks
Removed Socks
Added Coupon
Event
StartedShopping
{
CartId: f5a7f55d-1e33-440c-836c-ea50fc59a274,
CustomerId: f98902b3-e8cf-4b7a-b561-5e39a06b5e0c,
Date: 2014-01-03 15:36:08,
}
AddedSocksToShoppingCart
{
CartId: f5a7f55d-1e33-440c-836c-ea50fc59a274,
ProductId: ed00fa0b-6412-4cc6-bbac-14702bfeff3f,
Quantity: 1,
}
Why?
● Captures business intent
● Transaction & Audit log
● Build/Rebuild to any model
● Debugging
● Integration with other systems
Queries
● Generate Read Model from Events
● Secondary Data Source required
● Eventual Consistency
Started Shopping
Added T-Shirt
Added Socks
Removed Socks
Added Coupon
Any model you can
think of!
Cart Table
CartId
ProductId
Quantity
Denormalized Table
CartId
CustomerName
ProductId
Quantity
Price
CQRS/ES
Data Storage
Domain
Object
Domain
Object
Command Handlers
Client
Command
DTO
Message Queue
Read Layer
Facade
Query
DTO
Event Storage
Events
Message Queue Event Handlers
Data Storage
Drawbacks
● Multiple Models / Data Sources
● Versioning
● Performance
● Maturity / Public Knowledge

Más contenido relacionado

Destacado

Decision Making for Developers
Decision Making for DevelopersDecision Making for Developers
Decision Making for DevelopersDerek Comartin
 
Dati di traffico e indici di benchmark
Dati di traffico e indici di benchmarkDati di traffico e indici di benchmark
Dati di traffico e indici di benchmarkVisionarea
 
Σθένος "Νικήστε το άγχος των εξετάσεων."
Σθένος "Νικήστε το άγχος των εξετάσεων."Σθένος "Νικήστε το άγχος των εξετάσεων."
Σθένος "Νικήστε το άγχος των εξετάσεων."Kosmidis Eleftherios
 
Стратегия подготовки к егэ
Стратегия подготовки к егэСтратегия подготовки к егэ
Стратегия подготовки к егэchechery
 
Presentatie CultuurOntwerp tijdens Klasse Theater Uitjes op 29 april 2014 in ...
Presentatie CultuurOntwerp tijdens Klasse Theater Uitjes op 29 april 2014 in ...Presentatie CultuurOntwerp tijdens Klasse Theater Uitjes op 29 april 2014 in ...
Presentatie CultuurOntwerp tijdens Klasse Theater Uitjes op 29 april 2014 in ...anne-marie kremer
 
Pokemon episod 9
Pokemon episod 9Pokemon episod 9
Pokemon episod 9mimiqaqa
 
BNI 10minuit presentation
BNI 10minuit presentationBNI 10minuit presentation
BNI 10minuit presentationJohn Holloway
 
Http _www_significatodeitarocchi_it_tarocchi_tarocchi-nuovi-metodi-di-lettura_
Http  _www_significatodeitarocchi_it_tarocchi_tarocchi-nuovi-metodi-di-lettura_Http  _www_significatodeitarocchi_it_tarocchi_tarocchi-nuovi-metodi-di-lettura_
Http _www_significatodeitarocchi_it_tarocchi_tarocchi-nuovi-metodi-di-lettura_Rebecca Walcott
 

Destacado (10)

Decision Making for Developers
Decision Making for DevelopersDecision Making for Developers
Decision Making for Developers
 
Dn 3n2d
Dn 3n2dDn 3n2d
Dn 3n2d
 
Dati di traffico e indici di benchmark
Dati di traffico e indici di benchmarkDati di traffico e indici di benchmark
Dati di traffico e indici di benchmark
 
Σθένος "Νικήστε το άγχος των εξετάσεων."
Σθένος "Νικήστε το άγχος των εξετάσεων."Σθένος "Νικήστε το άγχος των εξετάσεων."
Σθένος "Νικήστε το άγχος των εξετάσεων."
 
Стратегия подготовки к егэ
Стратегия подготовки к егэСтратегия подготовки к егэ
Стратегия подготовки к егэ
 
Family law attorney
Family law attorneyFamily law attorney
Family law attorney
 
Presentatie CultuurOntwerp tijdens Klasse Theater Uitjes op 29 april 2014 in ...
Presentatie CultuurOntwerp tijdens Klasse Theater Uitjes op 29 april 2014 in ...Presentatie CultuurOntwerp tijdens Klasse Theater Uitjes op 29 april 2014 in ...
Presentatie CultuurOntwerp tijdens Klasse Theater Uitjes op 29 april 2014 in ...
 
Pokemon episod 9
Pokemon episod 9Pokemon episod 9
Pokemon episod 9
 
BNI 10minuit presentation
BNI 10minuit presentationBNI 10minuit presentation
BNI 10minuit presentation
 
Http _www_significatodeitarocchi_it_tarocchi_tarocchi-nuovi-metodi-di-lettura_
Http  _www_significatodeitarocchi_it_tarocchi_tarocchi-nuovi-metodi-di-lettura_Http  _www_significatodeitarocchi_it_tarocchi_tarocchi-nuovi-metodi-di-lettura_
Http _www_significatodeitarocchi_it_tarocchi_tarocchi-nuovi-metodi-di-lettura_
 

Similar a Event Sourcing

OSMC 2018 | From Monitoring to ITSM by Felix Kronlage
OSMC 2018 | From Monitoring to ITSM by Felix KronlageOSMC 2018 | From Monitoring to ITSM by Felix Kronlage
OSMC 2018 | From Monitoring to ITSM by Felix KronlageNETWAYS
 
SAP Event Management Use Cases
SAP Event Management Use CasesSAP Event Management Use Cases
SAP Event Management Use CasesQ Data USA, Inc.
 
Egn 5620 enterprise_sys_procurement process fall 2012
Egn 5620 enterprise_sys_procurement process fall 2012Egn 5620 enterprise_sys_procurement process fall 2012
Egn 5620 enterprise_sys_procurement process fall 2012Truptir20
 
Egn 5620 enterprise_sys_procurement process fall 2012_123
Egn 5620 enterprise_sys_procurement process fall 2012_123Egn 5620 enterprise_sys_procurement process fall 2012_123
Egn 5620 enterprise_sys_procurement process fall 2012_123Truptir20
 
Decision CAMP 2014 - Howard Rogers - Programming with decision tables v01
Decision CAMP 2014 - Howard Rogers - Programming with decision tables v01Decision CAMP 2014 - Howard Rogers - Programming with decision tables v01
Decision CAMP 2014 - Howard Rogers - Programming with decision tables v01Decision CAMP
 
Grocery Delivery App Development Company |G Tech Solutions
Grocery Delivery App Development Company |G Tech SolutionsGrocery Delivery App Development Company |G Tech Solutions
Grocery Delivery App Development Company |G Tech SolutionsGTechSolutions7
 
Grocery Delivery App Development Company|Features of grocery app|G Tech Solut...
Grocery Delivery App Development Company|Features of grocery app|G Tech Solut...Grocery Delivery App Development Company|Features of grocery app|G Tech Solut...
Grocery Delivery App Development Company|Features of grocery app|G Tech Solut...GTechSolutions7
 
COGS Account Generator Workflow Customization
COGS Account Generator Workflow CustomizationCOGS Account Generator Workflow Customization
COGS Account Generator Workflow CustomizationEdi Yanto
 
Methodology For Australian Business To Rayvat Accounting
Methodology For Australian Business To Rayvat AccountingMethodology For Australian Business To Rayvat Accounting
Methodology For Australian Business To Rayvat AccountingRayvat Accounting
 
The Digital Insurer Award - Tata AIG (IPDS)
The Digital Insurer Award - Tata AIG (IPDS)The Digital Insurer Award - Tata AIG (IPDS)
The Digital Insurer Award - Tata AIG (IPDS)The Digital Insurer
 
IoTで成功を収めるための製品と戦略 〜 Salesforce IoT 〜
IoTで成功を収めるための製品と戦略 〜 Salesforce IoT 〜IoTで成功を収めるための製品と戦略 〜 Salesforce IoT 〜
IoTで成功を収めるための製品と戦略 〜 Salesforce IoT 〜Salesforce Developers Japan
 
Where Digital Analytics is taking BI and Big Data
Where Digital Analytics is taking BI and Big DataWhere Digital Analytics is taking BI and Big Data
Where Digital Analytics is taking BI and Big DataRittman Analytics
 
Where Digital Analytics is taking BI and Big Data
Where Digital Analytics is taking BI and Big DataWhere Digital Analytics is taking BI and Big Data
Where Digital Analytics is taking BI and Big DataRittman Analytics
 
Sap scm ewm na muk 11 02
Sap scm ewm na muk 11  02 Sap scm ewm na muk 11  02
Sap scm ewm na muk 11 02 Gaddam Gaddam
 
Integrating Plone with E-Commerce and Relationship Management: A Case Study i...
Integrating Plone with E-Commerce and Relationship Management: A Case Study i...Integrating Plone with E-Commerce and Relationship Management: A Case Study i...
Integrating Plone with E-Commerce and Relationship Management: A Case Study i...David Glick
 

Similar a Event Sourcing (20)

OSMC 2018 | From Monitoring to ITSM by Felix Kronlage
OSMC 2018 | From Monitoring to ITSM by Felix KronlageOSMC 2018 | From Monitoring to ITSM by Felix Kronlage
OSMC 2018 | From Monitoring to ITSM by Felix Kronlage
 
SAP Event Management Use Cases
SAP Event Management Use CasesSAP Event Management Use Cases
SAP Event Management Use Cases
 
Egn 5620 enterprise_sys_procurement process fall 2012
Egn 5620 enterprise_sys_procurement process fall 2012Egn 5620 enterprise_sys_procurement process fall 2012
Egn 5620 enterprise_sys_procurement process fall 2012
 
Egn 5620 enterprise_sys_procurement process fall 2012_123
Egn 5620 enterprise_sys_procurement process fall 2012_123Egn 5620 enterprise_sys_procurement process fall 2012_123
Egn 5620 enterprise_sys_procurement process fall 2012_123
 
Decision CAMP 2014 - Howard Rogers - Programming with decision tables v01
Decision CAMP 2014 - Howard Rogers - Programming with decision tables v01Decision CAMP 2014 - Howard Rogers - Programming with decision tables v01
Decision CAMP 2014 - Howard Rogers - Programming with decision tables v01
 
Grocery Delivery App Development Company |G Tech Solutions
Grocery Delivery App Development Company |G Tech SolutionsGrocery Delivery App Development Company |G Tech Solutions
Grocery Delivery App Development Company |G Tech Solutions
 
Grocery Delivery App Development Company|Features of grocery app|G Tech Solut...
Grocery Delivery App Development Company|Features of grocery app|G Tech Solut...Grocery Delivery App Development Company|Features of grocery app|G Tech Solut...
Grocery Delivery App Development Company|Features of grocery app|G Tech Solut...
 
COGS Account Generator Workflow Customization
COGS Account Generator Workflow CustomizationCOGS Account Generator Workflow Customization
COGS Account Generator Workflow Customization
 
Work relay demo v3
Work relay demo v3Work relay demo v3
Work relay demo v3
 
Methodology For Australian Business To Rayvat Accounting
Methodology For Australian Business To Rayvat AccountingMethodology For Australian Business To Rayvat Accounting
Methodology For Australian Business To Rayvat Accounting
 
The Digital Insurer Award - Tata AIG (IPDS)
The Digital Insurer Award - Tata AIG (IPDS)The Digital Insurer Award - Tata AIG (IPDS)
The Digital Insurer Award - Tata AIG (IPDS)
 
Six Sigma Process Improvement Foundational Steps
Six Sigma Process Improvement Foundational StepsSix Sigma Process Improvement Foundational Steps
Six Sigma Process Improvement Foundational Steps
 
Erp system f test
Erp system   f testErp system   f test
Erp system f test
 
IoTで成功を収めるための製品と戦略 〜 Salesforce IoT 〜
IoTで成功を収めるための製品と戦略 〜 Salesforce IoT 〜IoTで成功を収めるための製品と戦略 〜 Salesforce IoT 〜
IoTで成功を収めるための製品と戦略 〜 Salesforce IoT 〜
 
Product list
Product listProduct list
Product list
 
Where Digital Analytics is taking BI and Big Data
Where Digital Analytics is taking BI and Big DataWhere Digital Analytics is taking BI and Big Data
Where Digital Analytics is taking BI and Big Data
 
Where Digital Analytics is taking BI and Big Data
Where Digital Analytics is taking BI and Big DataWhere Digital Analytics is taking BI and Big Data
Where Digital Analytics is taking BI and Big Data
 
Sap scm ewm na muk 11 02
Sap scm ewm na muk 11  02 Sap scm ewm na muk 11  02
Sap scm ewm na muk 11 02
 
Patterns for Building Streaming Apps
Patterns for Building Streaming AppsPatterns for Building Streaming Apps
Patterns for Building Streaming Apps
 
Integrating Plone with E-Commerce and Relationship Management: A Case Study i...
Integrating Plone with E-Commerce and Relationship Management: A Case Study i...Integrating Plone with E-Commerce and Relationship Management: A Case Study i...
Integrating Plone with E-Commerce and Relationship Management: A Case Study i...
 

Último

Take control of your SAP testing with UiPath Test Suite
Take control of your SAP testing with UiPath Test SuiteTake control of your SAP testing with UiPath Test Suite
Take control of your SAP testing with UiPath Test SuiteDianaGray10
 
Use of FIDO in the Payments and Identity Landscape: FIDO Paris Seminar.pptx
Use of FIDO in the Payments and Identity Landscape: FIDO Paris Seminar.pptxUse of FIDO in the Payments and Identity Landscape: FIDO Paris Seminar.pptx
Use of FIDO in the Payments and Identity Landscape: FIDO Paris Seminar.pptxLoriGlavin3
 
Why device, WIFI, and ISP insights are crucial to supporting remote Microsoft...
Why device, WIFI, and ISP insights are crucial to supporting remote Microsoft...Why device, WIFI, and ISP insights are crucial to supporting remote Microsoft...
Why device, WIFI, and ISP insights are crucial to supporting remote Microsoft...panagenda
 
Enhancing User Experience - Exploring the Latest Features of Tallyman Axis Lo...
Enhancing User Experience - Exploring the Latest Features of Tallyman Axis Lo...Enhancing User Experience - Exploring the Latest Features of Tallyman Axis Lo...
Enhancing User Experience - Exploring the Latest Features of Tallyman Axis Lo...Scott Andery
 
How to write a Business Continuity Plan
How to write a Business Continuity PlanHow to write a Business Continuity Plan
How to write a Business Continuity PlanDatabarracks
 
The Fit for Passkeys for Employee and Consumer Sign-ins: FIDO Paris Seminar.pptx
The Fit for Passkeys for Employee and Consumer Sign-ins: FIDO Paris Seminar.pptxThe Fit for Passkeys for Employee and Consumer Sign-ins: FIDO Paris Seminar.pptx
The Fit for Passkeys for Employee and Consumer Sign-ins: FIDO Paris Seminar.pptxLoriGlavin3
 
Moving Beyond Passwords: FIDO Paris Seminar.pdf
Moving Beyond Passwords: FIDO Paris Seminar.pdfMoving Beyond Passwords: FIDO Paris Seminar.pdf
Moving Beyond Passwords: FIDO Paris Seminar.pdfLoriGlavin3
 
Assure Ecommerce and Retail Operations Uptime with ThousandEyes
Assure Ecommerce and Retail Operations Uptime with ThousandEyesAssure Ecommerce and Retail Operations Uptime with ThousandEyes
Assure Ecommerce and Retail Operations Uptime with ThousandEyesThousandEyes
 
Rise of the Machines: Known As Drones...
Rise of the Machines: Known As Drones...Rise of the Machines: Known As Drones...
Rise of the Machines: Known As Drones...Rick Flair
 
Sample pptx for embedding into website for demo
Sample pptx for embedding into website for demoSample pptx for embedding into website for demo
Sample pptx for embedding into website for demoHarshalMandlekar2
 
The Ultimate Guide to Choosing WordPress Pros and Cons
The Ultimate Guide to Choosing WordPress Pros and ConsThe Ultimate Guide to Choosing WordPress Pros and Cons
The Ultimate Guide to Choosing WordPress Pros and ConsPixlogix Infotech
 
So einfach geht modernes Roaming fuer Notes und Nomad.pdf
So einfach geht modernes Roaming fuer Notes und Nomad.pdfSo einfach geht modernes Roaming fuer Notes und Nomad.pdf
So einfach geht modernes Roaming fuer Notes und Nomad.pdfpanagenda
 
Merck Moving Beyond Passwords: FIDO Paris Seminar.pptx
Merck Moving Beyond Passwords: FIDO Paris Seminar.pptxMerck Moving Beyond Passwords: FIDO Paris Seminar.pptx
Merck Moving Beyond Passwords: FIDO Paris Seminar.pptxLoriGlavin3
 
Data governance with Unity Catalog Presentation
Data governance with Unity Catalog PresentationData governance with Unity Catalog Presentation
Data governance with Unity Catalog PresentationKnoldus Inc.
 
A Framework for Development in the AI Age
A Framework for Development in the AI AgeA Framework for Development in the AI Age
A Framework for Development in the AI AgeCprime
 
From Family Reminiscence to Scholarly Archive .
From Family Reminiscence to Scholarly Archive .From Family Reminiscence to Scholarly Archive .
From Family Reminiscence to Scholarly Archive .Alan Dix
 
Modern Roaming for Notes and Nomad – Cheaper Faster Better Stronger
Modern Roaming for Notes and Nomad – Cheaper Faster Better StrongerModern Roaming for Notes and Nomad – Cheaper Faster Better Stronger
Modern Roaming for Notes and Nomad – Cheaper Faster Better Strongerpanagenda
 
A Deep Dive on Passkeys: FIDO Paris Seminar.pptx
A Deep Dive on Passkeys: FIDO Paris Seminar.pptxA Deep Dive on Passkeys: FIDO Paris Seminar.pptx
A Deep Dive on Passkeys: FIDO Paris Seminar.pptxLoriGlavin3
 
Passkey Providers and Enabling Portability: FIDO Paris Seminar.pptx
Passkey Providers and Enabling Portability: FIDO Paris Seminar.pptxPasskey Providers and Enabling Portability: FIDO Paris Seminar.pptx
Passkey Providers and Enabling Portability: FIDO Paris Seminar.pptxLoriGlavin3
 
How AI, OpenAI, and ChatGPT impact business and software.
How AI, OpenAI, and ChatGPT impact business and software.How AI, OpenAI, and ChatGPT impact business and software.
How AI, OpenAI, and ChatGPT impact business and software.Curtis Poe
 

Último (20)

Take control of your SAP testing with UiPath Test Suite
Take control of your SAP testing with UiPath Test SuiteTake control of your SAP testing with UiPath Test Suite
Take control of your SAP testing with UiPath Test Suite
 
Use of FIDO in the Payments and Identity Landscape: FIDO Paris Seminar.pptx
Use of FIDO in the Payments and Identity Landscape: FIDO Paris Seminar.pptxUse of FIDO in the Payments and Identity Landscape: FIDO Paris Seminar.pptx
Use of FIDO in the Payments and Identity Landscape: FIDO Paris Seminar.pptx
 
Why device, WIFI, and ISP insights are crucial to supporting remote Microsoft...
Why device, WIFI, and ISP insights are crucial to supporting remote Microsoft...Why device, WIFI, and ISP insights are crucial to supporting remote Microsoft...
Why device, WIFI, and ISP insights are crucial to supporting remote Microsoft...
 
Enhancing User Experience - Exploring the Latest Features of Tallyman Axis Lo...
Enhancing User Experience - Exploring the Latest Features of Tallyman Axis Lo...Enhancing User Experience - Exploring the Latest Features of Tallyman Axis Lo...
Enhancing User Experience - Exploring the Latest Features of Tallyman Axis Lo...
 
How to write a Business Continuity Plan
How to write a Business Continuity PlanHow to write a Business Continuity Plan
How to write a Business Continuity Plan
 
The Fit for Passkeys for Employee and Consumer Sign-ins: FIDO Paris Seminar.pptx
The Fit for Passkeys for Employee and Consumer Sign-ins: FIDO Paris Seminar.pptxThe Fit for Passkeys for Employee and Consumer Sign-ins: FIDO Paris Seminar.pptx
The Fit for Passkeys for Employee and Consumer Sign-ins: FIDO Paris Seminar.pptx
 
Moving Beyond Passwords: FIDO Paris Seminar.pdf
Moving Beyond Passwords: FIDO Paris Seminar.pdfMoving Beyond Passwords: FIDO Paris Seminar.pdf
Moving Beyond Passwords: FIDO Paris Seminar.pdf
 
Assure Ecommerce and Retail Operations Uptime with ThousandEyes
Assure Ecommerce and Retail Operations Uptime with ThousandEyesAssure Ecommerce and Retail Operations Uptime with ThousandEyes
Assure Ecommerce and Retail Operations Uptime with ThousandEyes
 
Rise of the Machines: Known As Drones...
Rise of the Machines: Known As Drones...Rise of the Machines: Known As Drones...
Rise of the Machines: Known As Drones...
 
Sample pptx for embedding into website for demo
Sample pptx for embedding into website for demoSample pptx for embedding into website for demo
Sample pptx for embedding into website for demo
 
The Ultimate Guide to Choosing WordPress Pros and Cons
The Ultimate Guide to Choosing WordPress Pros and ConsThe Ultimate Guide to Choosing WordPress Pros and Cons
The Ultimate Guide to Choosing WordPress Pros and Cons
 
So einfach geht modernes Roaming fuer Notes und Nomad.pdf
So einfach geht modernes Roaming fuer Notes und Nomad.pdfSo einfach geht modernes Roaming fuer Notes und Nomad.pdf
So einfach geht modernes Roaming fuer Notes und Nomad.pdf
 
Merck Moving Beyond Passwords: FIDO Paris Seminar.pptx
Merck Moving Beyond Passwords: FIDO Paris Seminar.pptxMerck Moving Beyond Passwords: FIDO Paris Seminar.pptx
Merck Moving Beyond Passwords: FIDO Paris Seminar.pptx
 
Data governance with Unity Catalog Presentation
Data governance with Unity Catalog PresentationData governance with Unity Catalog Presentation
Data governance with Unity Catalog Presentation
 
A Framework for Development in the AI Age
A Framework for Development in the AI AgeA Framework for Development in the AI Age
A Framework for Development in the AI Age
 
From Family Reminiscence to Scholarly Archive .
From Family Reminiscence to Scholarly Archive .From Family Reminiscence to Scholarly Archive .
From Family Reminiscence to Scholarly Archive .
 
Modern Roaming for Notes and Nomad – Cheaper Faster Better Stronger
Modern Roaming for Notes and Nomad – Cheaper Faster Better StrongerModern Roaming for Notes and Nomad – Cheaper Faster Better Stronger
Modern Roaming for Notes and Nomad – Cheaper Faster Better Stronger
 
A Deep Dive on Passkeys: FIDO Paris Seminar.pptx
A Deep Dive on Passkeys: FIDO Paris Seminar.pptxA Deep Dive on Passkeys: FIDO Paris Seminar.pptx
A Deep Dive on Passkeys: FIDO Paris Seminar.pptx
 
Passkey Providers and Enabling Portability: FIDO Paris Seminar.pptx
Passkey Providers and Enabling Portability: FIDO Paris Seminar.pptxPasskey Providers and Enabling Portability: FIDO Paris Seminar.pptx
Passkey Providers and Enabling Portability: FIDO Paris Seminar.pptx
 
How AI, OpenAI, and ChatGPT impact business and software.
How AI, OpenAI, and ChatGPT impact business and software.How AI, OpenAI, and ChatGPT impact business and software.
How AI, OpenAI, and ChatGPT impact business and software.
 

Event Sourcing