Migration (Informationstechnik)Der Begriff Migration (aus lateinisch migratio ‚Übersiedlung‘) steht in der Informationstechnik für den Prozess einer grundlegenden Veränderung einer bestehenden Systemlandschaft oder eines wesentlichen Teils dieser Landschaft. Die Migration kann sich sowohl auf Hard- als auch auf Software beziehen.[1] BegriffsabgrenzungDer Begriff der Migration ist vielschichtig. Er kann zum einen für die Umstellung eines einzelnen Systems stehen. Zum anderen können damit auch große Migrationsprojekte gemeint sein, bei denen viele Systeme oder mehrere neue Anwendungen implementiert werden.[2] Die Migration von einem Betriebssystem auf ein anderes umfasst in der Regel zugleich die Migration von Anwendungssoftware und Daten. Der Begriff Portierung steht in der Abgrenzung zu Migration für die Übertragung eines Programms von einer Hard- und/oder Softwareplattform auf eine andere.[3] Dafür werden die Programme – die für ein bestimmtes Betriebssystem oder eine Plattform geschrieben wurden – so verändert, dass sie auf einem anderen Betriebssystem laufen.[4] Zum Teil werden die Begriffe synonym verwendet. MedienmigrationMedienmigration bezeichnet einen Vorgang, bei dem das physische Datenträgermedium eines Datenobjekts innerhalb eines Archivs geändert wird. Sie ist damit eine Verfahrensart zur Erhaltung eines Bitstreams.[5] In der Durchführung unterscheidet man vier Arten:
Bei Refreshment und Replication geht es ausschließlich um den Erhalt von bestehenden Daten durch Wechsel der Speichermedien. Sie stellen damit Medienmigration im engeren Sinne dar. Hingegen wird bei Repackaging und Transformation auch der Inhalt der Daten verändert. Es liegt also eine doppelte Funktion vor. Zum einen wird mit der Änderung des Datenformats ein neues Datenobjekt erstellt, das in der Regel auf einem neuen Datenträger abgespeichert wird. Allerdings erfolgt hier die Migrationsmaßnahme auch mit Blick auf die zukünftige Interpretierbarkeit, d. h. Lesbarkeit der Daten. Deswegen spricht man hier von Medienmigration im weiteren Sinn oder Formatmigration. SoftwaremigrationSoftwaremigration lässt sich als Prozess der Umstellung von einer bisherigen zu einer neuen technologischen Umgebung definieren.[6] Die Migration geht über eine einfache Aktualisierung bzw. ein Upgrade hinaus und bezeichnet vielmehr einen grundlegenden Wechsel der Software-Infrastruktur. Basis einer Migration bilden Migrationsstrategien. Im Idealfall stehen Dienstprogramme zur weitestgehend automatisierten Umstellung zur Verfügung. Häufigste Gründe für die Durchführung einer Softwaremigration sind die Überalterung der Software oder das bestehende Altsystem („Legacy-System“) ist nicht mehr in der Lage, neue Anforderungen an Hard- und Software zu erfüllen. Letzteres kann besonders in Organisationen gegeben sein, wenn geeignetes IT-Fachpersonal für ältere Software fehlt.[7] Beispiele für eine Softwaremigration:
DatenmigrationDer Begriff Datenmigration steht für die Überführung von Daten von einem Quellsystem in ein Zielsystem. Durchgeführt wird eine Datenmigration, wenn ein neues System die Aufgaben eines oder mehrerer Altsysteme übernehmen soll. Auch die Ablösung eines Altsystems durch ein bereits produktives System bedingt eine Datenmigration.[9] Die Gründe für eine Datenmigration sind zum Beispiel inadäquate Datenbankstrukturen, kaum noch wartbare Anwendungssysteme, die Zusammenführung mehrerer Informationssysteme zu einem einheitlichen System und der Wunsch, neue Datenbanktechnologien einzuführen.[10] Beispiele:
Eine Datenmigration besteht aus mehreren Schritten – angefangen bei der Analyse der Quellsysteme bis zum Validieren der Ergebnisse.[11] Die eigentliche Migration besteht aus drei Schritten. Im Extraktionsschritt wird gefiltert, welche Daten übernommen werden sollen. Dazu werden die Daten zunächst analysiert, dann extrahiert und abgeglichen. Zudem werden Steuerungsdaten wie Mappingtabellen bereitgestellt.[11] Als Zweites erfolgt eine Transformation. Die Daten liegen im Datenmodell des Altsystems vor. Sie müssen also transformiert werden, dass sie zum Datenmodell des Zielsystems „passen“. Relevante Daten werden selektiert, fehlerhafte Daten korrigiert und mehrfach vorliegende Daten zusammengeführt. Anschließend folgt das Mapping.[11] Im dritten und letzten Schritt werden die transformierten Daten ins Zielsystem geladen. Die drei Schritte entsprechen dem ETL-Prozess eines Data-Warehouse. Das Ziel ist aber ein anderes. Ein Data-Warehouse soll neue Erkenntnisse liefern, z. B. um die Entwicklung von Verkaufszahlen zu verstehen. Bei der Datenmigration hingegen bleiben die Daten semantisch unverändert. Alle (relevanten) Kunden sind weiterhin vorhanden. Die Kontostände sind ebenso unverändert. Einzig das Datenmodell kann sich ändern. Technisch realisiert werden kann eine Datenmigration beispielsweise mittels ETL-Tools, Spezial-Migrationstools mit SQL-Skripten. Zuverlässigkeit spielt eine wichtige Rolle (es sollen keine Konten „verloren“ gehen). Ebenso sind oft sehr viele Objekttypen zu migrieren (Kunden, Konten, Aktiendepots, Börsenplätze, Bilanzdaten etc.). Eine Ablaufsteuerung koordiniert den ETL-Prozess für die verschiedenen Objekttypen. Eine Migrationsverifikation betrachtet ausgewählte Testfälle beispielsweise manuell (pars pro toto) und verwendet zusätzlich Statistiken. Statistiken erlauben, eine „Nadel im Heuhaufen“ zu finden, wenn beispielsweise ein einziges Konto von 10.000.000 zu migrierenden Konten fehlt. AnwendungsmigrationIm Rahmen der Anwendungsmigration wird eine Anwendung durch eine neue ersetzt.[12] Bei diesem Prozess kommen sowohl Elemente der Softwaremigration als auch der Datenmigration zusammen; oft wird auch neue Hardware benötigt. Eine sorgfältige Planung (Migrationsstrategie) und Durchführung ist entscheidend zur Wahrung der Datenkonsistenz und zum reibungslosen Wechsel der Funktionalität von der alten auf die neue Anwendung. Hardware-MigrationDie Migration bestehender Systeme auf neue Hardware wirft in etwa dieselben Probleme auf wie rein softwareseitige Migration und ist über Schnittstellentreiber meist zwangsläufig mit einer gewissen Softwaremigration verbunden. Datenmigration wird dabei tunlichst vermieden. Ein Beispiel aus der Praxis ist der Übergang von einem klassischen Ethernet-Netzwerk zur ATM-Technologie unter Beibehaltung der strukturierten Verkabelung. Eine Hardware-Migration zu einer völlig neuen Mikroprozessor-Technologie führte das Unternehmen Hewlett-Packard bei Bestandskunden seiner Server-Produkte ab etwa den 2000er Jahren durch. Dabei werden nach und nach die bei Kunden befindlichen Server mit den älteren Alpha-Prozessoren und PA-RISC-Prozessoren auf die zusammen mit Intel entwickelte Itanium-Prozessortechnologie umgestellt.[13][14] Live-MigrationAls Live-Migration wird der Umzug einer virtuellen Maschine (VM) bezeichnet, bei dem eine VM im laufenden Betrieb von einem physikalischen Wirtssystem (Host) auf ein anderes übertragen oder verschoben wird. Im Idealfall findet solch ein Umzug ohne Beeinträchtigung der VM statt, sodass auch laufende Arbeiten in der VM ohne Unterbrechung fortgesetzt werden können. Das Ziel derartiger Migrationen ist eine einfachere Wartbarkeit von Hardware sowie ein möglicher Lastenausgleich derselben.[15] Umstellung auf neuere Schnittstellen und TechnikenEine Funktion oder ein Parameter eines Programmes oder beispielsweise SGML-Elemente in Auszeichnungssprachen, welche in Folgeversionen möglicherweise nicht mehr verfügbar sein werden, oder aber auch überholte Programmiertechniken, werden als missbilligt/hinfällig (englisch deprecated) eingestuft. Der Sinn, diese aber dennoch weiterzuführen, liegt in der Aufwärtskompatibilität. Denn wenn eine Schnittstelle einfach abgeschafft würde, entstehen leicht Ausnahmefehler. Daher wird die alte Verarbeitung der Eingabe auf solch einer Schnittstelle durch eine einfache Fehlerbehandlungsroutine ersetzt, etwa, indem eine Funktion einen Rückgabewert erhält. Der Aufrufer erhält dann z. B. nicht einen Fehler, sondern zumindest einen – wenn vielleicht auch unnützen – Wert des erwarteten alten Datenformats. Das vermeidet Probleme, die folgen können, wenn der Aufrufer keine Fehlerauswertung auf dieser Schnittstelle implementiert hatte. Die Wahl des neuen Dummy-Werts bedarf aber einer sorgfältigen Auswahl (Ein Parameter vom Datentyp Zur Unterstützung der Umstellung besteht in manchen Programmiersprachen oder Entwicklungsumgebungen die Möglichkeit, missbilligte Techniken mit bestimmten Schlüsselwörtern zu kennzeichnen. Die Behandlung komplexer Schnittstellen kann ziemlich aufwändig werden, denn andernfalls geht dann einfach die Aufwärtskompatibilität verloren. Das „Mitschleppen von Altlasten“ kann sich im Laufe von Weiterentwicklung zu eminenten Problemen auswachsen: Ein typisches Beispiel ist die 16-Bit-Kompatibilität des Betriebssystems Windows, das noch die OS/2- und DOS-Kompatibilität sicherstellen muss. In modernen Windows-Versionen führt das dazu, dass ein eigener DOS-Emulator implementiert sein muss. Zwischen den beiden Möglichkeiten abzuwägen, ist eines der Hauptprobleme der Versionsverwaltung moderner Software. Daher wird bei neuen Versionen zwischen kleiner (minor) und großer Aktualisierung (major Upgrade) unterschieden, je nachdem, in welchem Ausmaß die Aufwärtskompatibilität gewährleistet wird. Eine Migration über mehrere Versionen (Releases) hinweg kann wesentlich leichter Probleme bereiten oder gar eine Neuinstallation erfordern. Siehe auchLiteratur
WeblinksAllgemeine Information:
Datenmigration-Tools:
Einzelnachweise
|