KonfigurationsmanagementKonfigurationsmanagement (abgekürzt auch: KM; englisch configuration management, CM) ist eine Managementdisziplin[1] "zur Herstellung und Erhaltung einer Übereinstimmung der Produktleistungen sowie der funktionalen und physikalischen Eigenschaften des Produkts".[2] Das "Konfigurationsmanagement soll sicherstellen, dass das Produkt und seine Artefakte vollständig reproduzierbar sind."[2] KM korreliert mit dem Dokumentationsmanagement im Projektmanagement (z. B. PRINCE2), sowie mit Referenzmodellen wie CMMI.[3][4][5][6] GrundlagenKM basiert auf sogenannten Konfigurationseinheiten. Häufiger genannt auch Konfigurationselement (englisch: configuration item) bedeutet es ein "Element oder Aggregation von Hardware, Software oder beidem, das für das Konfigurationsmanagement vorgesehen und behandelt ist als einzelne Entität im Konfigurationsverwaltungsprozess".[7] Per ISO/IEC 24765 existieren weitere sechs Definitionen aus verschiedenen ISO-Normen, die sich leicht unterscheiden, jedoch grob dasselbe aussagen.[7] Konfigurationsmanagement ist somit nicht per se an einen bestimmten Anwendungskontext und eine Systemkonfiguration gebunden. Konfigurationsmanagement geschieht innerhalb eines sogenannten Konfigurationsmanagement-Prozesses (KMP), welcher einer Organisation und Planung (KMO) bedarf.[8] Es sind vier Teilgebiete (Teilprozesse) des KM definiert:[9][10][7][11]
Die koordinierte Umsetzung der Prozesse ist z. B. Teil der Aufgabe eines Konfigurationsmanagers bzw. -verantwortlichen, eines Integrators oder in Vertretung eines Projektleiters.[8] GeschichteAuslöser für die Etablierung bzw. Entwicklung des KM war die stetig steigende Produktkomplexität.[10][12] Als Reaktion auf daraus resultierende Probleme (z. B. wahrgenommene Unbeherrschbarkeit) wurde KM in den 1950er Jahren in der Luft- und Raumfahrtindustrie als Lösungsansatz entwickelt. Instrument der Umsetzung waren zu diesem Zeitpunkt einfache Karten, die den Status einer Konfiguration kennzeichneten. Ähnliche Komplexitätsprobleme zeigten sich in Folge auch in anderen Produktbereichen. Entsprechend wurden die Methoden und Instrumente des KM für verschiedene Anwendungsbereiche verfeinert und spezialisiert. KM-Umsetzungen sind heute Teil vieler weitreichenderer Management-Disziplinen bspw. des Produktdatenmanagements oder im Bereich der Informatik des Softwarekonfigurationsmanagements. Frühe Ansätze für KM waren z. B. Prüfsummenverfahren, welche heutzutage noch im Einsatz sind, wenn Software für Kunden oder Benutzer bereitgestellt wird, um Versionsstatus und (unerwünschte) Änderungen sichtbar zu machen, um damit die Konfiguration der Software abzusichern.[13][14] DefinitionAus verschiedenen Fachbereichen wurden unterschiedliche, jedoch im Kern ähnliche Definitionen für das Konfigurationsmanagement hergeleitet. Die folgenden Definitionen sind bekannt: ANSIDas ANSI (American National Standards Institute) hat in Zusammenarbeit mit der EIA (Electronic Industries Alliance) folgende Definition veröffentlicht:[15] "Configuration Management ... is a management process for establishing and maintaining consistency of a product's performance, its functional and physical attributes, with its requirements, design and operational information, throughout its life." Zu Deutsch: "Konfigurationsmanagement ist ein Managementprozess zur Herstellung und Erhaltung einer Übereinstimmung der Produktleistungen sowie der funktionalen und physischen Eigenschaften des Produktes mit den Anforderungen, dem Produktdesign und den operativen Informationen während des gesamten Produktlebenszyklus." Automotive SPICEKM ist Teil der sogenannten Supporting Life Cycle Processes (kurz: SUP) der Automotive SPICE Norm, und dort ist es "SUP.8" mit folgender Definition: "Der Zweck des Konfigurationsmanagement-Prozesses ist es, die Integrität aller Arbeitsprodukte eines Prozesses oder Projekts herzustellen und zu erhalten und sie den betroffenen Parteien zur Verfügung zu stellen."[16][17] Dabei gibt die Norm sieben Prozessschritte vor für eine erfolgreiche Implementierung des KM sowie neun "Base practices" und hat sieben "Work products".[16] IEEE Std 828-2012 - IEEE Standard for Configuration Management in Systems and Software EngineeringDie IEEE Norm 828 (IEEE Standard for Configuration Management in Systems and Software Engineering) definiert KM wie folgt:[8]
Es ist zu beachten, dass sich die IEEE- und die ISO-Norm leicht unterscheiden (siehe Norm-Annex L[8]). Weiterhin erhebt die IEEE-Norm einen Fokus auf Software.[18] ISO 10007 - Qualitätsmanagement – Leitfaden für KonfigurationsmanagementDie international verabschiedete Definition gibt die ISO 10007:[19] Konfigurationsmanagement "ist eine Managementtätigkeit, die die technische und administrative Leitung des gesamten Produkt- und Dienstleistungslebenszyklus, dessen Konfigurationsangaben und Status und der produkt- und dienstleistungskonfigurationsbezogenen Angaben übernimmt." Weiterhin, "Konfigurationsmanagement dokumentiert die Produkt- oder Dienstleistungskonfiguration." sowie "Konfigurationsmanagement sorgt für Kennzeichnung und Rückverfolgbarkeit des Produkts und hält den erreichten Stand seiner physischen und funktionellen Anforderungen sowie den Zugang zu genauen Informationen in allen Phasen seines Lebenszyklus bereit." Eine Konfiguration ist somit die Summe "miteinander verbundener funktioneller und physischer Merkmale[20] eines Produktes, wie sie in den Konfigurationsangaben beschrieben sind". NISTDas NIST Computer Security Resource Center definiert KM wie folgt: "Eine Sammlung von Aktivitäten, die sich auf die Einrichtung und Aufrechterhaltung der Integrität von IT-Produkten und Informationssystemen konzentrieren, und zwar durch die Kontrolle von Prozessen zur Initialisierung, Änderung und Überwachung der Konfigurationen dieser Produkte und Systeme während des gesamten Lebenszyklus der Systementwicklung."[21][22] PRINCE2 (Agile 2016)PRINCE2 definiert eine sog. Konfigurationsmanagementstrategie:[23] "Mithilfe einer Konfigurationsmanagementstrategie wird ermittelt, wie und von wem die Produkte des Projekts gesteuert und geschützt werden." Andere DefinitionenWeitere Definitionen von KM finden sich in verschiedenen Büchern[24][25] (teils als Buchkapitel) oder anderen Medien, wie z. B. SWEBOK. Im Folgenden sind Definitionen von Herstellern aufgezeigt:
CCM - Change and Configuration Management - "A systematic approach to establish and maintain the consistent performance of a system or product throughout its lifecycle, and to effectively manage changes in that product or system."[26] Zu Deutsch: "Ein systematischer Ansatz, um die konsistente Leistung eines Systems oder Produkts über seinen gesamten Lebenszyklus hinweg zu etablieren und aufrechtzuerhalten und um Änderungen an diesem Produkt oder System effektiv zu verwalten."[26]
Unter KM versteht man "die Verwaltung von Computersystemen, Servern und Software in der gewünschten Einheitlichkeit." mit dem Ziel "damit Unternehmen sicherstellen können, dass ihre Systeme auch bei ständigen Veränderungen wie erwartet funktionieren."[27]
Zusätzlich, kann unter KM auch verstanden werden: "Planung von Änderungsanträgen" und die "interpretationsfreie Vergabe von Prioritäten für die weitere Bearbeitung von Änderungsanträgen, die Festlegung der Wirksamkeit des umgesetzten Änderungsantrags und die Gruppierung von Änderungsanträgen zur gemeinsamen Bearbeitung."[28][29] ZieleGenerellZiel des KM ist es[2][30], den Grad der Erfüllung physischer und funktionaler Anforderungen an eine Konfigurationseinheit zu dokumentieren und diesbezüglich volle Transparenz herzustellen. Diese soll zudem dazu führen, dass jede an einer Konfigurationseinheit beteiligte Partei die richtigen und zutreffenden Informationen verwendet.[8] Als Beispiel für den Bedarf von KM dient eine Studie der IAEA über 50 Missionen ("OSART Missions") und kommt zu dem Ergebnis, dass "die Konfigurationsprobleme immer noch ein sehr reales Problem sind, egal welche Größe oder Nationalität des Versorgungsunternehmens, und dass Anstrengungen erforderlich sind, um die Situation zu verbessern."[31] Generelle Ziele des KM
Des Weiteren die Vermeidung von Problemen
IT-KontextIm IT-Kontext werden die folgenden Ziele mit KM verfolgt bzw. davon abgedeckt:[32]
Im Sinne von ITIL 4, wird Konfigurationsmanagement dem Service Management Practice nebst Service Assets (siehe Asset Management, auch AM) zugeordnet.[33][34] Zwischen KM und AM existieren Parallelen, aber es gibt auch Unterschiede.[35][36][37] NormenerfüllungKM dient u. a. der Erfüllung weiterer Normen wie z. B. Funktionale Sicherheit, ISO 26262 (dort Teil 8)[38] oder ISO 20000.[39][40] Konzeptionelle TeilgebieteKMO – Organisation und Planung des KonfigurationsmanagementsIm Rahmen der KMO werden die organisatorischen und technischen Festlegungen zu KI, KB, KÜ und KA getroffen. Dies kann sowohl projekt- als auch produktspezifisch erfolgen. Wesentliche Entscheidungen betreffen die Auswahl der einzusetzenden Werkzeuge, die Zuweisung von zu erfüllenden Aufgaben an Aufgabenträger sowie deren Informationsrechte und -pflichten und die Festlegung von Prozessdefinitionen. Zudem fällt die Auditierung des Gesamtsystems zur Überprüfung der Einhaltung und Wirksamkeit der getroffenen Entscheidungen der KMO zu.[8] KI – KonfigurationsidentifizierungKI ist die Voraussetzung für die Durchführung von KB, KA, und KÜ. Sie umfasst die Auswahl von Konfigurationseinheiten, deren Gliederung zu einer Produktstruktur, Dokumentation sowie Nummernbildung zum Zweck der eindeutigen Identifizierung. Wesentliche Fragestellungen beziehen sich auf die Granularität einer Konfigurationseinheit, die Festlegung von Bezugskonfigurationen (Baselines) sowie die Auswahl einer Nummernsystematik.[8] KÜ – KonfigurationsüberwachungKÜ adressiert Probleme, die sich aus der Veränderung einer Konfiguration ergeben. Zentrale Aktivität stellt daher das Änderungsmanagement dar. Ziel dessen ist es, alle Änderungen an Konfigurationseinheiten sowie deren zugeordneten Dokumenten zu identifizieren, beschreiben, klassifizieren, bewerten, genehmigen und einzuführen. Die mit entsprechenden Kompetenzen und Befugnissen ausgestattete Instanz wird als Konfigurationsausschuss (engl. change control board (CCB) bzw. configuration control board) bezeichnet. Sinnvolle Konfigurationsüberwachung setzt einen festgeschriebenen, formalen Prozess für die Behandlung von Änderungen voraus. Übliche Prozessschritte sind die Beantragung, Bewertung, Entscheidung, Beauftragung, Review der umgesetzten Änderungen und Freigabe. Alle Schritte werden möglichst standardisiert dokumentiert. In diesem Zusammenhang relevante Dokumente sind Änderungsantrag (engl. change request (CR)), Sitzungsprotokoll des CCB und Änderungsauftrag. Referenzobjekt für das Änderungsmanagement ist eine Bezugskonfiguration. Zu einem bestimmten Zeitpunkt stellt diese zusammen mit allen bis dahin freigegebenen Änderungen die gültige Konfiguration dar.[8] KB – KonfigurationsbuchführungDer Prozess der Konfigurationsbuchführung hat die rückverfolgbare Dokumentation der Konfigurationen und Konfigurationseinheiten zum Ziel. Sie sollte daher sinnvollerweise bereits mit der ersten Erstellung von Konfigurationsdaten einsetzen. Gegenstand der KB sind alle Daten zur Konfigurationsidentifizierung und -überwachung.[8] KA – KonfigurationsauditEin Konfigurationsaudit ist die formale Überprüfung von Konfigurationen hinsichtlich der Erfüllung von vertraglich zugesicherten funktionellen und physischen Merkmalen sowie der Übereinstimmung von realisiertem Produkt und zugehöriger Konfigurationsdokumentation. Es werden in diesem Sinne funktionale und physische Konfigurationsaudits unterschieden. Konfigurationsaudits können sowohl für ganze Konfigurationen als auch einzelne Konfigurationseinheiten durchgeführt werden. Insbesondere vor der Festlegung einer Bezugskonfiguration sollte ein Konfigurationsaudit angestrengt werden.[8] Methoden und Werkzeuge zur KonfigurationsbuchführungFür ein funktionierendes KM wird gefordert, jeden Stand eines Elementes (Datei, Quellcode, Dokument, Spezifikation, Software, Hardware, System etc.) eine eindeutige Identifizierung zuzuordnen, unabhängig davon ob die Methodik manuell oder automatisch erfolgt.[2] Manuelle MethodenManuelle Verfahren sind Methoden, die ohne Verwendung eines digitalen Werkzeuges (Computer, EDV, Software) eine Versionierung bzw. Konfigurierung darstellen bzw. KM-Verwaltung ermöglichen. Zum Beispiel stellten Randlochkarten lange Zeit eine effiziente Verwaltung von Karteikarten für Archive und Bibliotheken ohne Einsatz der Computertechnik sicher. Im einfachsten Falle können Konfigurationseinheiten z. B. auf einem Papier erfasst und dokumentiert werden mit entsprechender Zuordnung des Gültigkeitsstands (Version) und weiterer Merkmale. Dies würde sogar möglich sein, um Software aus Sicht des KM zu "konfigurieren", jedoch wäre der Aufwand für manuelle Dokumentation, Prozesse und Integration der Änderungen praxisfern oder aufgrund hoher Komplexität von Systemen wie z. B. einem PKW oder Flugzeug sogar unmöglich, weshalb man sich heutzutage computergestützter, automatischer Werkzeuge bedient.[10] Automatische WerkzeugeAutomatische bzw. assistierende Konfigurationsmanagementwerkzeuge sind Werkzeuge, um Konfigurationsmanagement datenbasiert zu praktizieren. Sie verwenden Archivierungsverfahren und Datenbanken und darauf aufbauend Prozesse, um den Benutzer sinnvoll im KM zu unterstützen. Ein KM-Werkzeug verwaltet die Versionsnummerierung und auch weitere Informationen wie Bearbeiter, Modifizierungszeitpunkt, ein "Label" oder ein Attribut eines zur archivierenden Objektes, und unterstützt den gesamten KM-Prozess. Die Historie wird als Beziehung in der Datenbank für Rückverfolgbarkeit hinterlegt. Es werden z. B. die Differenzen der Dateistände zumeist mit „Reverse-Delta“-Verfahren in einer Archivdatei gespeichert. Konfigurationen des Systems können mit fortgeschrittenen Konfigurationsmanagementwerkzeugen ebenfalls mit eindeutiger Kennzeichnung im Archiv festgehalten werden, ohne dass die einzelnen Elemente dabei mehrfach in der Datenbank vorhanden sind. Diese Werkzeuge bieten auch eine geregelte Zugriffskontrolle, so dass konkurrierende Änderungen von verschiedenen Bearbeitern an einem Element entweder gar nicht zugelassen werden oder – wenn sie zugelassen wurden – nicht verloren gehen, sondern kontrolliert mit Merge-Mechanismen zusammengeführt werden können. Bei komplexeren Projekten ist eine Werkzeugunterstützung im Bereich Konfigurationsmanagement dringend angeraten. Beispiele für WerkzeugeDie folgenden Listen beinhalten verschiedene Werkzeuge, teils kommerziell, die für KM eingesetzt werden oder eingesetzt werden können. Eine weitere Vergleichsliste mit Fokus auf Open-Source-Software existiert. Per Software Engineering Body of Knowledge, kurz SWEBOK, dienen die folgenden Werkzeugklassen für KM:[6]
Zu beachten ist, dass ein KM-Werkzeug über den Umfang eines gewöhnlichen Versionsmanagement-Werkzeugs wie Git hinausgeht, da das Versionsmanagement-Werkzeug selbst als eine Konfigurationseinheit gilt und eine Rückverfolgbarkeit zu anderen Werkzeugen gewährleistet sein muss. Im einfachsten Falle kann z. B. Excel als KM-Werkzeug zum Einsatz kommen. Größere Werkzeuge (PLM, ALM) unterstützen KM nebst Versionskontrolle und decken z. B. auch Anforderungsmanagement ab. Wenige der genannten Werkzeuge beherrschen auch Funktionalitäten im Bereich Produktlinien- und Variantenmanagement.[41] Hinweis: Die folgende Liste ist nicht vollständig. Versionsverwaltung
Konfigurationsmanagement & Hybriden, ALM/PLM-Suiten
Spezialisierte KM-Werkzeuge (z. B. für DevOps oder Cloud), teils Open-Source
Siehe auch
Literatur
WeblinksCommons: Konfigurationsmanagement – Sammlung von Bildern, Videos und Audiodateien
Einzelnachweise
|