diff --git a/docs/02-Common-Architecture-Concepts/02-learning-goals.adoc b/docs/02-Common-Architecture-Concepts/02-learning-goals.adoc index ce4af0a..b98f304 100644 --- a/docs/02-Common-Architecture-Concepts/02-learning-goals.adoc +++ b/docs/02-Common-Architecture-Concepts/02-learning-goals.adoc @@ -6,11 +6,15 @@ Softwarearchitekt:innen kennen Muster moderner Architekturen für verteilte Anwendungen (speziell Microservices, Self-contained Systems) und verstehen die Gründe, die zu diesen Lösungen führen. +* Monolith <>, <>, <>, <> +* Microsoervices <>,<> +* Self Contained Systems <>, <> + Sie verstehen die unterschiedlichen Technologien entkoppelter Kommunikation und des Datenaustauschs zwischen Services, zum Beispiel: -* Event Sourcing -* Messaging Middleware -* HTTP Feeds +* Event Sourcing <>, <>, <> +* Messaging Middleware <> +* HTTP feeds <> Softwarearchitekt:innen kennen die Auswirkungen einer Shared-Something/Nothing-Architektur, die insbesondere durch eine Skalierung über Container entsteht. @@ -19,8 +23,8 @@ Softwarearchitekt:innen kennen die Auswirkungen einer Shared-Something/Nothing-A Softwarearchitekt:innen verstehen, wie mehrere Services über unterschiedliche Wege zu einer Applikation integriert werden können, zum Beispiel durch Integration über: -* Backend (Message-Bus, Datenbank, etc.) -* Frontend (UI-Integration) +* Backend (message bus, database, etc.) <> +* Frontend (UI integration) <> Softwarearchitekt:innen kennen die Auswirkungen von Eventual Consistency auf die Datenintegrität und Datenkonsistenz. @@ -32,11 +36,15 @@ Softwarearchitekt:innen kennen die Auswirkungen von Eventual Consistency auf die Software architects are familiar with patterns of modern architectures for distributed applications (especially microservices, self-contained systems) and understand the reasons that lead to these solutions. +* Monolith <>, <>, <>, <> +* Microsoervices <>,<> +* Self Contained Systems <>, <> + They understand the different possibilities of decoupled communication and data exchange between services, for example: -* Event Sourcing -* Messaging Middleware -* HTTP feeds +* Event Sourcing <>, <>, <> +* Messaging Middleware <> +* HTTP feeds <> Software architects understand the implications of a shared-something/nothing architecture, particularly as a result of scaling via containers. @@ -45,8 +53,8 @@ Software architects understand the implications of a shared-something/nothing ar Software architects understand how multiple services can be integrated into an application through different approaches, such as integration via: -* Backend (message bus, database, etc.) -* Frontend (UI integration) +* Backend (message bus, database, etc.) <> +* Frontend (UI integration) <> Software architects understand the impact of eventual consistency on data integrity and consistency. // end::EN[] diff --git a/docs/02-Common-Architecture-Concepts/references.adoc b/docs/02-Common-Architecture-Concepts/references.adoc index 6383d4c..94f7cdb 100644 --- a/docs/02-Common-Architecture-Concepts/references.adoc +++ b/docs/02-Common-Architecture-Concepts/references.adoc @@ -1,30 +1,31 @@ === {references} -- Cornelia Davis: Cloud Native Patterns. Designing Change-tolerant Software. Manning, 2019 - -* Ansätze moderner Architekturen - -** Monolith -*** https://www.techtarget.com/whatis/definition/monolithic-architecture -*** https://microservices.io/patterns/monolithic.html -*** https://martinfowler.com/articles/break-monolith-into-microservices.html - -** Microservice -*** https://martinfowler.com/articles/microservices.html -*** https://microservices.io/patterns/microservices.html -*** https://www.martinfowler.com/bliki/MonolithFirst.html - -** Self Contained Systems -*** https://scs-architecture.org -*** https://www.infoq.com/articles/scs-microservices-done-right/ -*** https://roca-style.org - -** Möglichkeiten Kommunikation / Datenaustausch -*** https://landscape.cncf.io/card-mode?category=streaming-messaging&grouping=category -*** https://microservices.io/patterns/data/event-sourcing.html -*** https://microservices.io/patterns/communication-style/messaging.html -*** https://www.rssboard.org/rss-specification - -** Anwendungs-Integration -*** https://www.microservice-api-patterns.org/patterns/foundation/FrontendIntegration -*** https://www.microservice-api-patterns.org/patterns/foundation/BackendIntegration +- [[[davis,Davis 2019]]] Cornelia Davis: Cloud Native Patterns. Designing Change-tolerant Software. Manning, 2019 + +- [[[awati_wigmore,Awati, R. & Wigmore, I. (2022). Monolithic architecture]]] Awati, R. & Wigmore, I. (2022). Monolithic architecture. WhatIs.com. https://www.techtarget.com/whatis/definition/monolithic-architecture + +- [[[microservices_monolith,Monolithic architecture pattern. (o. D.). microservices.io]]] Monolithic architecture pattern. (o. D.). microservices.io. Abgerufen am 4. Oktober 2023, von https://microservices.io/patterns/monolithic.html + +- [[[fowler_monolith,Dehghani, Z. (o. D.). How to break a monolith into microservices]]] Dehghani, Z. (o. D.). How to break a monolith into microservices. martinfowler.com. Abgerufen am 4. Oktober 2023, von https://martinfowler.com/articles/break-monolith-into-microservices.html + +- [[[fowler_monolithfirst,Fowler, M. (o. D.). Bliki: MonolithFirst]]] Fowler, M. (o. D.). Bliki: MonolithFirst. martinfowler.com. Abgerufen am 4. Oktober 2023, von https://www.martinfowler.com/bliki/MonolithFirst.html + +- [[[fowler_microservices,Lewis, J. (o. D.). Microservices]]] Lewis, J. (o. D.). Microservices. martinfowler.com. Abgerufen am 4. Oktober 2023, von https://martinfowler.com/articles/microservices.html + +- [[[microservices_microservice,Microservice Architecture Pattern. (o. D.). microservices.io]]] Microservice Architecture Pattern. (o. D.). microservices.io. Abgerufen am 4. Oktober 2023, von https://microservices.io/patterns/microservices.html + +- [[[scs,SCS: Self-contained systems (o. D.)]]] SCS: Self-contained systems. (o. D.). Abgerufen am 4. Oktober 2023, von https://scs-architecture.org/ + +- [[[scs_wolff,Wolff, E. (2017, 3. Mai). Self Contained Systems (SCS): Microservices done right]]] Wolff, E. (2017, 3. Mai). Self Contained Systems (SCS): Microservices done right. InfoQ. Abgerufen am 4. Oktober 2023, von https://www.infoq.com/articles/scs-microservices-done-right/ + +- [[[microservices_event-sourcing,Event sourcing. (o. D.). microservices.io]]] Event sourcing. (o. D.). microservices.io. Abgerufen am 4. Oktober 2023, von https://microservices.io/patterns/data/event-sourcing.html + +- [[[cncf_landscape_streaming_messaging,Cloud Native landscape. (o. D.). Cloud Native Landscape]]] Cloud Native landscape. (o. D.). Cloud Native Landscape. Abgerufen am 4. Oktober 2023, von https://landscape.cncf.io/card-mode?category=streaming-messaging&grouping=category + +- [[[microservices_messaging,Messaging. (o. D.). microservices.io]]] Messaging. (o. D.). microservices.io. Abgerufen am 4. Oktober 2023, von https://microservices.io/patterns/communication-style/messaging.html + +- [[[rss,RSS 2.0 specification (Current). (o. D.)]]] RSS 2.0 specification (Current). (o. D.). Abgerufen am 4. Oktober 2023, von https://www.rssboard.org/rss-specification + +- [[[backend_integration,Backend integration. (o. D.)]]] Backend integration. (o. D.). Abgerufen am 4. Oktober 2023, von https://www.microservice-api-patterns.org/patterns/foundation/BackendIntegration + +- [[[frontend_integration,Frontend Integration. (o. D.)]]] Frontend Integration. (o. D.). Abgerufen am 4. Oktober 2023, von https://www.microservice-api-patterns.org/patterns/foundation/FrontendIntegration diff --git a/docs/03-Cloud-Native-Journey/02-learning-goals.adoc b/docs/03-Cloud-Native-Journey/02-learning-goals.adoc index 0fa08ff..13be1b5 100644 --- a/docs/03-Cloud-Native-Journey/02-learning-goals.adoc +++ b/docs/03-Cloud-Native-Journey/02-learning-goals.adoc @@ -11,6 +11,8 @@ Softwarearchitekt:innen verstehen den Nutzen und die Ziele des Cloud Native Konz * Lieferartefakte * Isolation der Applikation vom Hostsystem +Literatur: <> + [[LZ-3-2]] ==== LZ 3-2: Grundlegende Container Konzepte verstehen @@ -35,6 +37,8 @@ Softwarearchitekt:innen verstehen die Abstraktionskonzepte aktueller Container-M * Skalierung und Load Balancing * Placement +Literatur: <>, <> + Softwarearchitekt:innen kennen die Prinzipien eines Overlay-Networks (VLAN) für Container und Container-Manager und verstehen, wie verschiedene Services oder Systeme isoliert werden. Sie kennen Anforderungszenarien wie z. B. die Realisierung einer verteilten Firewall zur Isolation von: * Mehreren Mandanten @@ -67,6 +71,7 @@ Software architects understand the benefits and goals of the Cloud Native concep * Resource abstraction * Delivery artifacts +References: <> [[LG-3-2]] ==== LG 3-2: Understand basic container concepts @@ -92,8 +97,9 @@ Software architects understand the abstraction concepts of current container man * Scaling and load balancing * Placement -Software architects know the principles of an overlay network (VLAN) for containers and container managers and understand how different services or systems are isolated. They are familiar with requirement scenarios such as implementing a distributed firewall for isolating: +References: <>, <>, <> +Software architects know the principles of an overlay network (VLAN) for containers and container managers and understand how different services or systems are isolated. They are familiar with requirement scenarios such as implementing a distributed firewall for isolating: * Multiple tenants * Test systems in the context of CI/CD @@ -115,5 +121,3 @@ Software architects understand the advantages and disadvantages of a cloud-nativ They are familiar with various concepts for backing up and restoring persistent data in the cloud. // end::EN[] - - diff --git a/docs/03-Cloud-Native-Journey/references.adoc b/docs/03-Cloud-Native-Journey/references.adoc index 6d78bc9..e2018fa 100644 --- a/docs/03-Cloud-Native-Journey/references.adoc +++ b/docs/03-Cloud-Native-Journey/references.adoc @@ -1,7 +1,7 @@ === {references} -- Brendan Burns: Designing Distributed Systems. Patterns and Paradigms for Scaleable, Reliable Services. O'Reilly Media, 2018 +- [[[davis,Davis 2019]]] Cornelia Davis: Cloud Native Patterns. Designing Change-tolerant Software. Manning, 2019 -- Cornelia Davis: Cloud Native Patterns. Designing Change-tolerant Software. Manning, 2019 +- [[[burns,Burns 2018]]] Brendan Burns: Designing Distributed Systems. Patterns and Paradigms for Scaleable, Reliable Services. O'Reilly Media, 2018 -- Ibryam Bilgin, Roland Huss: Kubernetes Patterns. Reusable Elements for Designing Cloud Native Applications. O'Reilly Media, Second edition, 2023 +- [[[bilgin_huss,Bilgin, Huss 2023]]] Ibryam Bilgin, Roland Huss: Kubernetes Patterns. Reusable Elements for Designing Cloud Native Applications. O'Reilly Media, Second edition, 2023 diff --git a/docs/04-Patterns/02-learning-goals.adoc b/docs/04-Patterns/02-learning-goals.adoc index 810f9ef..d06fcac 100644 --- a/docs/04-Patterns/02-learning-goals.adoc +++ b/docs/04-Patterns/02-learning-goals.adoc @@ -12,6 +12,8 @@ Sie kennen verschiedene Container Application Design Muster, wie zum Beispiel: * Scatter & Gather * Work Queue +Literatur: <> + Softwarearchitekt:innen kennen Methoden, um technische von fachlichen Aufgaben durch getrennte Container zu realisieren und verstehen, wie Container-Manager über dieses Prinzip technische Aufgaben übernimmt, insbesondere: * Konfiguration und Initialisierung von Anwendungen @@ -31,6 +33,8 @@ Softwarearchitekt:innen kennen u. a. folgende Resilienz-Muster: * Conditional Rate Limits * Traffic Shifting +Literatur: <> + Sie kennen das Konzept von Chaos Engineering und dessen Methoden, die Systemresilienz durch gezieltes Einbringen von Störungen zu testen. // end::DE[] @@ -47,6 +51,8 @@ They are aware of various container application design patterns, such as: * Scatter & Gather * Work Queue +References: <> + Software architects are familiar with methods for separating technical and business tasks through separate containers and understand how container managers handle technical tasks through this principle, particularly: * Configuration and initialization of applications @@ -66,8 +72,8 @@ Software architects are familiar with the following resilience patterns, among o * Conditional Rate Limits * Traffic Shifting +References: <> + They are familiar with the concept of chaos engineering and its methods to test system resilience by deliberately introducing disruptions. // end::EN[] - - diff --git a/docs/04-Patterns/references.adoc b/docs/04-Patterns/references.adoc index 103d8b9..e2018fa 100644 --- a/docs/04-Patterns/references.adoc +++ b/docs/04-Patterns/references.adoc @@ -1,7 +1,7 @@ === {references} -- Brendan Burns: Designing Distributed Systems. Patterns and Paradigms for Scaleable, Reliable Services. O'Reilly Media, 2018 +- [[[davis,Davis 2019]]] Cornelia Davis: Cloud Native Patterns. Designing Change-tolerant Software. Manning, 2019 -- Ibryam Bilgin, Roland Huss: Kubernetes Patterns. Reusable Elements for Designing Cloud Native Applications. O'Reilly Media, Second edition, 2023 +- [[[burns,Burns 2018]]] Brendan Burns: Designing Distributed Systems. Patterns and Paradigms for Scaleable, Reliable Services. O'Reilly Media, 2018 -- Cornelia Davis: Cloud Native Patterns. Designing Change-tolerant Software. Manning, 2019 +- [[[bilgin_huss,Bilgin, Huss 2023]]] Ibryam Bilgin, Roland Huss: Kubernetes Patterns. Reusable Elements for Designing Cloud Native Applications. O'Reilly Media, Second edition, 2023 diff --git a/docs/05-Development-and-CICD/02-learning-goals.adoc b/docs/05-Development-and-CICD/02-learning-goals.adoc index 57995c6..931dfc4 100644 --- a/docs/05-Development-and-CICD/02-learning-goals.adoc +++ b/docs/05-Development-and-CICD/02-learning-goals.adoc @@ -20,11 +20,15 @@ Sie kennen Möglichkeiten, um in einer Cloud-Umgebung Deployments und ein Applic ** Canary Deployment ** Blue/Green Deployment +Literatur: <>, <> + Sie kennen Komponenten und Vorgehensmodelle, um einen schnellen Test- und Deployment-Prozess zu realisieren. Insbesondere Konzepte zum Dev/Test/Prod Cluster wie: * Verantwortlichkeiten und Zugriffskontrolle * Good Practices zur Komponentengruppierung +Literatur : <> + [[LZ-5-2]] ==== LZ 5-2: Wege der Beobachtbarkeit von verteilten Applikationen kennen @@ -36,6 +40,8 @@ Sie kennen die besonderen Rahmenbedingungen verteilter Anwendung und den Einflus * Monitoring/Metriken und Alerting * Distributed Tracing +Literatur: <> + Sie kennen Wege und Verantwortlichkeiten zur Erstellung möglichst fehlervorhersagenden Time Series Queries für Alerts. // end::DE[] @@ -58,11 +64,15 @@ They understand the possibilities of implementing deployments and application li ** Canary deployment ** Blue/green deployment +References: <>, <> + They are familiar with components and models for achieving a fast testing and deployment process, particularly concepts related to dev/test/prod clusters, such as: * Responsibilities and access control * Good practices for component grouping +Literatur : <> + [[LG-5-2]] ==== LG 5-2: Understanding approaches for observability of distributed applications @@ -74,8 +84,7 @@ They understand the unique conditions of distributed applications and their impa * Monitoring/metrics and alerting * Distributed tracing -They are familiar with approaches and responsibilities for creating predictive time series queries for alerts. +Literatur : <> +They are familiar with approaches and responsibilities for creating predictive time series queries for alerts. // end::EN[] - - diff --git a/docs/05-Development-and-CICD/references.adoc b/docs/05-Development-and-CICD/references.adoc index 972bab5..a9e2627 100644 --- a/docs/05-Development-and-CICD/references.adoc +++ b/docs/05-Development-and-CICD/references.adoc @@ -1,4 +1,7 @@ === {references} +- [[[davis,Davis 2019]]] Cornelia Davis: Cloud Native Patterns. Designing Change-tolerant Software. Manning, 2019 +- [[[bilgin_huss,Bilgin, Huss 2023]]] Ibryam Bilgin, Roland Huss: Kubernetes Patterns. Reusable Elements for Designing Cloud Native Applications. O'Reilly Media, Second edition, 2023 +- [[[richardson,Richardson 2018]]] Chris Richardson: Microservice Patterns. Manning, 2018 \ No newline at end of file