JCON 2020: CQRS und Event Sourcing unter Strom: Lessons Learned mit Spring und Axon

Frank Scheffler
Frank SchefflerSenior Solution Architect um Digital Frontiers GmbH & Co. KG
1
CQRS und Event Sourcing
unter Strom
Lessons Learned mit Spring und Axon
@qimono on Pixabay
@maverick_1601
Frank SchefflerMatthias Grünewald
https://bit.ly/2J7wvwp
2
Syna
Netzbetreiber für Strom- und Gasversorgung
Fachdomäne
Energiesektor
Netzanschluss
3
Kunde
Die schriftliche, komplizierte Beantragung eines Strom- / Gasanschlusses
soll digital und einfach werden.
Fachbereich
Anträge von Netzanschlüssen sollen vollständige und plausible Angaben
enthalten. Rückfragen sollen reduziert werden.
Welche Probleme sollten gelöst werden?
4
Ausschnitt: Konfiguration eines Netzanschlusses
6000 Kombinationen
Ziel: Richtiger Weg
Kunden führen
5
https://netzanschluss.syna.de
6
Warum haben wir uns für CQRS und Event Sourcing entschieden?
Skalierbare Infrastruktur
zur Abfrage der
Applikationsdaten
(Firestore)
vs.
Zentrale Koordination
ändernder Operationen
(REST)
Auf Basis historischer
Daten Nutzerverhalten
verstehen
Konsistente
Datenübermittlung an
Drittsysteme, auch
nachträglich
7
Schichtenarchitektur vs. CQRS & ES
Presentation
Domain Logic
Data Access
DB
Queue
REST
Controller
Services
Repositories
Interaction
New/Updated
State
Messages
Domain Logic
Event
Store
Presentation
Interaction
Change
Event(s)
REST
Controller
Queue
Input Message
Output
Message
Event Handler
Event Handler
Read
Model
Current State
(Event Sourced)
Repositories
C
C
E
E
E
9
Axon in Action
Event
Store
Presentation
Event Handler
Read
Model
Command
Gateway
10
Hexagonale Architektur
(Ports & Adapters)
Domain
Web App
Firestore
REST
Controller
Firestore
Projector
Storage
Bucket
Pub/Sub
Message
Sink
Storage
Topic
PDF
Creator
SAP
SAP
Client
Analytics
Analytics
Data
C
C
E
E
E
E
Domain
Test(s)
Adapter
Test(s)
11
Fazit: “Was haben wir gelernt?”
Hat uns überzeugt
● Intuitive Code Struktur
(Commands, Aggregates,
Events)
● Testing mit Axon (Domain
und Adapter)
● Replay-Fähigkeit (z.B.
Analytics)
Hätten wir gerne
vorher gewusst
● Umgang mit Konflikten,
Retry und Caching
● Persistierung der Events
(JSON) und Upcasting
● Parallelisierbare
Eventverarbeitung
Haben wir noch vor
uns
● Feingranulare Events
(besonders bei
nicht-transaktionalen
Aufrufen, z.B. REST)
● Aussteuerung und
Visualisierung
blockierender Events
12
Ja, …
1. … denn es ist ein anderes, aber sehr intuitives Programmiermodell
2. … man benötigt jedoch eine gewisse Einarbeitungszeit
3. … man sammelt historische Daten, die man jederzeit bei neuen Fragestellungen auswerten kann
Fazit: “Würden wir es wieder tun?”
13
Ist ihre Domäne bereit für CQRS/Event Sourcing?
CQRS und Event Sourcing unter Strom
Lessons Learned mit Spring und Axon
@maverick_1601
https://github.com/maverick1601
https://bit.ly/2EDAagi
Frank Scheffler Matthias Grünewald
https://bit.ly/2J7wvwp
@mat_gruenewald
https://github.com/gruenewald
1 von 12

Recomendados

OOP 2021: CQRS und Event Sourcing unter Strom von
OOP 2021: CQRS und Event Sourcing unter StromOOP 2021: CQRS und Event Sourcing unter Strom
OOP 2021: CQRS und Event Sourcing unter StromFrank Scheffler
184 views12 Folien
Mieterstrom, IoT und Blockchain (DE) von
Mieterstrom, IoT und Blockchain (DE)Mieterstrom, IoT und Blockchain (DE)
Mieterstrom, IoT und Blockchain (DE)Next Big Thing AG
505 views12 Folien
Sicherheit im Smart Grid von
Sicherheit im Smart GridSicherheit im Smart Grid
Sicherheit im Smart GridFraunhofer AISEC
1.8K views41 Folien
OpenFridge @ Auftaktveranstaltung, IKT der Zukunft 2013 von
OpenFridge @ Auftaktveranstaltung, IKT der Zukunft 2013OpenFridge @ Auftaktveranstaltung, IKT der Zukunft 2013
OpenFridge @ Auftaktveranstaltung, IKT der Zukunft 2013Slobodanka Dana Kathrin Tomic
690 views9 Folien
Intelligente Messsysteme für die Energiewende von
Intelligente Messsysteme für die EnergiewendeIntelligente Messsysteme für die Energiewende
Intelligente Messsysteme für die EnergiewendeIsabell_Echemendia_Camejo
243 views30 Folien
Redispatch 2.0 - Anforderungen und Konzepte für die Energiewende von
Redispatch 2.0 - Anforderungen und Konzepte für die EnergiewendeRedispatch 2.0 - Anforderungen und Konzepte für die Energiewende
Redispatch 2.0 - Anforderungen und Konzepte für die EnergiewendeDell Technologies
14 views2 Folien

