SlideShare a Scribd company logo
BuildÄąng a tÄąme machine with
.NET Core
Alper Hankendi
@alper_hankendi
github.com/alperhankendi
Agenda
➔ Getting Started Event
Sourcing
➔ History of Event
Sourcing
➔ Building Aggregates
➔ Projections
➔ Rolling Snapshot
➔ Demo yey!
Join at
slido.com
#U520
Audience Q&A Session
Once upon a time...
ScalÄąng up...
Let’s go asynchronous
COMMAND SOURCING
COMMANDs >>> Event sourcing
COMMANDS vs events
Command
“Create Account”
—> A request (imperative sentence)
—> May fail
—> May affect multiple Aggregates
Rebuild Aggregate State
From Commands
COMMANDS vs events
Event
“Account Created”
—> Statement of fact (past tense)
—> Never fails
—> May affect a signle Aggregates
—> Events are immutable
Rebuild Aggregate State
From Events
What about reads?
Building time machine with .net core
Building time machine with .net core
CQRS and Event sourcÄąng
A couple of concepts from ddd
InteractÄąon wÄąth aggregates
Projections
Demo tÄąme!
Demo tÄąme!
Commands
Events
Projections
How do I replay tons of events ?
The problem is that there may be a large number of events
between the beginning of time and the current point. You can
imagine that an event stream with a million or more events would
be inefficient to load.
The answer is “rollıng snapshot”
Snapshot is a projection of the current state of an aggregate at a
given point. It presents the state when all events to that point
have been replayed.
UPS! The bank says “Where ıs my commısıon ffs”?
You can’t delete events...
How we gonna fÄąx Äąt?
WithdrewFix
you can fÄąx the past wÄąth adding a new event
FIN
@alper_hankendi
github.com/alperhankendi
Ad

Recommended

React Fundamentals - Jakarta JS, Apr 2016
React Fundamentals - Jakarta JS, Apr 2016
Simon Sturmer
 
React Walk-Thru - Santa Cruz JS, May 2015
React Walk-Thru - Santa Cruz JS, May 2015
Simon Sturmer
 
JS Chicago Meetup 2/23/16 - Redux & Routes
JS Chicago Meetup 2/23/16 - Redux & Routes
Nick Dreckshage
 
Node.js Lightning Talk
Node.js Lightning Talk
CodeSlice
 
Starting with Reactjs
Starting with Reactjs
Thinh VoXuan
 
ReactJS.NET - Fast and Scalable Single Page Applications
ReactJS.NET - Fast and Scalable Single Page Applications
Rick Beerendonk
 
From zero to git
From zero to git
Bruno Almeida
 
From MVP to a Product
From MVP to a Product
Justyna Wojtczak
 
Migrating your Web app to Virtual Reality
Migrating your Web app to Virtual Reality
Denis Radin
 
HTML GL - 60 FPS and amazing effects by rendering HTML/CSS in WebGL, framewor...
HTML GL - 60 FPS and amazing effects by rendering HTML/CSS in WebGL, framewor...
Denis Radin
 
Real time event dashboards
Real time event dashboards
epiineg1
 
Service Worker Presentation
Service Worker Presentation
Kyle Dorman
 
Untangling spring week7
Untangling spring week7
Derek Jacoby
 
xPad - Building Simple Tablet OS with Gtk/WebKit
xPad - Building Simple Tablet OS with Gtk/WebKit
Ping-Hsun Chen
 
Event-Driven Architecture Traps - Jakub Pilimon
Event-Driven Architecture Traps - Jakub Pilimon
VMware Tanzu
 
Simple todo app with meteor
Simple todo app with meteor
Alex Long
 
Introduction to ReactJS
Introduction to ReactJS
Hoang Long
 
Os mobile
Os mobile
jimlindforpope
 
Desktop, Web e Mobile
Desktop, Web e Mobile
Paulo Moura
 
Breaking the Server-Client Divide with Node.js and React
Breaking the Server-Client Divide with Node.js and React
Dejan Glozic
 
Os mobile
Os mobile
jimlindforpope
 
GreenButton-201502
GreenButton-201502
Jonathan Kalbfeld, MBA
 
Untangling8
Untangling8
Derek Jacoby
 
