Softwarearchitektur – Wikipedia

Eine Softwarearchitektur ist einer der Architekturtypen in der Informatik und beschreibt die grundlegenden Komponenten und deren Zusammenspiel innerhalb eines Softwaresystems. Als spezialisierte Tätigkeit hat sich der Softwarearchitekt herausentwickelt, der für das High Level Design und die Planung neuer Softwareprodukte verantwortlich ist.

Eine Definition von Helmut Balzert beschreibt den Begriff als „eine strukturierte oder hierarchische Anordnung der Systemkomponenten sowie Beschreibung ihrer Beziehungen“.[1] Die Architekturkomponenten bilden eine Zerlegung des Gesamtsystems, was bedeutet, dass jedes Softwareelement genau einer Architekturkomponente zugeordnet ist.

Paul Clements beschreibt Softwarearchitektur als „Strukturen eines Softwaresystems: Softwareteile, die Beziehungen zwischen diesen und die Eigenschaften der Softwareteile und ihrer Beziehungen“.[2]

Insgesamt gibt es eine Reihe von verschiedenen Definitionen für diesen Begriff.[3]

Die Softwarearchitektur ist Teil des Softwareentwurfs (siehe SWEBOK), innerhalb dessen sie als Grobgliederung der Komponenten entsteht. Während der Softwareentwurf sich auch auf lokale Aspekte innerhalb des architektonischen Rahmens der Software bezieht und deshalb sehr detailliert sein kann, ist die Softwarearchitektur eine globale Eigenschaft des Gesamtsystems.

Einordnung und Abgrenzung

[Bearbeiten | Quelltext bearbeiten]

Im Rahmen der Softwareentwicklung repräsentiert die Softwarearchitektur die früheste Softwaredesign-Entscheidung (Architekturentwurf). Sie wird wesentlich durch Softwarequalitätskriterien, also nicht-funktionale Eigenschaften wie Modifizierbarkeit, Wartbarkeit, Sicherheit oder Performance bestimmt (siehe beispielsweise FURPS). Eine einmal eingerichtete Softwarearchitektur ist später nur mit hohem Aufwand abänderbar. Die Entscheidung über ihr Design ist somit einer der kritischsten und wichtigsten Punkte im Entwicklungsprozess einer Software.

Eine Softwarearchitektur ist in ihrer wirtschaftswissenschaftlichen Perspektive sehr stark von umgebenden Aspekten abhängig. Deswegen benötigt eine Softwarearchitektur, um erfolgreich funktionieren zu können, eine geeignete Abstimmung mit den wichtigsten übrigen Faktoren des Softwareprojekts. Für Benutzer und Entwickler des Softwareprojekts ermöglicht eine gut konstruierte Softwarearchitektur ein grundlegendes Verständnis des Systems. Wichtige Faktoren, die auf die Eignung der Softwarearchitektur Einfluss nehmen, sind Projektplanung, Risikoanalyse, Organisation, Entwicklungsprozess, Arbeitsabläufe, Hardware, Qualitätssicherung und Anforderungen.

Diagramm der Wikimedia-Server-Architektur

Eine Architekturbeschreibung umfasst etwa im Falle einer Web-Anwendung den Aufbau des Systems aus Datenbanken, Web-/Application-Servern, E-Mail- und Cachesystemen – siehe etwa Wikipedia selbst.

Anfänge (1960–1990)

[Bearbeiten | Quelltext bearbeiten]

Die Anfänge der Beschreibung und Nutzung einer expliziten Softwarearchitektur reichen zurück bis in die 1960er-Jahre, als die ersten größeren Softwaresysteme entstanden.[4] Die Komplexität der Systeme (z. B. OS/360) machte es notwendig, die Implementierungsaufgaben auf verschiedene Teams aufzuteilen und Schnittstellen zu definieren. Die erste Erwähnung des Begriffs „Softwarearchitektur“ findet sich im Tagungsband einer von der NATO finanzierten Konferenz über Softwaretechnik im Jahre 1969 in Rom.[5] Besucher dieser Konferenz waren zahlreiche Informatikpioniere, wie z. B. Tony Hoare, Edsger W. Dijkstra, Alan Perlis, Per Brinch Hansen, Friedrich L. Bauer, und Niklaus Wirth.

