Software Versionsverwaltung mit SVN
Einleitung
Als Software Versionsverwaltung nutzen wir an der HSHL Subversion (SVN). Subversion ist ein freies/Open-Source Versionskontrollsystem. Das bedeutet, Subversion verwaltet Dateien und Verzeichnisse und die Änderungen an ihnen im Lauf der Zeit. Das erlaubt Ihnen, alte Versionen Ihrer Daten wiederherzustellen oder die Geschichte der Änderungen zu verfolgen. Unter diesem Blickwinkel denken viele Leute bei einem Versionskontrollsystem an eine Art „Zeitmaschine“.
Subversion kann netzwerkübergreifend arbeiten, was die Benutzung durch Menschen an verschiedenen Computern ermöglicht. Auf einer bestimmten Ebene fördert die Fähigkeit unterschiedlicher Personen dieselbe Menge an Daten bearbeiten und verwalten zu können die Zusammenarbeit. Ohne auf einen einzigen Kanal, über den alle Änderungen abgewickelt werden müssen, beschränkt zu sein, kann das Vorankommen beschleunigt werden. Und weil die Arbeit versioniert ist, braucht nicht befürchtet zu werden, dass die Qualität bei Verlust dieses Kanals geopfert wird – falls irgendeine falsche Änderung an den Daten gemacht wird, kann man sie einfach zurücknehmen.
USVN ist ein browserbasiertes Verwaltungssystem. Auf Ihrem Rechner benötigen Sie eine Client-Software um auf den Server zugreifen zu können. Eine ausführliche Zusammenstellung verfügbarer Clients finden Sie unter dieser Zusammenstellung und Vergleich von SVN-Clients, die für jeden Client die abgedeckten Funktionen aufführt.
Warum sollten Sie SVN nutzen?
- Ihre Daten sind auf einem Server sicher und weltweit für Sie zugänglich.
- Teammitglieder können auf ihre Arbeitsergebnisse zugreifen, auch wenn Sie verhindert sind.
- Kommentare ermöglichen die schnelle Identifizierung von Änderungen.
- Änderungen erfolgen persönlich - sie finden über die Historie sofort heraus, wer was programmiert hat.
- Dateien liegen ihnen nur in einer Version vor - der aktuellen. Die Historie dieser Datei ist jederzeit rückverfolgbar und wiederherstellbar.
- Fertige Stände Ihrer Software können mit einem Stempel (Tag) versehen und später schnell wiederhergestellt werden.
- Versionsverwaltung ist Industriestandard und die Übung im Studium wird Ihnen später helfen sich zurecht zu finden.
Handbücher/Einführungen
Im Internet finden sich zahlreiche Anleitungen zu SVN und der Bedienung mit Tortoise SVN.
SVN Quickstart
- Loggen Sie sich via usvn ein und ändern Sie Ihr Passwort
- Vorname_Nachname::Kennwort1 (z.B. Max_Mustermann Kennwort1)
- Prüfen Sie, ob Sie Zugang zum passenden Repositorium haben.
- Installieren Sie Tortoise SVN für Windows (Mac) inkl. "Language-Pack"
- Hochschulrechner:
- Legen Sie sich auf der Datenpartition unter \SVN ein Repositorium an.
- Sichern Sie alle Ihren Quelltext in Ihrem Gruppenordner.
- Eigener Rechner:
- Beliebigen Ordner erstellen (Empfehlung: Ordner ohne Leerstellen etc. verwenden, damit für Programmierung/Matlab/... keine Probleme)
- SVN > auschecken/checkout
- Machen Sie sich mit der Funktion von SVN bekannt.
- Antworten auf alle Fragen finden Sie hier.
Grundregeln im Umgang mit SVN
Nutzen Sie die folgende Liste und arbeiten Sie nachhaltig in SVN. Diese Liste ist lang, lohnt sich jedoch sehr, da sie die wichtigsten Regeln und Erkenntnisse beim Umgang und effizienten Arbeit mit SVN zeigt.
- Spätestens an jedem Arbeitstag sollten Sie ihre Daten ins Projektarchiv übertragen (="commit"), wenn nicht sogar nach jeder wichtigen Änderung
- Überlassen Sie SVN die Versionierung. Falsch wäre die Speicherung von 3 Domumenten:
Dokument_v1, Dokument_v2, Dokument_v3
. Richtig:Dokument
wurde 3x in SVN übertragen (Commit
). - Sichern Sie nur wichtige Dateien in SVN (auf keinen Fall Kompilat, Backup-Sicherheitskopien, temporäre Dateien, große Videos,...).
- Sichern Sie keine Binärdateien.
- Testen Sie Ihren Quelltext sorgfältig vor dem Übertragen.
- Aktualisieren Sie vor dem Übertragen das gesamte Quellverzeichnis und testen Sie erneut.
- Sie sind verantwortlich für alle Fehler, die durch Ihr Änderungen entstehen. Also: testen, aktialisieren, Konflikte lösen, nochmal testen und übertragen.
- Sichern Sie nur getesteten Quellcode in SVN, welcher über Header und Kommentare verfügt.
- Übertragen Sie stets nur die Änderungen und nicht ein komplettes Verzeichnis.
- Wenn Sie eine Datei hinzufügen nutzen Sie
SVN Add
und anschließendSVN Commit
- Wenn es Konflikte gibt, kontaktieren Sie das Teammitglied und beheben Sie die Konflikte gemeinsam um Schäden zu vermeiden.
- Sie sind für Ihre Änderungen verantwortlich. Verwenden Sie Ihren Nutzernamen und Passwort.
- Checken Sie nur die Projekte aus, an denen Sie auch arbeiten.
- Sperren ("Lock") Sie Dateien nur dann, wenn diese zur Bearbeitung eine Sperre benötigen. Normalfall: Nie! Bei binären Dateien (Office-Dokumente, Bilder,...): Immer!
- Sperren werden automatisch entfernt beim Übertragungen (="commit") oder manuell über das Kontextmenü von z. B. TortoiseSVN.
- Sperren können über "
Check for Modifications
" überprüft werden. (Lokale tauchen direkt auf und um alle zusehen muss "Check Repository" verwendet werden)
- Übertragen (engl. "commit") Sie nur mit Kommentaren.
- Kommentare sollten verständlich und kurz gehalten werden.
- Kommentare erläutern Ihrer Änderungen. Was haben Sie geändert? (Jedoch nicht: Welche Datei ist neu, welche gelöscht etc.: das sieht man im Log-Bericht automatisch)
- Anzahl der Änderungen
- Typ der Änderung (Änderung, Bug Fix,…)
- Was macht die Änderung?
- Wichtige Details
- Ggf. Link zur Anforderung
- Ggf. Link zum Testbericht
- Name und Datum sind nicht notwendig!
- Führen Sie zu Beginn Ihrer Arbeit und vor jedem "commit" stets ein "update" durch.
- Lesen Sie ggf. zu Beginn Ihrer Arbeit das Log-File ("
Show Log
") und befolgen Sie die Hinweise. - Verschieben Sie Inhalte nur mit der rechten Maustaste "
SVN Move versioned Item(s) here
". - Versionieren Sie ausschließlich die Primärdateien. Nicht erlaubt sind:
- Compiler-, Build- oder Debug-Dateien oder Backups (z. B.
.asv, .bkp, ~Dateinamen
) - Temporäre Ordner oder Ordner die nur für den Arbeitsrechner erstellt werden (z. B.
.vs
) - Videodateien die nicht als Eingabedatei für Programme dienen
- Externe Bibliotheken die im gleichen Umfang im Internet zur Verfügung stehen (z. B. opencv)
- Compiler-, Build- oder Debug-Dateien oder Backups (z. B.
- Vermeiden Sie in Ordnerbezeichnungen und Dateiennamen Sonderzeichen, Freizeichen und Umlaute (z. B.
Uebung_1_2
). - Cleanup wird benötigt, wenn Fehler aufgetreten sind bei einem
Commit
oderUpdate
.- Cleanup sollte im Obersten Ornder verwendet werden.
- In den meisten Fällen sollte "
Clean up working copy status
" und "Refresh shell overlays
" genügen. - Genaue Befehl Beschreibung ist hier aufzufinden [1]
- Weitere TortoiseSVN Regeln
Umgang mit binären (nicht textbasierten) Dateien
SVN spielt seine Stärke besonders dann aus, wenn textbasierte Dateien versioniert werden sollen, z. B. Programmcode, Skripte etc. Beim Versionieren werden dann die Änderungen von verschiedenen Nutzern zusammengeführt.
Bei binären Dateien (Bilder, Excel-Tabellen, ...) macht dieses Vorgehen keinen Sinn, da durch das Zusammenführen nicht mehr richtig interpretierbare Dateien resulieren können. Um auch diese Dateien per SVN versionieren zu können, müssen so genannte Sperren genutzt werden. Vorgehen beim Arbeiten mit Sperren:
- Per Rechtsklick - Tortoise SVN - Eigenschaften - Neu - Dateisperre kann eingestellt werden, dass eine Datei eine Sperre benötigt.
- Eine Datei mit dieser Eigenschaft ist dann in jeder Arbeitskopie zu Beginn gesperrt, d. h. schreibgeschützt.
Zum Arbeiten mit dieser Datei befolgen Sie folgende Schritte:
- Rechtsklick auf die Datei - Tortoise SVN - Sperre holen >> Datei ist entsperrt, d. h. veränderbar (Schreibschutz aufgehoben)
- Datei ändern und speichern
- Beim Übertragen per Rechtsklick auf die Datei - Tortoise SVN - Übertragen ist die Datei wieder gesperrt.
- Hinweis: Beim letzten Schritt kann das automatische Wieder-Sperren deaktiviert werden, falls Sie z. B. gleich weiter mit der Datei arbeiten möchten.
Wann sollte man Daten übertragen?
- Sie haben einen SW-Stand zu dem Sie zurückkehren möchten.
- Übertragen Sie zusammenhängenden Dateien in einer operation. Nutzen Sie eine LOG-Nachricht für alle Dateien.
- Übertragen Sie Daten als Backup.
- Übertragen Sie Daten von einem Arbeitsrechner um sie mit anderen zu teilen.
Anforderungen an Ihr Passwort
Für das Arbeiten mit SVN ist zwingend ein sicheres Passwort erforderlich. Bechaten Sie nachfolgende Regeln
- Das Passwort muss mindestens 12 Zeichen umfassen.
- Es sollte mindestens 2 Sonderzeichen, eine Zahl, einen Kleinbuchstaben und einen Großbuchstaben enthalten.
- Für das Passwort sind folgende Zeichen erlaubt:
- Kleinbuchstaben ( a - z )
- Großbuchstaben ( A - Z )
- Ziffern ( 0 - 9 )
- die Sonderzeichen ( ) [ ] { } ? ! $ % & / = * + ~ , . ; : < > - _
Verbindungsprobleme
Bei Verbindungsproblemen schreiben Sie bitte eine Email an die IT (it-support@hshl.de) und beschreiben Sie freundlich Ihr Problem und senden Sie folgende Infos:
- Betreff: Ticket#2013120310000018
- Fehlermeldung
- Zeit
- Client
- Netz (HSHL oder Web incl. IP Adresse)
Einführungsvideo
Video Tutorials
Mit den folgenden Video Tutorial lernen Sie spielend leicht und kostenlos den Einstieg in die Versionskontrolle:
- Christopher Janietz- Versionskontrolle mit Git und SVN bei LinkedIn
- Julian Robichaux - SVN for Java Developers bei LinkedIn
Den kostenlosen Zugang zum LinkedIN Portal erhalten Sie über den Bibliothekskatalog unter dem Reiter "Literatur und Fachdatenbanken".
Weblinks
- Wikipedia-Artikel: Apache_Subversion
- Comparison of Subversion clients
- Subversion Apps for OS X
- Video Kurzeinführung
- Top Tipp: V2B Versionskontrolle mit Git und SVN
- SVN Notify
- William Echlin
- Tortoise Tutorial 1 auf Deutsch - Funktionsweise von SVN kurz erklärt (German)
- Tortoise Tutorial 2 auf Deutsch - Repository erstellen und Datei Check-in (German)
- Tortoise Tutorial 3 auf Deutsch - Datei Check-out an einen anderen Ort (German)
- Tortoise Tutorial 4 auf Deutsch - Datei Check-in einer neuen Version (German)