HTML GL - возьмите столько FPS, сколько вам нужно!
HTML GL - возьмите столько FPS, сколько вам нужно!
CodeFest
 
Building Single Page Apps with React.JS
Building Single Page Apps with React.JS
Vagmi Mudumbai
 
JavaScript Roadmap - DOM Manipulation
JavaScript Roadmap - DOM Manipulation
Aswin Barath
 
Unleashing WebGL & WebAudio with babylon.js
Unleashing WebGL & WebAudio with babylon.js
davrous
 
Introduction to ReactJS
Introduction to ReactJS
Tu Hoang
 
Beyond CRUD: patterns that never forget
Beyond CRUD: patterns that never forget
Diego Moreno
 
Andrii Dembitskyi "Events in our applications Event bus and distributed systems"
Andrii Dembitskyi "Events in our applications Event bus and distributed systems"
Fwdays
 

More Related Content

What's hot (20)

Migrating your Web app to Virtual Reality
Migrating your Web app to Virtual Reality
Denis Radin
 
HTML GL - 60 FPS and amazing effects by rendering HTML/CSS in WebGL, framewor...
HTML GL - 60 FPS and amazing effects by rendering HTML/CSS in WebGL, framewor...
Denis Radin
 
Real time event dashboards
Real time event dashboards
epiineg1
 
Service Worker Presentation
Service Worker Presentation
Kyle Dorman
 
Untangling spring week7
Untangling spring week7
Derek Jacoby
 
xPad - Building Simple Tablet OS with Gtk/WebKit
xPad - Building Simple Tablet OS with Gtk/WebKit
Ping-Hsun Chen
 
Event-Driven Architecture Traps - Jakub Pilimon
Event-Driven Architecture Traps - Jakub Pilimon
VMware Tanzu
 
Simple todo app with meteor
Simple todo app with meteor
Alex Long
 
Introduction to ReactJS
Introduction to ReactJS
Hoang Long
 
Os mobile
Os mobile
jimlindforpope
 
Desktop, Web e Mobile
Desktop, Web e Mobile
Paulo Moura
 
Breaking the Server-Client Divide with Node.js and React
Breaking the Server-Client Divide with Node.js and React
Dejan Glozic
 
Os mobile
Os mobile
jimlindforpope
 
GreenButton-201502
GreenButton-201502
Jonathan Kalbfeld, MBA
 
Untangling8
Untangling8
Derek Jacoby
 
HTML GL - возьмите столько FPS, сколько вам нужно!
HTML GL - возьмите столько FPS, сколько вам нужно!
CodeFest
 
Building Single Page Apps with React.JS
Building Single Page Apps with React.JS
Vagmi Mudumbai
 
JavaScript Roadmap - DOM Manipulation
JavaScript Roadmap - DOM Manipulation
Aswin Barath
 
Unleashing WebGL & WebAudio with babylon.js
Unleashing WebGL & WebAudio with babylon.js
davrous
 
Introduction to ReactJS
Introduction to ReactJS
Tu Hoang
 
Migrating your Web app to Virtual Reality
Migrating your Web app to Virtual Reality
Denis Radin
 
HTML GL - 60 FPS and amazing effects by rendering HTML/CSS in WebGL, framewor...
HTML GL - 60 FPS and amazing effects by rendering HTML/CSS in WebGL, framewor...
Denis Radin
 
Real time event dashboards
Real time event dashboards
epiineg1
 
Service Worker Presentation
Service Worker Presentation
Kyle Dorman
 
Untangling spring week7
Untangling spring week7
Derek Jacoby
 
xPad - Building Simple Tablet OS with Gtk/WebKit
xPad - Building Simple Tablet OS with Gtk/WebKit
Ping-Hsun Chen
 
Event-Driven Architecture Traps - Jakub Pilimon
Event-Driven Architecture Traps - Jakub Pilimon
VMware Tanzu
 
Simple todo app with meteor
Simple todo app with meteor
Alex Long
 
Introduction to ReactJS
Introduction to ReactJS
Hoang Long
 
Desktop, Web e Mobile
Desktop, Web e Mobile
Paulo Moura
 
Breaking the Server-Client Divide with Node.js and React
Breaking the Server-Client Divide with Node.js and React
Dejan Glozic
 