In den 1970er und 1980er Jahren wurde das Wort „Architektur“ im IT-Bereich häufig im Zusammenhang mit Systemarchitekturen (also physischen Computersystemstrukturen) verwendet oder bezog sich speziell auf Prozessorfamilien.[6] 1972 veröffentlichte David Parnas einen einflussreichen Artikel über Kriterien für die Moduldekomposition von Softwaresystemen.[7] Obwohl er dabei nicht den Begriff „Softwarearchitektur“ verwendete, nahm er doch einige der späteren Konzepte und Ideen für Softwarearchitektur vorweg.[6] 1975 erschien das Buch The Mythical Man Month von Frederick P. Brooks, in dem Schlüsselkonzepte zum Entwurf und der Organisation von Softwaresystemen diskutiert wurden.[4] Weitere Artikel von Parnas und Brooks in den 1980er Jahren vertieften diese Ideen und Konzepte.

Etablierung (1990–2000)

[Bearbeiten | Quelltext bearbeiten]

Softwarearchitektur wurde erst in den 1990er Jahren ein unabhängiges Teilgebiet der Softwaretechnik. 1992 veröffentlichten Dewayne Perry und Alexander Wolf einen grundlegenden Artikel mit dem Titel Foundations for the Study of Software Architecture.[8] Darin führten sie die Formel „Elemente + Form + Begründung = Softwarearchitektur“ ein. Viele Forscher interpretierten „Elemente“ als Softwarekomponenten und -konnektoren.[6] Daraufhin entstanden an verschiedenen Universitäten eine Reihe von Architekturbeschreibungssprachen (C2, Rapide, Darwin, Wright, ACME, Unicon), die allerdings kaum industriell eingesetzt wurden.[6]

Ab 1995 gewann die Softwarearchitektur sowohl im industriellen als auch im akademischen Umfeld zunehmend an Bedeutung. Das Software Engineering Institute (SEI) in Pittsburgh veröffentlichte die Software Architecture Analysis Method (SAAM).[9] Das Konzept der Architektursichten spiegelte sich in verschiedenen Ansätzen wie Rationals „4+1 views[10] oder Siemens „Four views“[11] wider. 1996 erschien das Buch Pattern-oriented Software Architecture, welches das Konzept der Entwurfsmuster auf Softwarearchitekturen übertrug.[12] Siemens, Nokia, Philips, Nortel, Lockheed Martin, IBM und andere größere Softwarefirmen nutzten Softwarearchitektur zur besseren Wiederverwendbarkeit von Software und entwarfen Softwareproduktlinien.[6] 1999 fand in den USA die erste internationale Konferenz (WICSA 1) speziell zum Thema Softwarearchitektur statt.[13]

Aktuell (2000–heute)

[Bearbeiten | Quelltext bearbeiten]

Im Jahr 2000 erschien die IEEE 1471:2000 Norm Recommended Practice for Architectural Description of Software-Intensive Systems zur Architekturbeschreibung von Softwaresystemen. Im gleichen Jahr übernahm mit Bill Gates eine der prominentesten Personen aus dem IT-Bereich den Titel Chief Software Architect bei Microsoft.[14] Das SEI arbeitete die szenariobasierte Architekturbewertungsmethode Architecture Trade-off Analysis Method (ATAM) aus, die im Folgenden in zahlreichen Industrieprojekten Anwendung fand.[15] Die Unified Modeling Language (UML) eignet sich ab Version 2.0 aus dem Jahr 2003 auch zur Dokumentation von Softwarearchitekturen. 2003 erschien das mittlerweile meistzitierte Buch zur Softwarearchitektur (Software Architecture in Practice) und hob die Bedeutung von Qualitätsattributen für den Entwurf und die Bewertung von Softwarearchitekturen hervor.[16]

