Menü
Ein Beitrag von Adacor

Versionskontrolle: Migration von Subversion zu Git

Lange Zeit nutzte die ADACOR zur Versionskontrolle Apache Subversion (SVN), jetzt sind wir auf Git mit der Verwaltungsoberfläche GitLab umgestiegen.

Warum der Wechsel notwendig wurde, erläutere ich in meinem Beitrag.

Wir Softwareentwickler der ADACOR nutzen das Versionskontrollsystem zur Verwaltung des intern entwickelten Software-Source-Codes. Mithilfe des Programms werden sämtliche Versionen archiviert, mit einem Zeitstempel versehen und per Benutzerkennung gesichert. Damit können alle Quellcodedateien im Nachhinein zu jedem beliebigen Zeitpunkt wiederhergestellt werden.

Die Softwareentwicklung nutzte vor der Migration zu Git für alle internen und externen Projekte Subversion (SVN) zur Versionskontrolle. Mit steigender Mitarbeiter- und Projektzahl offenbarte die freie Software jedoch erhebliche Nachtteile.

Image

Managing your Cloud Transformation

Exolink bietet Ihnen eine hochkarätige Expertise in den Bereichen Hyperscaling und Public Cloud.

Wir konzipieren, entwickeln und betreiben Lösungen auf Amazon Web Services, Microsoft Azure und Google Cloud Platform.

Jetzt informieren!

Nachteile von Subversion

  • Der Überblick über die Projekte und die Zugriffsberechtigungen der einzelnen Mitarbeiter ging leicht verloren.
  • Das Merging, also das Zusammenführen von zwei Revisionen (Versionen), missglückte des Öfteren. Infolgedessen dauerten die gemeinsamen Merging-Sessions länger als geplant.
  • Ungünstig war das Arbeiten mit mehr als vier Personen an einem Projekt.
  • Feature-Branches, der Ablauf der Funktionsentwicklung in verschiedenen Zweigen, sind zwar mit SVN möglich, die Darstellung wird jedoch schnell unübersichtlich und die einzelnen Branches entfernen sich immer mehr voneinander.

Welche Alternativen gibt es zu SVN?

Um die genannten Nachteile zu beseitigen, evaluierte das Entwicklungsteam mehrere Softwarealternativen für die Versionsverwaltung der Quellcodes(z. B. Mercurial, Bazaar und Git). Schnell zeichnete sich ab, dass sich Git am besten für die Ansprüche der ADACOR eignete. So überzeugten die zentralen Git-Management-Systeme im Hinblick auf „Sicherheit“, „Verlässlichkeit“, „Rechtemanagement“, „Komfort“ und „Features“. Ein weiterer Vorteil war, dass sich die dezentrale Lösung unverändert in die integrierte Entwicklungsumgebung „PHPStorm“ integrieren ließ.

Git und GitLab waren die besten

Git ist ein hoch performantes, verteiltes, dezentrales Versionsverwaltungssystem, dass sich in einigen Eigenschaften von den traditionellen Systemen abhebt.

Vorteile von Git und GitLab

  • Sowohl das Erstellen neuer Entwicklungszweige als auch das Merging von Branches sind integraler Bestandteil von Git.
  • Git sieht keinen zentralen Server vor. Die Entwickler können die Merges (verschmolzenen Versionen) bzw. die Commits (bestätigte Freischaltung einer Änderung) untereinander austauschen.
  • Git ist weniger speicherintensiv als SVN oder andere Systeme. Deshalb kann jeder Entwickler problemlos alle Versionen bzw. Commits lokal vorhalten.

Als zentrales System für die Git-Verwaltung wählten die Entwickler GitLab, welches sowohl optisch als auch technisch dem öffentlichen System GitHub.com entspricht.
Für GitLab sprach zudem, dass einige von uns Entwicklern bereits Erfahrungen mit dem Tool gesammelt hatten. GitLab unterstützt die Erstellung und Verwaltung der gesamten Repositorys. Ähnlich wie bei GitHub kann dabei auch der veränderte Quellcode angezeigt werden. Eine Syntaxhervorhebung, Unterschiede zwischen den einzelnen Commits sowie die Darstellungen der Branches sind nur einige Features, welche die Arbeit mit Git zusätzlich erleichtern.

Migration und erste Erfahrungen