HTML GL - возьмите столько FPS, сколько вам нужно!
HTML GL - возьмите столько FPS, сколько вам нужно!
CodeFest
 
Building Single Page Apps with React.JS
Building Single Page Apps with React.JS
Vagmi Mudumbai
 
JavaScript Roadmap - DOM Manipulation
JavaScript Roadmap - DOM Manipulation
Aswin Barath
 
Unleashing WebGL & WebAudio with babylon.js
Unleashing WebGL & WebAudio with babylon.js
davrous
 
Introduction to ReactJS
Introduction to ReactJS
Tu Hoang
 

Similar to Building time machine with .net core (20)

Beyond CRUD: patterns that never forget
Beyond CRUD: patterns that never forget
Diego Moreno
 
Andrii Dembitskyi "Events in our applications Event bus and distributed systems"
Andrii Dembitskyi "Events in our applications Event bus and distributed systems"
Fwdays
 
The Fine Art of Time Travelling: implementing Event Sourcing
The Fine Art of Time Travelling: implementing Event Sourcing
Andrea Saltarello
 
Tyler Wright - Undo History with Flight
Tyler Wright - Undo History with Flight
360|Conferences
 
Concurrecny inf sharp
Concurrecny inf sharp
Riccardo Terrell
 
Introduction to Event Sourcing in PHP
Introduction to Event Sourcing in PHP
Evan McMahon
 
Introduction to Client Side Dev in SharePoint Workshop
Introduction to Client Side Dev in SharePoint Workshop
Mark Rackley
 
Event Driven Architecture Concepts in Web Technologies - Part 1
Event Driven Architecture Concepts in Web Technologies - Part 1
Hamidreza Soleimani
 
Kickstarting Node.js Projects with Yeoman
Kickstarting Node.js Projects with Yeoman
Patrick Buergin
 
Flink. Pure Streaming
Flink. Pure Streaming
Indizen Technologies
 
Slideshare - Magento Imagine - Do You Queue
Slideshare - Magento Imagine - Do You Queue
10n Software, LLC
 
Continuous Integration using Cruise Control
Continuous Integration using Cruise Control
elliando dias
 
Prototyping app using JS and HTML5 (Ciklum Kharkiv)
Prototyping app using JS and HTML5 (Ciklum Kharkiv)
Yuriy Silvestrov
 
Investing in a good software factory and automating the build process
Investing in a good software factory and automating the build process
Nicolas Mas
 
fram^ TechTalk #1 - CQRS and Event Sourcing (ES)
fram^ TechTalk #1 - CQRS and Event Sourcing (ES)
Fram^ - IT Engineering & Venture Building
 
A New Perspective on Resource-Level Cloud Forensics
A New Perspective on Resource-Level Cloud Forensics
Christopher Doman
 
Why do you Need to Migrate to Salesforce Flow?, Andrew Cook
Why do you Need to Migrate to Salesforce Flow?, Andrew Cook
CzechDreamin
 
Zero to tested
Zero to tested
MagenTys
 
CI
CI
Patrick Mizer
 
Magento's Imagine eCommerce Conference: Do You Queue?
Magento's Imagine eCommerce Conference: Do You Queue?
varien
 
Beyond CRUD: patterns that never forget
Beyond CRUD: patterns that never forget
Diego Moreno
 
Andrii Dembitskyi "Events in our applications Event bus and distributed systems"
Andrii Dembitskyi "Events in our applications Event bus and distributed systems"
Fwdays
 
The Fine Art of Time Travelling: implementing Event Sourcing
The Fine Art of Time Travelling: implementing Event Sourcing
Andrea Saltarello
 
Tyler Wright - Undo History with Flight
Tyler Wright - Undo History with Flight
360|Conferences
 
Concurrecny inf sharp
Concurrecny inf sharp
Riccardo Terrell
 
Introduction to Event Sourcing in PHP
Introduction to Event Sourcing in PHP
Evan McMahon
 
Introduction to Client Side Dev in SharePoint Workshop
Introduction to Client Side Dev in SharePoint Workshop
Mark Rackley
 
