178 lines
		
	
	
	
		
			5 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			178 lines
		
	
	
	
		
			5 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| ---
 | ||
| title: How to Install and Configure Subversion (SVN) Server on Ubuntu
 | ||
| date: 2011-10-19
 | ||
| excerpt: How to install and configure your own SVN server.
 | ||
| tags:
 | ||
|     - svn
 | ||
|     - ubuntu
 | ||
|     - version-control
 | ||
| ---
 | ||
| 
 | ||
| Recently, I needed to set up a Subversion (SVN) server on a Ubuntu Linux server.
 | ||
| This post is going to outline the steps taken, and the commands used, to install
 | ||
| and configure the service.
 | ||
| 
 | ||
| Note: As I was using Ubuntu, I was using the 'apt-get' command to download and
 | ||
| install the software packages. If you're using a different distribution of
 | ||
| Linux, then this command may be different. I'm also assuming that Apache is
 | ||
| already installed.
 | ||
| 
 | ||
| Firstly, I'm going to ensure that all of my installed packages are up to date,
 | ||
| and install any available updates.
 | ||
| 
 | ||
| ```language-bash
 | ||
| $ sudo apt-get update
 | ||
| ```
 | ||
| 
 | ||
| Now, I need to download the subversion, subversion-tools and libapache2
 | ||
| packages.
 | ||
| 
 | ||
| ```language-bash
 | ||
| $ sudo apt-get install subversion subversion-tools libapache2-svn
 | ||
| ```
 | ||
| 
 | ||
| These are all of the packages that are needed to run a Subversion server.
 | ||
| 
 | ||
| ## Create subversion directory
 | ||
| 
 | ||
| Now, I need to create the directory where my repositories are going to sit. I've
 | ||
| chosen this directory as I know that it's one that is accessible to my managed
 | ||
| backup service.
 | ||
| 
 | ||
| ```language-bash
 | ||
| $ sudo mkdir /home/svn
 | ||
| ```
 | ||
| 
 | ||
| ## Create a test repository
 | ||
| 
 | ||
| First, I'll create a new folder in which I'll create my test project, and then
 | ||
| I'll create a repository for it.
 | ||
| 
 | ||
| ```language-bash
 | ||
| $ sudo mkdir ~/test
 | ||
| $ sudo svnadmin create /home/svn/test -m 'initial project structure'
 | ||
| ```
 | ||
| 
 | ||
| This will create a new repository containing the base file structure.
 | ||
| 
 | ||
| ## Adding files into the test project
 | ||
| 
 | ||
| ```language-bash
 | ||
| $ cd ~/test
 | ||
| $ mkdir trunk tags branches
 | ||
| ```
 | ||
| 
 | ||
| I can now import these new directories into the test repository.
 | ||
| 
 | ||
| ```language-bash
 | ||
| $ sudo svn import ~/test file:///home/svn/test -m 'Initial project directories'
 | ||
| ```
 | ||
| 
 | ||
| This both adds and commits these new directories into the repository.
 | ||
| 
 | ||
| In order for Apache to access the SVN repositories, the `/home/svn` directory
 | ||
| needs to be owned by the same user and group that Apache runs as. In Ubuntu,
 | ||
| this is usually www-data. To change the owner of a directory, use the chown
 | ||
| command.
 | ||
| 
 | ||
| ```language-bash
 | ||
| $ sudo chown -R www-data:www-data /home/svn
 | ||
| ```
 | ||
| 
 | ||
| ## Configuring Apache
 | ||
| 
 | ||
| The first thing that I need to do is enable the dav_svn Apache module, using the
 | ||
| a2enmod command.
 | ||
| 
 | ||
| ```language-bash
 | ||
| $ sudo a2enmod dav_svn
 | ||
| ```
 | ||
| 
 | ||
| With this enabled, now I need to modify the Apache configuration file.
 | ||
| 
 | ||
| ```language-bash
 | ||
| $ cd /etc/apache2
 | ||
| $ sudo nano apache2.conf
 | ||
| ```
 | ||
| 
 | ||
| At the bottom of the file, add the following lines, and then save the file by
 | ||
| pressing Ctrl+X.
 | ||
| 
 | ||
| ```language-apacheconf
 | ||
| <Location "/svn">
 | ||
|   DAV svn
 | ||
|   SVNParentPath /home/svn
 | ||
| </Location>
 | ||
| ```
 | ||
| 
 | ||
| With this saved, restart the Apache service for the changes to be applied.
 | ||
| 
 | ||
| ```language-bash
 | ||
| sudo service apache2 restart
 | ||
| ```
 | ||
| 
 | ||
| I can now browse through my test repository by opening Firefox, and navigating
 | ||
| to `http://127.0.0.1/svn/test`. Here, I can now see my three directories,
 | ||
| although they are currently all empty.
 | ||
| 
 | ||
| ## Securing my SVN repositories
 | ||
| 
 | ||
| Before I start committing any files to the test repository, I want to ensure
 | ||
| that only authorised users can view it - currently anyone can view the
 | ||
| repository and it's contents, as well as being able to checkout and commit
 | ||
| files. To do this, I'm going to require the user to enter a username and a
 | ||
| password before viewing or performing any actions with the repository.
 | ||
| 
 | ||
| Re-open apache2.conf, and replace the SVN Location information with this:
 | ||
| 
 | ||
| ```language-apacheconf
 | ||
| <Location "/svn">
 | ||
|   DAV svn
 | ||
|   SVNParentPath /home/svn
 | ||
|   AuthType Basic
 | ||
|   AuthName "My SVN Repositories"
 | ||
|   AuthUserFile /etc/svn-auth
 | ||
|   Require valid-user
 | ||
| </Location>
 | ||
| ```
 | ||
| 
 | ||
| Now I need to create the password file.
 | ||
| 
 | ||
| ```language-bash
 | ||
| $ htpasswd -cm /etc/svn-auth oliver
 | ||
| ```
 | ||
| 
 | ||
| I'm prompted to enter and confirm my password, and then my details are saved.
 | ||
| The Apache service will need to be restarted again, and then the user will need
 | ||
| to authenticate themselves before viewing the repositories.
 | ||
| 
 | ||
| ## Checking out the repository and commiting files
 | ||
| 
 | ||
| For example, now want to checkout the files within my repository into a new
 | ||
| directory called 'test2' within my home directory. Firstly, I need to create the
 | ||
| new directory, and then I can issue the checkout command.
 | ||
| 
 | ||
| ```language-bash
 | ||
| $ cd ~
 | ||
| $ mkdir test2
 | ||
| $ svn checkout http://127.0.0.1/svn/test/trunk test2
 | ||
| ```
 | ||
| 
 | ||
| I'm passing the command two arguments - the first is the URL of the repository's
 | ||
| trunk directory, and the second is the directory where the files are to be
 | ||
| placed. As no files have been commited yet into the trunk, it appears to be
 | ||
| empty - but if you perform an ls -la command, you'll see that there is a hidden
 | ||
| .svn directory.
 | ||
| 
 | ||
| Now you can start adding files into the directory. Once you've created your
 | ||
| files, perform a svn add command, passing in individual filenames as further
 | ||
| arguments.
 | ||
| 
 | ||
| ```language-bash
 | ||
| $ svn add index.php
 | ||
| $ svn add *
 | ||
| ```
 | ||
| 
 | ||
| With all the required files added, they can be committed using
 | ||
| `svn commit -m 'commit message'` command, and the server can be updated using
 | ||
| the svn up command.
 |