svn服务器的服务配置有3种方式:apache+mod_dav+svn、svnserve和穿越SSH隧道的svnserve服务器。应该用什么服务器,每个团队都有不同的需要,不同的服务器都有不同的代价。
svn的运行主要有两种方式:独立服务器 和 借助apache。
本文主要介绍安装配置svn独立服务器的步骤。svn客户端操作见svn客户端TortoiseSVN安装配置和操作手册。
svn存储版本数据也有2种方式:BDB和FSFS。在subversion1.2版本之前,默认的存储版本数据是BDB方式,之后是FSFS方式了,因为BDB方式在服务器中断时,有可能锁住数据,所以还是FSFS方式更安全一点。
一. svn服务器安装
操作系统: GNU/ubuntu linux 12.04LTS
1 获取svn安装包
最新版本subversion可以在http://subversion.tigris.org/getting.html 下载。
2 编译svn
以root用户登录。
将subversion-1.6.18.tar.gz和subversion-deps-1.6.18.tar.gz传到服务器。
tar -xfvz subversion-1.6.18.tar.gz
tar -xfvz subversion-deps-1.6.18.tar.gz
cd subversion-1.6.18
./configure --prefix=/usr/local/svn –without-berkeley-db –with-zlib
(注:以svnserve方式运行,不加apache编译参数。以fsfs格式存储版本库,不编译berkeley-db)
make clean
make
make install
vi /etc/profile(linux系统下的环境变量文件),在/etc/profile最后加入:
PATH=$PATH:/usr/local/svn/bin
export PATH
3 svn测试
svnserve –version
如果显示如下,svn安装成功:
svnserve,版本 1.4.2 (r22196)
编译于 Aug 5 2009,19:02:07
Copyright (C) 2000-2006 CollabNet.
Subversion is open source software, see http://subversion.tigris.org/
This product includes software developed by CollabNet (http://www.Collab.Net/).
The following repository back-end (FS) modules are available:
* fs_base : 模块与伯克利数据库(Berkeley DB)档案库一起工作。
* fs_fs : 模块与纯文本文件(FSFS)档案库一起工作。
二. svn配置
1 建立svn版本库目录
可建多个:
mkdir -p /opt/svndata/repos1
mkdir -p /opt/svndata/repos2
mkdir -p /home/webapps/svndata
2 建立svn版本库
svnadmin create /opt/svndata/repos1
svnadmin create /opt/svndata/repos2
svnadmin create /home/webapps/svndata/repos
在创建版本库的时候,可以通过使用--fs-type参数来指定版本库的存储数据格式,比如svnadmin create --fs-type fsfs /home/webapps/svndata/repos
运行这个命令后,你就有了一个版本库,就可以往版本库里导入数据了。
3 修改svn版本库认证方式配置文件(svnserve.conf文件)
版本库1:
vi /opt/svndata/repos1/conf/svnserve.conf
内容修改为:
[general]
anon-access = none
auth-access = write
password-db = /opt/svn/conf/pwd.conf
authz-db = /opt/svn/conf/authz.conf
realm = repos1
版本库2:
vi /opt/svndata/repos2/conf/svnserve.conf
内容修改为:
[general]
anon-access = none
auth-access = write
password-db = /opt/svn/conf/pwd.conf
authz-db = /opt/svn/conf/authz.conf
realm = repos2
即除realm = repos2外,其他与版本库1配置文件完全相同。如果有更多的版本库,依此类推。
4 配置允许访问的svn用户(passwd文件)
vi /opt/svn/conf/pwd.conf
为了简化配置,2个版本库共用1个用户配置文件。如有必要,也可以分开。
注意:对用户配置文件的修改立即生效,不必重启svn。
文件格式如下:
[users]
<用户1> = <密码1>
<用户2> = <密码2>
其中,[users]是必须的。下面列出要访问svn的用户,每个用户一行。示例:
[users]
alan = password
king = hello
5 配置svn用户访问权限(authz文件)
vi /opt/svn/conf/authz.conf
为了简化配置,3个版本库共用1个权限配置文件/opt/svn/conf/authz.conf。如有必要,也可以分开。文件中定义用户组和版本库目录权限。
注意:
* 权限配置文件中出现的用户名必须已在用户配置文件中定义。
* 对权限配置文件的修改立即生效,不必重启svn。
用户组格式:
[groups]
<用户组名> = <用户1>,<用户2>
其中,1个用户组可以包含1个或多个用户,用户间以逗号分隔。
版本库目录格式:
[<版本库>:/项目/目录]
@<用户组名> = <权限>
<用户名> = <权限>
其中,方框号内部分可以有多种写法:
/,表示根目录及以下。根目录是svnserve启动时指定的,我们指定为/opt/svndata。这样,/就是表示对全部版本库设置权限。
repos1:/,表示对版本库1设置权限
repos2:/abc, ,表示对版本库2中的abc项目设置权限
repos2:/abc/aaa, ,表示对版本库2中的abc项目的aaa目录设置权限
权限主体可以是用户组、用户或*,用户组在前面加@,*表示全部用户。权限可以是w、r、wr和空,空表示没有任何权限。
示例:
[groups]
admin = alan
[/]
@admin = rw
[repos1:/abc/aaa]
king = rw
[repos2:/pass]
king =
6 svn配置完毕,删除无用文件
rm /opt/svndata/repos1/conf/authz
rm /opt/svndata/repos1/conf/passwd
rm /opt/svndata/repos2/conf/authz
rm /opt/svndata/repos2/conf/passwd
以上文件是各个版本库中的用户文件 和 权限配置文件,因为在以上配置中都使用了/opt/svn/conf/目录中的配置文件,所以这里可以删除各版本库中的相应配置文件。
三. 启动svn
1 建立启动svn的用户
useradd svn
passwd svn
根据提示为用户svn设置密码
2 允许用户svn访问版本库
chown -R svn:svn /opt/svndata
3 启动svn
su - svn -c "svnserve -d –listen-port 9999 -r /opt/svndata"
其中:
su - svn表示以用户svn的身份启动svn
-d表示以daemon方式(后台运行)运行
–listen-port 9999表示使用9999端口,可以换成你需要的端口。但注意,使用1024以下的端口需要root权限
-r /opt/svndata指定根目录是/opt/svndata
4 检查:
ps -ef | grep svnserve
如果显示如下,即为启动成功:
svn 2417 1 0 2012 ? 00:00:00 svnserve -d --listen-port 9999 -r /opt/svndata
通过web方式访问svn有很多方法,请参阅配置websvn或配置bsSvnBrowser的方法。