Event Driven Architecture Concepts in Web Technologies - Part 1
Event Driven Architecture Concepts in Web Technologies - Part 1
Hamidreza Soleimani
 
Kickstarting Node.js Projects with Yeoman
Kickstarting Node.js Projects with Yeoman
Patrick Buergin
 
Slideshare - Magento Imagine - Do You Queue
Slideshare - Magento Imagine - Do You Queue
10n Software, LLC
 
Continuous Integration using Cruise Control
Continuous Integration using Cruise Control
elliando dias
 
Prototyping app using JS and HTML5 (Ciklum Kharkiv)
Prototyping app using JS and HTML5 (Ciklum Kharkiv)
Yuriy Silvestrov
 
Investing in a good software factory and automating the build process
Investing in a good software factory and automating the build process
Nicolas Mas
 
A New Perspective on Resource-Level Cloud Forensics
A New Perspective on Resource-Level Cloud Forensics
Christopher Doman
 
Why do you Need to Migrate to Salesforce Flow?, Andrew Cook
Why do you Need to Migrate to Salesforce Flow?, Andrew Cook
CzechDreamin
 
Zero to tested
Zero to tested
MagenTys
 
Magento's Imagine eCommerce Conference: Do You Queue?
Magento's Imagine eCommerce Conference: Do You Queue?
varien
 
Ad

Recently uploaded (20)

IDM Crack with Internet Download Manager 6.42 Build 41 [Latest 2025]
IDM Crack with Internet Download Manager 6.42 Build 41 [Latest 2025]
pcprocore
 
OpenChain Webinar - AboutCode - Practical Compliance in One Stack – Licensing...
OpenChain Webinar - AboutCode - Practical Compliance in One Stack – Licensing...
Shane Coughlan
 
Modern Platform Engineering with Choreo - The AI-Native Internal Developer Pl...
Modern Platform Engineering with Choreo - The AI-Native Internal Developer Pl...
WSO2
 
Sysinfo OST to PST Converter Infographic
Sysinfo OST to PST Converter Infographic
SysInfo Tools
 
Folding Cheat Sheet # 9 - List Unfolding 𝑢𝑛𝑓𝑜𝑙𝑑 as the Computational Dual of ...
Folding Cheat Sheet # 9 - List Unfolding 𝑢𝑛𝑓𝑜𝑙𝑑 as the Computational Dual of ...
Philip Schwarz
 
The Anti-Masterclass Live - Peak of Data & AI 2025
The Anti-Masterclass Live - Peak of Data & AI 2025
Safe Software
 
Automated Migration of ESRI Geodatabases Using XML Control Files and FME
Automated Migration of ESRI Geodatabases Using XML Control Files and FME
Safe Software
 
Zoneranker’s Digital marketing solutions
Zoneranker’s Digital marketing solutions
reenashriee
 
How Automation in Claims Handling Streamlined Operations
How Automation in Claims Handling Streamlined Operations
Insurance Tech Services
 
Streamlining CI/CD with FME Flow: A Practical Guide
Streamlining CI/CD with FME Flow: A Practical Guide
Safe Software
 
Key Challenges in Troubleshooting Customer On-Premise Applications
Key Challenges in Troubleshooting Customer On-Premise Applications
Tier1 app
 
Canva Pro Crack Free Download 2025-FREE LATEST
Canva Pro Crack Free Download 2025-FREE LATEST
grete1122g
 
MOVIE RECOMMENDATION SYSTEM, UDUMULA GOPI REDDY, Y24MC13085.pptx
MOVIE RECOMMENDATION SYSTEM, UDUMULA GOPI REDDY, Y24MC13085.pptx
Maharshi Mallela
 
Zoho Creator Solution for EI by Elsner Technologies.docx
Zoho Creator Solution for EI by Elsner Technologies.docx
Elsner Technologies Pvt. Ltd.
 
Enable Your Cloud Journey With Microsoft Trusted Partner | IFI Tech
Enable Your Cloud Journey With Microsoft Trusted Partner | IFI Tech
IFI Techsolutions
 
CodeCleaner: Mitigating Data Contamination for LLM Benchmarking
CodeCleaner: Mitigating Data Contamination for LLM Benchmarking
arabelatso
 
