sudo mkdir /home/svn
sudo svnadmin create /home/svn/dev
# change ownership
sudo chown -R subversion:www-data /home/svn/dev
# make the dir group write-able
chmod -R g+w /home/svn/dev/
# add yourself to the www-data group
sudo usermod -a -G www-data alan
sudo apt-get install apache2
sudo apt-get install libapache2-svn
sudo nano /etc/apache2/mods-available/dav_svn.conf
add at the end:
DAV svn
SVNParentPath /home/svn
SVNListParentPath On
AuthType Basic
AuthName "Subversion Repository"
# AuthUserFile /etc/subversion/passwd
Require valid-user
Save.
sudo /etc/init.d/apache2 restart
# Add your users in subversion, create their accounts:
sudo nano /home/svn/dev/conf/passwd
alan=123456
mary=654321
# For subversion over http, also add the same users to the
# subversion passwd file, first time use -c to "create" it.
sudo htpasswd -c /etc/subversion/passwd alan
sudo htpasswd /etc/subversion/passwd mary
# Empty out config file
sudo su -
echo "" > /home/svn/dev/conf/svnserve.conf
# Edit file and add next entries:
sudo -u subversion nano /home/svn/dev/conf/svnserve.conf
[general]
anon-access = none
auth-access = write
password-db = passwd
realm = digitalagora
[sasl]
# Save, exit.
# Install xinetd, and let it take care of running the subversion server
sudo apt-get install xinetd
# edit a new svn file
sudo nano /etc/xinetd.d/svn
# Paste these contents:
service svn
{
port = 3690
protocol = tcp
socket_type = stream
wait = no
disable = no
user = subversion
server = /usr/bin/svnserve
server_args = -i -r /home/svn/dev
#ALAN - increase incoming connections per second
# X connections per second, 1 sec to reset after overload
cps = 3000 1
# if in /var/log/messages you see: FAIL: svn per_source_limit from=IP...
per_source = UNLIMITED
}
# Save the file, exit.
# start the xinetd service
sudo service xinetd restart
# check that subversion is running, you should not get an error from this command (use your
username/pass)
svn --non-interactive --username alan --password abc12345 list svn://localhost/
# ===================================================
# ALTERNATIVELY, IF YOU DO NOT WANT TO USE XINETD:
# Start the server manually...
svnserve -d -r /home/svn/
#
# Check that it's running
ps aux | grep svn
#
You should see something like: svnserve -d -r /home/svn/
# to stop svnserve, run
ps aux | grep svn
killall svnserve
ps aux | grep svn
# ===================================================
Test the installation
# create project
svn --non-interactive --username alan --password abc12345 -m "new" mkdir
svn://localhost/dev/testproject
# check out project
cd ~
svn --non-interactive --username alan --password myPassw0rd checkout
svn://localhost/dev/testproject
# create new files in checked out project
touch ~/testproject/newfile1.txt
touch ~/testproject/newfile2.txt
touch ~/testproject/newfile3.txt
# go into project
cd ~/testproject
svn add *
# commit the files
svn commit -m "new" *
Adding newfile1.txt
Adding newfile2.txt
Adding newfile3.txt
Transmitting file data ...
Committed revision 2.
=================================
a2ensite default-ssl
a2enmod ssl
sudo /etc/init.d/apache2 restart
sudo make-ssl-cert generate-default-snakeoil --force-overwrite
=================================
Check that it's working:
http://localhost/
No comments:
Post a Comment