Flexible Anwendungsarchitektur mit der Clean und Hexagonal Architecture

Online-Workshop, 28. Juni 2023, ca. 9–16 Uhr

Neu ist immer besser! Zugegeben, nicht jeder ist dieser Meinung. In meiner Ansicht baut neues oft auf alten auf. Durch die Aufnahme neuer Ideen sowie der Beseitigung identifizierter Schwächen, stellt neues oft eine Verbesserung dar. Setzen wir dies in den Kontext von Architekturmustern, ist eine Entwicklung der Schichtenarchitektur als De-Facto Standard zu Ports & Adapters basierenden Architekturmustern, wie z.B. der Clean oder Hexagonal Architecture, als neuer De-Facto-Standard wahrzunehmen.

Geht es allerdings darum, diese Architekturmuster im eigenen Projekt-Kontext anzuwenden, ist der Wissensaufbau zeitgleich mit der Entwicklung von neuen Features eine hohe Hürde. Die Hexagonal und Clean Architecture stehen für Qualität und beinhalten mehr Designregeln und -prinzipen, als die Schichtenarchitektur. Dennoch kann schnell ein Verständnis für diese fortgeschrittene Architekturmuster aufgebaut und im Entwicklungsalltag angewendet werden.

Im Workshop „Flexible Anwendungsarchitektur“ beschreibe ich die grundlegenden Konzepte des Clean Architecture Pattern anhand konkreter Anwendungsfälle. Die Theorie wird mit Code-Beispielen und Code-Übungen in Java vertieft. Im Fokus des Architekturentwurfs steht die Wartbarkeit und die Erweiterbarkeit der Softwarearchitektur. Darauf aufbauend wird die Philosophie der Evolutionären Architektur diskutiert und technische Lösungsstrategie erläutert. Ich möchte aufzeigen, dass die Lernkurve genommen werden kann und zur weiteren Vertiefung im Selbst-Studium befähigen. Hierfür erhältst du alle Trainingsmaterialien und Zugang zu einer Demo-Anwendung.

Vorkenntnisse

Teilnehmer:innen sollten die folgenden Kenntnisse und Erfahrung mitbringen:

  • Mehr als 12 Monate praktische Erfahrung in arbeitsteiliger Softwareentwicklung im Team
  • Kenntnisse und praktische Erfahrung in mindestens einer höheren Programmiersprache (bevorzugt Java, Kotlin, C#, Python)
  • Vertraut mit Schichtenarchitektur, SOLID Prinzipien, Entwurfsmuster, Dependency Injection sowie Konzepte der Modularisierung (Module, Pakete, Namensräume)
  • Vertraut mit der Erstellung fachlicher Objektmodelle in Java oder in einer vergleichbaren Programmiersprache

Lernziele

  • Die Probleme der Schichtenarchitektur erkennen und ihnen mittels Ports & Adapters sowie fachlicher Modularisierung begegnen können
  • Die Clean und Hexagonal Architecture implementieren sowie diese Architekturmuster unterscheiden können
  • Unterschiedliche Modularisierungsvarianten und Mappingsstrategien für die Clean und Hexagonal Architecture anwenden können
  • Die Möglichkeit, Ihre Architektur mittels Architekturtest kontinuierlich zu testen und das Mindset der Evolutionären Architektur anzuwenden
  • Der praktische Teil in Java wird unterstützt durch eine Demo-Anwendung inklusive Programmierübungen.

Agenda

Softwarearchitektur als Struktur und Methodik
  • Funktionale Systemdekomposition und Modularisierung
  • Architekturmuster, Architekturprinzipien, Entwurfsmuster und Mustersprache
  • Time-To-Adaption und strukturelle Qualität von Softwarearchitektur
Ports & Adapters Architekturmuster
  • Die Schwächen der Schichtenarchitektur
  • Von der Schichtenarchitektur zu Ports & Adapters Architekturmuster
Eine isolierte Domäne erstellen
  • Implementierung von Geschäftsobjekten und Fachwerten nach dem Prinzip des Rich Domain Model
  • Domänen-bezogene Datenvalidierung implementieren
  • Unterschiedliche Aufgaben auf die Klassenstereotypen Service, Root Entity, Entity und Value Object verteilen
  • Code-Übung: Domänenmodell
Hexagonal Architecture
  • Die Domäne in der Hexagonal Architecture
  • Der Application Ring der Hexagonal Architecture
  • Der Framework Ring der Hexagonal Architecture
  • Der Klassenstereotyp ApplicationService, Repository, Controller und ServiceClient
  • Call-Flow durch die Hexagonal Architecture mit Code-Demo
Clean Architecture
  • Die Domäne in der Clean Architecture
  • Der Use-Case-Ring der Clean Architecture
  • Prinzipien des Use-Case-Schnitt
  • Der Famework Ring der Clean Architecture
  • Call-Flow durch die Clean Architecture
  • Code-Übung: Use-Case-Ring und Framework-Ring
Mapping-Strategien für Ports & Adapters basierende Architekturmuster
  • One-Way, Two-Way und Full Mapping Strategie
  • Mappings mit Third-Party-Bibliotheken vereinfachen
  • Mapper, Konverter und Factories
  • Code-Übung: Two-Way-Mapping-Strategie
Domain-Driven Modularization
  • Modularisierung mit Domänenmodulen anhand Root Entities
  • Strukturierung von Domänenmodulen
  • Entwurfsmuster für Beziehungen zwischen den Domänenmodulen
  • Coding-Übung: Abhängigkeiten zwischen Domänenmodulen
Evolutionäre Architektur
  • Motivation für Architektur-Disziplin anhand der Broken Window Theory
  • Das Mindset der Evolutionären Architektur
  • Fitness Functions für die Clean und Hexagonal Architecture
  • Coding-Übung: Clean Architecture Fitness Functions mit ArchUnit

 

Technische Anforderungen

  • Jede Teilnehmer:in trägt dafür Sorge, dass eine Demo Anwendung von GitHub geklont werden kann.
  • Jede Teilnehmer:in trägt dafür Sorge, dass eine lauffähige Java Entwicklungsumgebung mit der IDE seiner Wahl (empfohlen: IntelliJ) mit dem Build-Tool Maven für die Durchführung der Programmierübungen bereit steht.
  • Alternative für C# und Kotlin trägt die Teilnehmer:in dafür Sorge, dass ein Projekt erstellt und ausgeführt werden kann.
  • Der Workshop wird über Zoom durchgeführt.

Speaker

 

Matthias Eschhold
Matthias Eschhold
Mein Ziel ist es Softwarearchitektur agil und modern zu leben. Als Domain-Driven Design Enthusiast und Lead Architekt gestaltet mein Team und ich die Domäne Elektromobilität bei der EnBW. Am stärksten treiben mich die Entwicklung von Domänenmodelle, die Erstellung strategischer Architekturen, Team Schnitte sowie sozio-technische Architekturen. Dem Thema Architecture Enabling habe ich mich persönlichen verschrieben und sehe dies als den modernen Führungsansatz für Architektur. Als Trainer für Softwarearchitektur und Domain-Driven Design sowie als Speaker auf Konferenzen, teile ich meine Erfahrungen und Wissen praxisnah und anwendbar.

betterCode-Newsletter

Du möchtest über die betterCode() und weitere unserer betterCode()-Events auf dem Laufenden gehalten werden?

 

Anmelden