Más contenido relacionado

Destacado

ChatGPT and the Future of Work - Clark Boyd von
ChatGPT and the Future of Work - Clark Boyd ChatGPT and the Future of Work - Clark Boyd
ChatGPT and the Future of Work - Clark Boyd Clark Boyd
24.3K views69 Folien
Getting into the tech field. what next von
Getting into the tech field. what next Getting into the tech field. what next
Getting into the tech field. what next Tessa Mero
5.7K views22 Folien
Google's Just Not That Into You: Understanding Core Updates & Search Intent von
Google's Just Not That Into You: Understanding Core Updates & Search IntentGoogle's Just Not That Into You: Understanding Core Updates & Search Intent
Google's Just Not That Into You: Understanding Core Updates & Search IntentLily Ray
6.4K views99 Folien
How to have difficult conversations von
How to have difficult conversations How to have difficult conversations
How to have difficult conversations Rajiv Jayarajah, MAppComm, ACC
5K views19 Folien
Introduction to Data Science von
Introduction to Data ScienceIntroduction to Data Science
Introduction to Data ScienceChristy Abraham Joy
82.3K views51 Folien
Time Management & Productivity - Best Practices von
Time Management & Productivity -  Best PracticesTime Management & Productivity -  Best Practices
Time Management & Productivity - Best PracticesVit Horky
169.7K views42 Folien

Destacado(20)