Mithilfe der vorhandenen Tools können die SVN-Repositorys inklusive der History in ein Git-Repository migriert werden. Dank einfachster Schritt-für-Schritt-Setupanleitung für jedes neu angelegte Respository, gehen die ersten Anwendungsversuche auch für Git-Neulinge leicht von der Hand. Die Einteilung der Projekte nach Kunde und Entwicklungsteam sowie die Rechtevergabe sind ebenfalls mit wenigen Klicks erledigt. Bis auf die Tatsache, dass man neben den bekannten Befehlen „Commit“ und „Update“, zwei neue Kommandos „Push“ und „Pull“ kennen muss, laufen die meisten Schritte in PHPStorm genauso wie in Subversion ab. Nur übersichtlicher und schneller. Der Wechsel zwischen verschiedenen Branches funktioniert mit einem Klick innerhalb von Sekunden.
Das Mergen bzw. Zusammenführen von Entwicklungszweigen in den Master (Hauptzweig), geschieht nach Erstellen eines Merge-Requests und dem Code-Review eines anderen Entwicklers, direkt in der Weboberfläche von GitLab. Der Vorgang funktioniert in 99 % der Fälle vollautomatisch. Für den Umgang mit dem einen Prozent, das meistens durch Konflikte hervorgerufen wird, gibt es eine detaillierte Schritt-für-Schritt-Anleitung direkt in der GitLab-Oberfläche.

Image

Strategien mit denen Unternehmen ihren Cloud-Erfolg steigern

Ausgzeichnete DevOps Private Cloud – Adacor erhält Innovationspreis
Wenn Daten umziehen müssen – Storage Migration in der Praxis
Was genau ist "Digitalisierung"– Aufteilung in Bereiche bringt Klarheit

Die neue Ausgabe des IT-Magazins komfortabel lesen!
Jetzt PDF hier downloaden

Verbesserte Prozesse beschleunigen die Entwicklung

Die Umstellung des Versionskontrollsystems zur Verwaltung der Software-Source-Codes von Subversion auf Git/GitLab hat sich für die ADACOR gelohnt. Alle Entwickler haben sich innerhalb kürzester Zeit eingearbeitet und die vorhandenen Arbeitsabläufe funktionieren besser als vorher. Besonders die Code-Reviews durch einen anderen Entwickler sowie das gezielte Merging einzelner Features ist durch die GitLab-Oberfläche massiv vereinfacht und beschleunigt worden. Alle Projekte sind mittlerweile migriert und fast alle sind zusätzlich an einen zentralen, auf Jenkins aufbauenden Build-Server angeschlossen. Dieser ist für die Ausführung von automatisierten Tests (hauptsächlich PHPUnit und Selenium) und das Deployen (Livegang) von neuen Versionen zuständig.

Hat Ihnen der Beitrag gefallen? Dann teilen Sie ihn doch einfach durch Klicken auf einen der hier unten angezeigten Buttons bei Facebook, Google Plus oder Twitter.

, , , , , , , , , , , ,

Sie möchten keinen Beitrag verpassen?

Es gibt einen Newsletter. Hier können Sie ihn abonnieren.

Datenschutzhinweise


Weitere Artikel zum Thema lesen

Herausforderung Datenschutz aus Sicht von Managed Hosting

Hosting

Herausforderung Datenschutz aus Sicht von Managed Hosting

Wieso Datensicherheit und -schutz integrale Bestandteile unserer Dienstleistungen sind.

weiter lesen

Kanban-basierte Taskverwaltung unternehmensweit eingeführt

Biz & Trends, Cloud, Hosting

Kanban-basierte Taskverwaltung unternehmensweit eingeführt

Vor der Einführung des Kanban-Systems entschied bei Adacor jeder Mitarbeiter selbst, wie er die ihm zugewiesenen Aufgaben managt und organisiert. Dieses Vorgehen funktionierte im...

weiter lesen

Public-Key-Verfahren (PGP) einfach erklärt

Hosting, IT Security

Public-Key-Verfahren (PGP) einfach erklärt

Verschlüsselung wie im Mittelalter - Dokumente hinter Schloss und Riegel bringen.

weiter lesen


Neueste Nachrichten von Adacor

IT Security

Risikomanagement als Mehrwert für Unternehmen sehen

Wie Sie das Zusammenspiel von ISMS und IKS für sich nutzen können.

weiter lesen

Cloud

AWS, Azure und Co.: Brauchen Sie wirklich eine große Public-Cloud?

Das Angebot großer Public Clouds klingt für viele Unternehmen verlockend. Eine Private Cloud kann jedoch die ökonomisch sinnvollere Lösung sein.

weiter lesen

Biz & Trends

Was ist eigentlich Digitalisierung?

Der Begriff „ Digitalisierung“ weist viele Facetten auf. Die Aufteilung in Bereiche bringt jedoch Klarheit.

weiter lesen