Subversion für Anfänger und solche, die es noch werden wollen ;) Alexander R. Krug –...

Post on 06-Apr-2015

104 views 0 download

Transcript of Subversion für Anfänger und solche, die es noch werden wollen ;) Alexander R. Krug –...

Subversion

für Anfänger und solche, die es noch werden wollen ;)

Alexander R. Krug – krugar@ipsi.fhg.de

Module dieses Vortrages

• Was ist Versionierung und wozu ist das gut?• Terminologie• Warum Subversion und nicht CVS?• Wie benutze ich Subversion?• Wie setze ich einen Server auf?• Wie migriere ich von CVS nach Subversion?• Links

Versionierung

Was und Warum?

Versionsmanagement

• Versionsmanagement ermöglicht einfach Abspeichern ohne zu überschreiben.

• Man hat also zu einer Datei nicht nur die zuletzt gespeicherte Version, sondern auch alle vorher abgespeicherten Versionen.

• Das Verwalten paraleller Versionen und das Zusammenführen derselben ist die eigentliche Aufgabe solcher Systeme.

checkout? commit? head? wtf?

Die wichtigsten Begriffe aus der wundervollen Welt des

Versionsmanagements in einfachem Deutsch

checkout? commit? head? wtf?

• repository - Die Datensammlung, die svn für einen verwaltet• working copy - Die lokale Kopie der Daten aus dem repository, an

der man arbeitet und Veränderungen vornimmt.• revision – Zustand des repositories zu einem Zeitpunkt. Jeder

commit (kommt später) erzeugt eine neue revision.• head - Die aktuellste revision• trunk - Der Stamm des Versionsbaumes• branch – Ein Ast im Versionsbaum• tag – revision mit nem Namenszettel dran ;)

wtf? contd.

• checkout - Sich eine Verzeichnisstruktur mit Daten vom repository holen, macht man üblicherweise einmal am Anfang.

• update - Sich die Neuerungen zwischen dem mit "checkout" Heruntergeladenen und dem aktuell auf dem repository Verfügbaren herunterladen. Damit ist die working copy auf dem aktuellen Stand (wenn man lokal Daten verändert hat, können merges norwendig werden, siehe unten)

• merge – Einen Konflikt zwischen dem aktuellen head und einer veralteten, aber lokal veränderten Datei auflösen

• commit - lokal veränderte daten in das repository hochladen (und damit eine neue revision der daten als head in das repository legen). Das geht nur, wenn im head keine veränderungen sind, die man damit überschreiben würde. Gibt es auf repository-seite veränderungen, muss man diese erst per merge lokal einpflegen, bevor man commiten kann

merge nochmal genauer

Subversion vs. CVS

Warum nicht auch das nehmen, was alle anderen schon seit

Jahren verwenden?

Warum lieber Subversion?

• „atomic commits“ – Wenn eine Transaktion mit dem Subversion Server unterbrochen wird, bevor sie zuende ist, passiert genau garnichts.

• Man kann Dateien und Verzeichnisse umbenennen und verschieben und Subversion kommt damit zurecht

• Performanteres Datenbank-Backend• saubere C-API und anderer Kleinkram

Subversion

Benutzung und Integration

Integration in Eclipse und IDEA

• IntelliJ IDEA 5.0 bringt eine native Unterstützung mit, für 4.x gibt es ein Plugin

• Für Eclipse 3.x und 2.2+ gibts ein Plugin namens Subclipse ( subclipse.tigris.org )

• Womit wohl die meisten JAVA Entwickler glücklich werden sollten...

Standalone Clients

• Für Windows: TorquoiseSVN

• Für alle (dank JAVA): SmartSVN

Ye good ole command line

• Zu haben für Windows, Mac, BSD, Solaris und verschiedene Linuxe

• Zum Scripten und für Anhänger der Alten Schule

• Achtung: für ANT 1.6.x gibts noch keinen brauchbaren ChangeLog Task (was mich den restlichen Nachmittag noch beschäftigen wird >.< )

svnserve oder mod_dav_svn

Oder einfach ohne Server?

svnserve

• svnserve ist ein standalone deamon• Läuft standardmäßig auf tcp port 3690• Unterstützt User-Authentifizierung mit CRAM-MD5• Verzeichnisbasierte Zugriffsrechte nur mit schmutzigen

Tricks• Zugriff via URL á la svn://find-meinen.server.net• Kann unter Unix per inetd gestartet werden• Unter Windows gibts ein kleines Hilfsprogramm namens

SVNservice, das erlaubt es, den Server als Service zu starten (das spart einem das hässliche DOS-Fenster)

svnserve + SSH

• svnserve kann auch zusammen mit einem SSH-System benutzt werden, in dem Fall wird der Server-Prozess vom SSH-Server gestartet

• Vorteil: Quellcode wird verschlüsselt übertragen• Nachteil: Da der Server-Prozess unter dem mit

SSH authentifizierten Betriebssystem-Benutzer gestartet wird, kann man sich hier mittels Dateirechten vorzüglich in den Fuß schiessen...

• Zugriff via URL á la svn+ssh://find-meinen...

mod_dav_svn

• Plugin für Apache 2.x

• Authentifizierung erfolgt über Apache, daher auch feingranularere Zugriffsrechte möglich

• Zugriff via URL á la http(s)://find...

• Interessant für Server mit mehreren Projekten in einem Repository oder an Stellen mit restriktiveren Firewalls

Ohne Server

• Für den Hausgebrauch kann man auch auf den Server verzichten.

• Der svn Client kann über einen file://-URL direkt auf das Repository zugreifen

• Vorteil: weniger arbeit beim aufsetzen• Nachteil: wenn mehrere Rechner (zB über

Samba oder NFS) Zugriff auf das Repository haben sollen, kann man das Berkerly DB Backend nicht nutzen und muss mit dem FSFS Backend Vorlieb nehmen. (es sei denn, man hat eine Share, die strikte POSIX-konforme file locks bietet...)

Oder doch lieber... alle?

• Man kann mehrere Server-Prozesse gleichzeitig auf einem Repository laufen lassen, die Datenbank kommt damit zurecht.

cvs2svn

was es kann und was es braucht

cvs2svn

• Braucht Phyton 2.0+, GNU Sort und entweder den RCS co Client (schneller) oder einen CVS Client (langsamer, aber es gibt Spezialfälle, wo der nötig ist)

• Kann nur mit direktem Dateisystem-Zugriff auf das CVS Repository benutzt werden (!)

• Kann ganze Subversion-Repositories oder Dumpfiles erstellen, oder Daten in ein existierendes Repository einpflegen

• Auswahlmöglichkeiten umfassen head-only, trunk-only, einzelne Unterverzeichnisse, einfach alles, oder oder...

Links

• Das hier als Website für alle Schreibfaulen: http://krugar.de/stuff/svn-intro/

• Allgemeine Entscheidungshilfen für Versionierungssoftware auf Deutsch: http://better-scm.berlios.de/

• Subversion: http://subversion.tigris.org• Das Subversion-Buch: http://svnbook.red-bean.com/• TortoiseSVN: http://tortoisesvn.tigris.org/• SmartSVN: http://www.smartcvs.com/smartsvn/• Subclipse: http://subclipse.tigris.org

FIN

Aufwachen, ich bin fertig :P