Milwaukee Marketo User Group June 2025 - Optimize and Enhance Efficiency - Sm...
Milwaukee Marketo User Group June 2025 - Optimize and Enhance Efficiency - Sm...
BradBedford3
 
Microsoft-365-Administrator-s-Guide1.pdf
Microsoft-365-Administrator-s-Guide1.pdf
mazharatknl
 
Best MLM Compensation Plans for Network Marketing Success in 2025
Best MLM Compensation Plans for Network Marketing Success in 2025
LETSCMS Pvt. Ltd.
 
SAP PM Module Level-IV Training Complete.ppt
SAP PM Module Level-IV Training Complete.ppt
MuhammadShaheryar36
 
IDM Crack with Internet Download Manager 6.42 Build 41 [Latest 2025]
IDM Crack with Internet Download Manager 6.42 Build 41 [Latest 2025]
pcprocore
 
OpenChain Webinar - AboutCode - Practical Compliance in One Stack – Licensing...
OpenChain Webinar - AboutCode - Practical Compliance in One Stack – Licensing...
Shane Coughlan
 
Modern Platform Engineering with Choreo - The AI-Native Internal Developer Pl...
Modern Platform Engineering with Choreo - The AI-Native Internal Developer Pl...
WSO2
 
Sysinfo OST to PST Converter Infographic
Sysinfo OST to PST Converter Infographic
SysInfo Tools
 
Folding Cheat Sheet # 9 - List Unfolding 𝑢𝑛𝑓𝑜𝑙𝑑 as the Computational Dual of ...
Folding Cheat Sheet # 9 - List Unfolding 𝑢𝑛𝑓𝑜𝑙𝑑 as the Computational Dual of ...
Philip Schwarz
 
The Anti-Masterclass Live - Peak of Data & AI 2025
The Anti-Masterclass Live - Peak of Data & AI 2025
Safe Software
 
Automated Migration of ESRI Geodatabases Using XML Control Files and FME
Automated Migration of ESRI Geodatabases Using XML Control Files and FME
Safe Software
 
Zoneranker’s Digital marketing solutions
Zoneranker’s Digital marketing solutions
reenashriee
 
How Automation in Claims Handling Streamlined Operations
How Automation in Claims Handling Streamlined Operations
Insurance Tech Services
 
Streamlining CI/CD with FME Flow: A Practical Guide
Streamlining CI/CD with FME Flow: A Practical Guide
Safe Software
 
Key Challenges in Troubleshooting Customer On-Premise Applications
Key Challenges in Troubleshooting Customer On-Premise Applications
Tier1 app
 
Canva Pro Crack Free Download 2025-FREE LATEST
Canva Pro Crack Free Download 2025-FREE LATEST
grete1122g
 
MOVIE RECOMMENDATION SYSTEM, UDUMULA GOPI REDDY, Y24MC13085.pptx
MOVIE RECOMMENDATION SYSTEM, UDUMULA GOPI REDDY, Y24MC13085.pptx
Maharshi Mallela
 
Zoho Creator Solution for EI by Elsner Technologies.docx
Zoho Creator Solution for EI by Elsner Technologies.docx
Elsner Technologies Pvt. Ltd.
 
Enable Your Cloud Journey With Microsoft Trusted Partner | IFI Tech
Enable Your Cloud Journey With Microsoft Trusted Partner | IFI Tech
IFI Techsolutions
 
CodeCleaner: Mitigating Data Contamination for LLM Benchmarking
CodeCleaner: Mitigating Data Contamination for LLM Benchmarking
arabelatso
 
Milwaukee Marketo User Group June 2025 - Optimize and Enhance Efficiency - Sm...
Milwaukee Marketo User Group June 2025 - Optimize and Enhance Efficiency - Sm...
BradBedford3
 
Microsoft-365-Administrator-s-Guide1.pdf
Microsoft-365-Administrator-s-Guide1.pdf
mazharatknl
 
Best MLM Compensation Plans for Network Marketing Success in 2025
Best MLM Compensation Plans for Network Marketing Success in 2025
LETSCMS Pvt. Ltd.
 
SAP PM Module Level-IV Training Complete.ppt
SAP PM Module Level-IV Training Complete.ppt
MuhammadShaheryar36
 
Ad

Building time machine with .net core