IS2739: Subversion

Preview:

DESCRIPTION

IS2739: Subversion. Team B. Outline. 1. Version Control 2. Subversion vs. CVS 3. Demo. What is version control?. Version control is the management of changes to documents, programs, and other information stored as computer files. - PowerPoint PPT Presentation

Citation preview

IS2739: Subversion

Team B

1. Version Control2. Subversion vs. CVS3. Demo

Outline

• Version control is the management of changes to documents, programs, and other information stored as computer files.

• Put it another way, track every change to every document and identify the change with number, letter, and time.

• Versions can be compared, restored, and with some types of files, merged.

What is version control?

• Manage files and directories, and its changes over time

• Collaboration and keep track of who made which change.

What you cannot do without version control?

• No need to notify other members before change the project file.

• No need to manually duplicate the original version before change the project file.

• No need to tell other members or remember what changes you have made.

Why version control is needed

The Problem of File Sharing

All version control systems have to solve the same fundamental problem : How will the system allow users to share information, but prevent them from accidentally stepping on each other's feet?

• Repository allows only one person to change a file at a time.

• Managed using Locks.

Problems:• One by One• No concurrency• False sense of Security• Administrative problems: lock a file and forget to unlock it

after finish.

When lock-modify-unlock is necessary? Files with binary format like picture, sound and video

Lock-Modify-Unlock solution

Lock-Modify-Unlock solution

Copy – Modify – Merge Solution

• Each client gets a working copy. Users work simultaneously and independently on private copies. Finally, copies are merged into a final version.

• Overlaps are flag as being in state of conflict

Problems• Manually fix it.• Communication

When copy-modify-merge is necessary?Line-based text files can be contextually mergeable

Copy – Modify – Merge Solution

1.Graphic demonstration2.Color,number-highlight demonstration3.Comparison demonstration4.User-defined demonstration

Track the change

Subversion Categories

1. You always see tags,trunk,branches in Subversion.These are three different 'categories' for versions of the project. 

2. Trunk is traditionally the cutting-edge version that is being actively developed, a lot like CVS HEAD.

3. Branches are for alternative copies of your project. Allow you to create as many bugs as you want. After you finish, merge it into the trunk.

4. Tags are used for milestone releases.

1. Create branches by copying your data2. Maintain parallel branches of your file and directory3. Duplicate changes from one branch to another branch4. Reflect differences among branches

Branch Cont.

• Can move or rename files or directories cleanly• Atomic commits• Good remote options http/https/svn vs pserver• File formats

Why Subversion over CVS

svn --helpsvn add filename/directorysvn delete filename/directorysvn checkout http://nodename/repos/svn/trunk/parentPath/pathsvn commit --message "Message goes here." filenamesvn diff filenamesvn mkdir directorysvn import local-directory http://node/repos/svn/trunk/directorysvn log filenamesvn merge file1@revJ file2@revKsvn statussvn update filename

Basic operations in subversion

• Where and How? Local Server or Online Server, backups.o VisualSVNo SVN Servero Kenaio Assembla

• File and Directory Organization : o 1 Repository per Project or all Projects in one

Repository?o Trunk , branches, tags

• Choosing Data Storage (Reliability, Accesibility, Scalability, Performance)o Berkely DB – database environmento FSFS – flat files, custom format

Planning Your Repository

What is Project Kenai?Project Kenai is Sun's connected developer destination, where developers can host OPEN SOURCE projects, as well as connect, communicate, and collaborate with developers of like mind.

Cool features:• Forums• Wiki• IM Chat• Code Repository• Netbeans integration

Project Kenai

Demo for SVN Server&Client 

1. Download CollabNet Subversion Server Package and Install it2. Create the repository folder(like D:/svnrepository) and select it as the repository during install Subversion Server(For binary file package. create subversion server manuallyCommand:     sc create svnserve binpath= "    \"C:\Program Files\Subversion\bin\svnserve.exe\"    --service --root c:\repos" displayname= "Subversion"     depend= tcpip start= auto)3. Restart computer and server will start automaticlly4. svnadmin create d:\svnrepository

Demo cont.

5. edit conf,passwd file in svnrepository :o delete comment symbol and following space in o anon-access, auth-access,passw-db in confo [users] in passwd

6. svn mkdir svn://localhost/myproject (server setup finish)7. Install TortoiseSVN client 8. Create a project folder somewhere on your hard drive. Right click in that folder and select "SVN Checkout..."9. type svn://localhost/myproject/ for the repository URL and click OK.10.Create a new file in that directory. Right click the file and select "TortoiseSVN, Add"

Demo cont.

11. The file hasn't actually been checked in yet. Subversion batches any changes and commits them as one atomic operation. To send all your changes to the server, right click and select "SVN Commit"

12.You now have a networked Subversion server and client set up on your machine.

References:1. Setting up a Subversion Server under Windows2.Practical guide to subversion on Windows with TortoiseSVN