In Deutschland werden mit dem International Software Architect Qualification Board (iSAQB),[17] ein Zusammenschluss deutscher IT Firmen, seit 2003 Zertifikate für Softwarearchitekten vergeben. Bis 2013 wurden so mehr als 3000 Softwarearchitekten nach CPSA-F (Foundation Level) zertifiziert.[18] 2004 gründete sich ein Arbeitskreis der Gesellschaft für Informatik zum Thema Softwarearchitektur und veröffentlichte 2006 das Handbuch der Software-Architektur.[19] 2006 entstand aus dem temporären Arbeitskreis eine permanente GI-Fachgruppe.[20]

Aktuelle Praxisthemen sind z. B. Softwarearchitekturen für Cloud Computing, Mehrkernprozessoren und mobile Endgeräte, sowie Serviceorientierte Architekturen. Aktuelle Forschungsthemen im Bereich Softwarearchitektur sind z. B. Wissensmanagement für Softwarearchitekturen, modellbasierte Analyseverfahren sowie Softwareproduktlinien.

In agilen Softwareentwicklungsprojekten wird zunehmend auf evolutionäre Softwarearchitektur und emergentes Design im Gegensatz zu vorher festgelegter Architektur (engl.: „Big Design Up Front“)[21] gesetzt. Dabei soll durch Techniken wie Behavior Driven Development, Testgetriebene Entwicklung und vor allem Refactoring sichergestellt werden, dass das technische Design und die Architektur im Laufe eines Softwareentwicklungsprojektes ständig an die Anforderungen angepasst werden.[22]

Die Beschreibung einer Softwarearchitektur enthält Informationen über die Struktur („Komponentisierung“) eines Software-Systems, aber auch Informationen über die Kommunikation zwischen Komponenten, sowie deren Abbildung auf Hardware- oder Software-Ressourcen (Verteilung und Deployment).

Dabei kann eine Softwarearchitektur unterschiedliche Ausprägungen haben:

  • So kann in einer Funktionsarchitektur (oder auch fachliche Architektur) die Gliederung des Systems in Funktionen oder Features dargestellt werden.
  • In der Komponentenarchitektur wird der Grobentwurf des Systems in einzelne Komponenten festgehalten.
  • Dieser Grobentwurf lässt sich im Feinentwurf feingranularer darstellen. Hierbei handelt es sich beispielsweise um Klassenhierarchien, Modularchitekturen oder programmiersprachenspezifischen Quelltext. Die Übergänge zwischen Feinentwürfen sind teilweise fließend.

Festzuhalten ist, dass es nicht die eine Softwarearchitektur eines Systems gibt. Es müssen je nach Fragestellung und Interessenspunkt unterschiedliche Sichten hinzugezogen werden. Ein Beispiel hierfür ist das 4+1 Sichtenmodell.

Softwarearchitekturbeschreibungen können über den gesamten Lebenszyklus eines Software-Systems genutzt werden. Dazu gehören neben der Entwicklung insbesondere auch Software-Evolution, Software-Installation und Software-Betrieb. Ebenso profitieren neben technischen Tätigkeiten auch Projektmanagement-Tätigkeiten, wie Kostenschätzung, Meilensteinplanung, Planung projektübergreifender Software-Wiederverwendung und die Organisation verteilter Software-Entwicklung von einer guten Architekturbeschreibung.

Verschiedene textuelle oder graphische Notationen werden zur Beschreibung von Softwarearchitekturen eingesetzt. Der Wert von rein grafischen Darstellungen von Softwarearchitekturen ist ebenso umstritten wie der Wert von rein textuellen Darstellungen. Bekannte Beispiele sind:[23]

Der Entwurf einer Softwarearchitektur ist der Erstellungsprozess einer Grobstruktur eines Softwaresystems. Dabei dienen funktionale und nichtfunktionale Anforderungen sowie technische und organisatorische Einflussfaktoren als Eingabe.[24] Der Entwurfsprozess läuft meist iterativ und inkrementell ab.[25] Das Ergebnis des Softwarearchitekturentwurfs ist eine Softwarearchitekturbeschreibung, die die Grundlage für den Feinentwurf bildet.[26]

