Bereitstellungsumgebung

Als Bereitstellungsumgebung (englisch deployment environment oder deployment tier) bezeichnet man in der Informatik ein oder mehrere Computersysteme, um ein Computerprogramm für Anwender und andere Beteiligte auszuführen und bereitzustellen.

Unterscheidung

Abhängig vom Entwicklungsfortschritt des Programms unterscheidet man zwischen unterschiedlichen Umgebungen:[1][2][3][4]

Entwicklungsumgebung
In der Entwicklungsumgebung (englisch development environment), oft kurz als DEV bezeichnet, werden die Softwareanforderungen umgesetzt und durch automatisierte Tests abgesichert. Um Fehlentwicklungen zu vermeiden, muss die Entwicklungsumgebung der Produktivumgebung nachempfunden sein. Typischerweise werden alle Dienste, von denen das Programm abhängig ist, lokal ausgeführt.
Build-Umgebung
In der Build-Umgebung, oft kurz als BUILD bezeichnet, wird der Quelltext der Anwendung zentral kompiliert, jedoch nicht ausgeführt. Die Build-Umgebung muss hierbei nicht der Produktivumgebung ähneln, sondern lediglich die für das Kompilieren nötigen Abhängigkeiten bereitstellen.
Testumgebung
In der Testumgebung (englisch testing environment), oft kurz als TEST bezeichnet, werden automatisierte Softwaretests ausgeführt.[5][6] Unittests werden hierbei typischerweise nach jedem Check-In in der Versionsverwaltung ausgeführt, während lang laufende Integrationstests je nach Laufzeit teilweise nur auf täglicher (englisch Nightly) bis wöchentlicher Basis ausgeführt werden.
Qualitätssicherungsumgebung
In der Qualitätssicherungsumgebung (englisch quality assurance environment), oft kurz als QS oder QA bezeichnet, wird die Anwendung für die Qualitätssicherung bereitgestellt, in der Tester explorativ nach Fehlern in der Anwendung suchen und zusätzliche Tests implementieren. Die Qualitätssicherungsumgebung muss möglichst der Produktivumgebung entsprechen.
Staging-Umgebung (auch Integrationsumgebung und Konsolidierungsumgebung)
Die Staging-Umgebung (englisch staging environment) stellt das Programm für den Product Owner und den Kunden für die Abnahme bereit. Die Stagingumgebung muss möglichst der Produktivumgebung entsprechen.[7]
Produktivumgebung
in dieser Umgebung, oft kurz als PROD bezeichnet, wird das Programm für den eigentlichen Einsatzzweck des Kunden verwendet und generiert hierbei einen Geschäftswert. Die Funktion des Programms wird hierbei laufend mittels Logging, Monitoring und Auditing überwacht.

Bedeutung

Je später ein Programmfehler gefunden wird, desto teurer ist es, den Fehler zu beheben und desto höher sind die durch den Fehler verursachten Kosten. Insbesondere können Fehler in Finanzanwendungen innerhalb kurzer Zeit zu massiven Geldverlusten führen und Fehler in sicherheitskritischen Anwendungen zu einer Lebensgefahr werden. Deshalb durchläuft die Entwicklung unterschiedliche Phasen um Fehler zu finden, bevor das Programm in die Produktion geht.

Relative Kosten durch Programmfehler[8]
Projektstatus Kostenfaktor für Fehlerbehebung
Anforderung 1
Entwurf 3–6
Entwicklung 10
Testumgebung 14-15
Qualitätssicherung 30–70
Produktion 40–1000

Es ist daher wichtig, Fehler durch geeignete Maßnahmen zu vermeiden und möglichst früh zu finden. Maßnahmen umfassen hierbei:

Siehe auch

Einzelnachweise

  1. Verwenden von Umgebungen für die Bereitstellung. In: GitHub-Dokumentation. Abgerufen am 15. September 2024.
  2. Richard Ellison: Software Testing Environments Best Practices. In: Software Testing Magazine. 20. Juni 2016, abgerufen am 15. September 2024 (englisch).
  3. Scott Ambler: Development Sandboxes: An Agile Core Practice. In: agiledata.org. 20. März 2023, abgerufen am 15. September 2024 (englisch).
  4. Rick Anderson, Kirk Larkin: Use multiple environments in ASP.NET Core. In: Microsoft Learn. 26. April 2024, abgerufen am 15. September 2024 (englisch).
  5. Antonia Bertolino, Andrea Polini: A framework for component deployment testing. In: Proceedings of the 25th International Conference on Software Engineering (ICSE 2003). May 3-10, 2003, Portland, Oregon. IEEE Computer Society 2003, S. 221–231.
  6. Christian Murphy et al.: Automatic detection of previously-unseen application states for deployment environment testing and analysis. In: Proceedings of the 5th International Workshop on Automation of Software Test (AST). May 3-4, 2010, Cape Town, South Africa. 2010, S. 16–23.
  7. Jason Lee: Szenario: Konfigurieren einer Stagingumgebung für die Webbereitstellung. In: Microsoft Learn. 13. Juli 2023, abgerufen am 15. September 2024.
  8. Jonette Stecklein, Jim Dabney u. a.: Error cost escalation through the project life cycle. (PDF) In: NASA Technical Reports Server. NASA Johnson Space Center, abgerufen am 29. Mai 2017 (englisch).