ChatGPT and the Future of Work - Clark Boyd von Clark Boyd
ChatGPT and the Future of Work - Clark Boyd ChatGPT and the Future of Work - Clark Boyd
ChatGPT and the Future of Work - Clark Boyd
Clark Boyd24.3K views
Getting into the tech field. what next von Tessa Mero
Getting into the tech field. what next Getting into the tech field. what next
Getting into the tech field. what next
Tessa Mero5.7K views
Google's Just Not That Into You: Understanding Core Updates & Search Intent von Lily Ray
Google's Just Not That Into You: Understanding Core Updates & Search IntentGoogle's Just Not That Into You: Understanding Core Updates & Search Intent
Google's Just Not That Into You: Understanding Core Updates & Search Intent
Lily Ray6.4K views
Time Management & Productivity - Best Practices von Vit Horky
Time Management & Productivity -  Best PracticesTime Management & Productivity -  Best Practices
Time Management & Productivity - Best Practices
Vit Horky169.7K views
The six step guide to practical project management von MindGenius
The six step guide to practical project managementThe six step guide to practical project management
The six step guide to practical project management
MindGenius36.6K views
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright... von RachelPearson36
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...
RachelPearson3612.7K views
Unlocking the Power of ChatGPT and AI in Testing - A Real-World Look, present... von Applitools
Unlocking the Power of ChatGPT and AI in Testing - A Real-World Look, present...Unlocking the Power of ChatGPT and AI in Testing - A Real-World Look, present...
Unlocking the Power of ChatGPT and AI in Testing - A Real-World Look, present...
Applitools55.5K views
12 Ways to Increase Your Influence at Work von GetSmarter
12 Ways to Increase Your Influence at Work12 Ways to Increase Your Influence at Work
12 Ways to Increase Your Influence at Work
GetSmarter401.7K views
Ride the Storm: Navigating Through Unstable Periods / Katerina Rudko (Belka G... von DevGAMM Conference
Ride the Storm: Navigating Through Unstable Periods / Katerina Rudko (Belka G...Ride the Storm: Navigating Through Unstable Periods / Katerina Rudko (Belka G...
Ride the Storm: Navigating Through Unstable Periods / Katerina Rudko (Belka G...
DevGAMM Conference3.6K views
Barbie - Brand Strategy Presentation von Erica Santiago
Barbie - Brand Strategy PresentationBarbie - Brand Strategy Presentation
Barbie - Brand Strategy Presentation
Erica Santiago25.1K views
Good Stuff Happens in 1:1 Meetings: Why you need them and how to do them well von Saba Software
Good Stuff Happens in 1:1 Meetings: Why you need them and how to do them wellGood Stuff Happens in 1:1 Meetings: Why you need them and how to do them well
Good Stuff Happens in 1:1 Meetings: Why you need them and how to do them well
Saba Software25.2K views
Introduction to C Programming Language von Simplilearn
Introduction to C Programming LanguageIntroduction to C Programming Language
Introduction to C Programming Language
Simplilearn8.4K views
The Pixar Way: 37 Quotes on Developing and Maintaining a Creative Company (fr... von Palo Alto Software
The Pixar Way: 37 Quotes on Developing and Maintaining a Creative Company (fr...The Pixar Way: 37 Quotes on Developing and Maintaining a Creative Company (fr...
The Pixar Way: 37 Quotes on Developing and Maintaining a Creative Company (fr...
Palo Alto Software88.4K views
9 Tips for a Work-free Vacation von Weekdone.com
9 Tips for a Work-free Vacation9 Tips for a Work-free Vacation
9 Tips for a Work-free Vacation
Weekdone.com7.2K views
How to Map Your Future von SlideShop.com
How to Map Your FutureHow to Map Your Future
How to Map Your Future
SlideShop.com275.1K views

JCON 2020: CQRS und Event Sourcing unter Strom: Lessons Learned mit Spring und Axon

  • 1. 1 CQRS und Event Sourcing unter Strom Lessons Learned mit Spring und Axon @qimono on Pixabay @maverick_1601 Frank SchefflerMatthias Grünewald https://bit.ly/2J7wvwp
  • 2. 2 Syna Netzbetreiber für Strom- und Gasversorgung Fachdomäne Energiesektor Netzanschluss
  • 3. 3 Kunde Die schriftliche, komplizierte Beantragung eines Strom- / Gasanschlusses soll digital und einfach werden. Fachbereich Anträge von Netzanschlüssen sollen vollständige und plausible Angaben enthalten. Rückfragen sollen reduziert werden. Welche Probleme sollten gelöst werden?
  • 4. 4 Ausschnitt: Konfiguration eines Netzanschlusses 6000 Kombinationen Ziel: Richtiger Weg Kunden führen
  • 6. 6 Warum haben wir uns für CQRS und Event Sourcing entschieden? Skalierbare Infrastruktur zur Abfrage der Applikationsdaten (Firestore) vs. Zentrale Koordination ändernder Operationen (REST) Auf Basis historischer Daten Nutzerverhalten verstehen Konsistente Datenübermittlung an Drittsysteme, auch nachträglich
  • 7. 7 Schichtenarchitektur vs. CQRS & ES Presentation Domain Logic Data Access DB Queue REST Controller Services Repositories Interaction New/Updated State Messages Domain Logic Event Store Presentation Interaction Change Event(s) REST Controller Queue Input Message Output Message Event Handler Event Handler Read Model Current State (Event Sourced) Repositories C C E E E
  • 8. 9 Axon in Action Event Store Presentation Event Handler Read Model Command Gateway
  • 9. 10 Hexagonale Architektur (Ports & Adapters) Domain Web App Firestore REST Controller Firestore Projector Storage Bucket Pub/Sub Message Sink Storage Topic PDF Creator SAP SAP Client Analytics Analytics Data C C E E E E Domain Test(s) Adapter Test(s)
  • 10. 11 Fazit: “Was haben wir gelernt?” Hat uns überzeugt ● Intuitive Code Struktur (Commands, Aggregates, Events) ● Testing mit Axon (Domain und Adapter) ● Replay-Fähigkeit (z.B. Analytics) Hätten wir gerne vorher gewusst ● Umgang mit Konflikten, Retry und Caching ● Persistierung der Events (JSON) und Upcasting ● Parallelisierbare Eventverarbeitung Haben wir noch vor uns ● Feingranulare Events (besonders bei nicht-transaktionalen Aufrufen, z.B. REST) ● Aussteuerung und Visualisierung blockierender Events
  • 11. 12 Ja, … 1. … denn es ist ein anderes, aber sehr intuitives Programmiermodell 2. … man benötigt jedoch eine gewisse Einarbeitungszeit 3. … man sammelt historische Daten, die man jederzeit bei neuen Fragestellungen auswerten kann Fazit: “Würden wir es wieder tun?”
  • 12. 13 Ist ihre Domäne bereit für CQRS/Event Sourcing? CQRS und Event Sourcing unter Strom Lessons Learned mit Spring und Axon @maverick_1601 https://github.com/maverick1601 https://bit.ly/2EDAagi Frank Scheffler Matthias Grünewald https://bit.ly/2J7wvwp @mat_gruenewald https://github.com/gruenewald