Softwarearchitekten folgen einer Reihe fundamentaler Entwurfsprinzipien.[27] Mit dem Prinzip der gezielten Abstraktion von Informationen machen sie die Komplexität eines Systems beherrschbar.[28] Das Prinzip der Trennung von Zuständigkeiten (engl. separation of concerns) sorgt dafür, dass jede Komponente einer Architektur nur für eine einzige Aufgabe zuständig ist.[29] Das Innenleben von Komponenten wird durch Schnittstellen verkapselt, was auf das Prinzip des Verbergens von Informationen (engl. information hiding) zurückgeht.[7] Das System wird idealerweise in eine Menge in sich geschlossener, lose gekoppelter Komponenten mit hoher Kohäsion zerlegt (Prinzip der Modularität, siehe auch Packaging-Prinzipien), wodurch es leichter verständlich und anpassbar wird.[30][31] Eine Softwarearchitektur ist zudem häufig hierarchisch aufgebaut.[32] Das Prinzip der konzeptionellen Integrität zielt auf eine durchgängige Anwendung von Entwurfsentscheidungen ab.[33]

Softwarearchitekten bedienen sich beim Entwurf oft bei bewährten Lösungen, die als sogenannte Architekturmuster dokumentiert sind.[34] Diese bieten Vorlagen für die grundlegende Organisation und Interaktion von Softwarekomponenten. Beispiele für Architekturmuster sind Client-Server (z. B. Grundlage für HTTP) oder Schichtenarchitektur (z. B. beim OSI-Modell). Einige Architekturmuster können mit Hilfe vorgefertigter Infrastruktursoftware umgesetzt werden. Beispielsweise kann das Peer-to-Peer Architekturmuster mit einer Referenzbibliothek wie JXTA implementiert werden.

Qualitätsanforderungen (z. B. für Performanz, Wartbarkeit, Zuverlässigkeit und Sicherheit) sind ein wesentlicher Einflussfaktor für den Entwurf einer Softwarearchitektur, da sich funktionale Anforderungen auch mit unstrukturierter Software realisieren lassen.[35] Oftmals ist es die Aufgabe des Softwarearchitekten die technische Machbarkeit sowie die Kosten für nichtfunktionale Anforderungen beim Architekturentwurf zu klären.[36] Dazu können Benutzungsszenarien entworfen werden, ähnliche Systeme untersucht werden und experimentelle Prototypen erstellt werden. Zur Umsetzung von Qualitätsanforderungen wurden eine Reihe von Architekturtaktiken dokumentiert, die als Heuristik den Entwurfsprozess leiten können.[37]

Die wichtigsten Ziele der Softwarearchitekturbewertung sind die Identifikation von potenziellen Risiken, die Beurteilung der Realisierung von Qualitätsanforderungen durch die Architektur und die Identifikation von Möglichkeiten zur Wiederverwendung von Softwarekomponenten und anderen Artefakten.[38]

Ein wichtiges Qualitätsmerkmal von Softwarearchitekturen ist ihre Stetigkeit in Bezug auf Änderungen an den durch die Software zu lösenden Problemen. Kleine Änderungen der Problemstellung sollen nur zu kleinen Änderungen in der Softwarearchitektur führen. Das zentrale Qualitätsmerkmal für die Arbeit eines Softwarearchitekten aus wirtschaftlicher Sicht ist deshalb, ob er eine Softwarearchitektur definieren kann, die bei kleinen Änderungen in der Problemstellung nicht oder nur wenig geändert werden muss. In der Agilen Softwareentwicklung spricht man in diesem Zusammenhang von Design for Change – eine Softwarearchitektur die offen gegenüber jedweden Änderungen der Problemstellung ist. Diese zu erreichen bedient man sich des emergenten Designs – eine sukzessive wachsende Softwarearchitektur die genau dort flexibel ist, wo sich die Anforderungen oft ändern.

Zur Bewertung von Softwarearchitekturen existieren verschiedene Methoden, die sich in Zielen, Einsatzkontexten, Kosten und Nutzen zum Teil erheblich unterscheiden:[39]

  • Informelle Präsentation
  • Ausfüllen von vorgefertigten Fragebögen und Checklisten
  • Architektursichtungen (engl. Walkthroughs)
  • Szenariobasierte Verfahren
  • Simulation formaler Architekturmodelle
  • Bau und Analyse von Prototypen
  • Erhebung und Überprüfung von Architekturmetriken und -kennzahlen
  • Architekturkonsistenzprüfung mittels statischer Codeanalyse

Abwägungen bei Entwicklung und Aufbau einer Softwarearchitektur

[Bearbeiten | Quelltext bearbeiten]

Bei der Entwicklung und dem Aufbau einer Softwarearchitektur in einem Unternehmen sind im Allgemeinen unter anderem folgende Abwägungen durchzuführen:

Form Funktion
Interne Anforderungen Externe Anforderungen
Strenge Kontrolle Flexible Änderungen
Geld- und Zeitkosten Zusätzliche Funktionen
Komplexität Verständlichkeit
Neue Technologien Bewährte Technologien
Top-Down-Planung Bottom-Up-Planung
Fortlaufende Verbesserung Stabilität
Knappe Integration Wenige Interfaces

Dokumentation von Architekturentscheidungen

[Bearbeiten | Quelltext bearbeiten]

Es gibt viele Vorlagen und Werkzeuge um Architekturentscheidungen festzuhalten. In der agilen Softwareentwicklung werden diese üblicherweise nach M. Nygard Architecture Decision Records (ADRs) genannt.[40][41] Ähnlich wie bei Anwendungsfällen gibt es auch dafür Notationen wie beispielsweise die Y Notation nach G. Fairbanks[42]: „Im Kontext von <Anwendungsfall bzw. User Story>, betreffend <Betreff> haben wir uns wegen <Gründe> für <Option> und gegen <Weitere Optionen> entschieden, um <Qualitative Aspekte oder gewünschte Auswirkungen> zu erreichen, während wir <Nachteile oder ungewünschte Auswirkungen> akzeptierten.“

Zunehmend werden auch neue Modelle zur Dokumentation wie der Business Model Canvas (BMC) eingesetzt, mit dem Informationen auf das Wesentliche reduziert werden.[43]

Wichtige Konferenzen zu Software-Architektur sind:

Deutsch
  • M. Gharbi, A. Koschel, A. Rausch, G. Starke: Basiswissen für Softwarearchitekten. dpunkt Verlag, Heidelberg 2020, ISBN 978-3-86490-781-4.
  • Ralf Reussner, Wilhelm Hasselbring: Handbuch der Software-Architektur. 2. Auflage. dpunkt Verlag, Heidelberg 2008, ISBN 978-3-89864-559-1.
  • Johannes Siedersleben: Moderne Software-Architektur. dpunkt Verlag, Heidelberg 2004, ISBN 3-89864-292-5.
  • Gernot Starke: Effektive Software-Architekturen: Ein praktischer Leitfaden. 5. Auflage. Carl-Hanser-Verlag, München 2010, ISBN 978-3-446-41215-6.
  • Gernot Starke, Peter Hruschka: Software-Architektur kompakt. 2. Auflage. Springer-Verlag, 2011, ISBN 978-3-8274-2834-9.
  • Oliver Vogel, Ingo Arnold, Arif Chughtai, Markus Völter: Software-Architektur. Grundlagen – Konzepte – Praxis. Spektrum Akademischer Verlag, Heidelberg 2005, ISBN 3-8274-1534-9.
  • Joachim Goll: Architektur- und Entwurfsmuster der Softwaretechnik. Springer-Verlag, 2014, ISBN 978-3-658-05531-8.
Englisch
  • Len Bass, Paul Clements, Rick Kazman: Software Architecture in Practice. Addison-Wesley Professional, 2003, ISBN 0-321-15495-9.
  • M. Gharbi, A. Koschel, A. Rausch: Software Architecture Fundamentals: A Study Guide for the Certified Professional for Software Architecture® – Foundation Level – iSAQB compliant, dpunkt Verlag, Heidelberg 2021 ISBN 978-3-86490-625-1
  • Richard N. Taylor, Nenad Medvidović, Eric M. Dashofy: Software architecture. foundations, theory, and practice Wiley, 2009, ISBN 978-0-470-16774-8.
  • Mark Richards, Neal Ford: Fundamentals of Software Architecture: An Engineering Approach. O’Reilly, 2021, ISBN 978-1-4920-4345-4.
  • Ian Gorton: Essential Software Architecture. Springer-Verlag, 2014, ISBN 978-3-642-43531-7.
  • Carola Lilienthal: Sustainable Software Architecture. Dpunkt, 2019, ISBN 978-3-86490-673-2.

Einzelnachweise

[Bearbeiten | Quelltext bearbeiten]
  1. Helmut Balzert: Lehrbuch der Softwaretechnik. Bd. 2: Entwurf, Implementierung, Installation und Betrieb. Spektrum Akademischer Verlag, 2011, ISBN 978-3-8274-1706-0, S. 580.
  2. Paul Clements, Felix Bachmann, Len Bass, David Garlan, James Ivers, Reed Little, Paulo Merson, Robert Nord, Judith Stafford: Documenting Software Architectures: Views and Beyond. 2. Auflage. Addison-Wesley, Boston 2010, ISBN 978-0-321-55268-6.
  3. Software Engineering Institute an der Carnegie Mellon University: What is your definition of software architecture?, 2017, 01.22.17, abgerufen am 25. August 2021.
  4. a b Frederick P. Brooks: The mythical man-month: essays on software engineering. Addison-Wesley, Reading (Mass.) 1995, ISBN 0-201-83595-9.
  5. B. Randell, J. N. Buxton (Hrsg.): Software Engineering Techniques. Report of a Conference Sponsored by the NATO Science Committee. Scientific Affairs Division, NATO, 1970, S. 12.
  6. a b c d e P. Kruchten, H. Obbink, J. Stafford: The Past, Present, and Future for Software Architecture. In: IEEE Software. Vol. 23, Nr. 2, 2006, ISSN 0740-7459, S. 22–30, doi:10.1109/MS.2006.59.
  7. a b D. L. Parnas: On the criteria to be used in decomposing systems into modules. In: Communications of the ACM. Vol. 15, Nr. 12, 1972, ISSN 0001-0782, S. 1053–1058, doi:10.1145/361598.361623.
  8. Dewayne E. Perry, Alexander L. Wolf: Foundations for the study of software architecture. In: ACM SIGSOFT Software Engineering Notes. Vol. 17, Nr. 4, 1992, ISSN 0163-5948, S. 40–52, doi:10.1145/141874.141884.
  9. R. Kazman, L. Bass, G. Abowd, M. Webb: SAAM: a method for analyzing the properties of software architectures. 1994, S. 81–90, doi:10.1109/ICSE.1994.296768.
  10. P. B. Kruchten: The 4+1 View Model of architecture. In: IEEE Software. Vol. 12, Nr. 6, 1995, ISSN 0740-7459, S. 42–50, doi:10.1109/52.469759.
  11. Christine Hofmeister, Robert Nord, Dilip Soni: Applied Software Architecture. Addison-Wesley Professional, 2009, ISBN 978-0-321-64334-6.
  12. Frank Buschmann u. a.: Pattern-oriented software architecture. Volume 1: A system of patterns. Wiley, Chichester (New York) 1996, ISBN 0-471-95869-7.
  13. The Working IEEE/IFIP Conference on Software Architecture (Memento vom 6. März 2012 im Internet Archive)
  14. news.cnet.com
  15. Paul Clements, Rick Kazman, Mark Klein: Evaluating software architectures. Methods and case studies. Addison-Wesley Professional, 2002, ISBN 0-201-70482-X.
  16. Len Bass, Paul Clements, Rick Kazman: Software Architecture in Practice. Addison-Wesley Professional, 2003, ISBN 0-321-15495-9.
  17. isaqb.org
  18. isaqb.org
  19. handbuch-softwarearchitektur.de
  20. fg-swa.gi.de
  21. C2 Wiki zu Big Design Up Front
  22. Mike Cohn: Agile Design: Intentional Yet Emergent. In: Mountain Goat Software Blog. 4. Dezember 2009, abgerufen am 24. November 2014 (englisch).
  23. Richard N. Taylor, Nenad Medvidović, Eric M. Dashofy: Software architecture. Foundations, theory, and practice. Wiley, Hoboken 2010, ISBN 978-0-470-16774-8, S. 199–241.
  24. Torsten Posch, Klaus Birken, Michael Gerdom: Basiswissen Softwarearchitektur. 2004, ISBN 3-89864-270-4, S. 95 f.
  25. Grady Booch: Objektorientierte Analyse und Design. 1994, ISBN 3-89319-673-0, S. 291 f.
  26. Helmut Balzert: Lehrbuch der Softwaretechnik. Band 2: Entwurf, Implementierung, Installation und Betrieb. Spektrum Akademischer Verlag, 2011, ISBN 978-3-8274-1706-0, S. 6.
  27. Helmut Balzert: Lehrbuch der Softwaretechnik. Band 2: Entwurf, Implementierung, Installation und Betrieb. Spektrum Akademischer Verlag, 2011, ISBN 978-3-8274-1706-0, S. 29 ff.
  28. M. Shaw, R. DeLine, D. V. Klein, T. L. Ross, D. M. Young, G. Zelesnik: Abstractions for software architecture and tools to support them. In: IEEE Transactions on Software Engineering. Vol. 21, Nr. 4, 1995, ISSN 0098-5589, S. 314–335, doi:10.1109/32.385970.
  29. Edsger Wybe Dijkstra: A discipline of programming. Prentice Hall, 1976, ISBN 0-13-215871-X, S. 56.
  30. W. P. Stevens, G. J. Myers, L. L. Constantine: Structured design. In: IBM Systems Journal. Vol. 13, Nr. 2, 1974, ISSN 0018-8670, S. 115–139, doi:10.1147/sj.132.0115.
  31. Edward Yourdon, Larry L. Constantine: Structured design. Fundamentals of a discipline of computer program and systems design. 1979, ISBN 0-13-854471-9.
  32. Vincenzo Ambriola, Genoveffa Tortora: Advances in software engineering and knowledge engineering. World Scientific, 1993, ISBN 981-02-1594-0, S. 27.
  33. Frederick P. Brooks: The mythical man-month: essays on software engineering. Addison-Wesley, Reading (Mass.) 1995, ISBN 0-201-83595-9, S. 44.
  34. Richard N. Taylor, Nenad Medvidovic, Eric M. Dashofy: Software architecture. Foundations, theory, and practice. Wiley, 2009, ISBN 978-0-470-16774-8, S. 99.
  35. Len Bass, Paul Clements, Rick Kazman: Software Architecture in Practice. Addison-Wesley Professional, 2003, ISBN 0-321-15495-9, S. 71.
  36. Len Bass, Paul Clements, Rick Kazman: Software Architecture in Practice. Addison-Wesley Professional, 2003, ISBN 0-321-15495-9, S. 13.
  37. Len Bass, Paul Clements, Rick Kazman: Software Architecture in Practice. Addison-Wesley Professional, 2003, ISBN 0-321-15495-9, S. 99.
  38. Muhammed Ali Barbar, Ian Gorton: Software Architecture Review: The State of Practice. In: IEEE Computer. Vol. 42, Nr. 7, Juli 2009, S. 26–32, doi:10.1109/MC.2009.233.
  39. Nick Rozanski, Eóin Woods: Software Systems Architecture. Working With Stakeholders Using Viewpoints and Perspectives. Addison-Wesley, 2011, ISBN 978-0-321-71833-4, S. 191–208.
  40. M. Nygard, Documenting Architecture Decisions
  41. https://adr.github.io/
  42. G. Fairbanks, Architecture Haiku, http://www.slideshare.net/matthewmccullough/architecture-haiku
  43. Dr. Gernot Starke, Benjamin Wolf: Der Architecture Communication Canvas. In: Informatik Aktuell. 22. Februar 2024;.