svn存储版本数据也有2种方式:BDB和FSFS。因为BDB方式在服务器中断时,有可能锁住数据,所以还是FSFS方式更安全一点
注:
SVN服务器版本库有两种格式,一种为FSFS,一种为BDB
把文件上传到SVN版本库后,上传的文件不再以文件原来的格式存储,而是被svn以它自定义的格式压缩成版本库数据,存放在版本库中。
如果是FSFS格式,这些数据存放在版本库的db目录中,里面的revs和revprops分别存放着每次提交的差异数据和日志等信息
1. svn服务器安装操作系统:CentOS6.0,由于我这是新安装的系统,所以安装svn服务之前我先执行了以下命令:
yum install gcc
yum install expat expat-devel
获取svn安装包
以root用户登录。
将subversion-1.6.17.tar.gz和subversion-deps-1.6.17.tar.gz传到服务器。
tar xfvz subversion-1.6.17.tar.gz
tar xfvz subversion-deps-1.6.17.tar.gz
cd subversion-1.6.17
./configure --prefix=/home/xzp/svn
(注:以svnserve方式运行,不加apache编译参数。以fsfs格式存储版本库,不编译berkeley-db)
make clean
make
make install
vim /etc/profile,在/etc/profile最后加入:
PATH=$PATH:/home/xzp/svn/bin
export PATH
svnserve –version
如果显示如下,svn安装成功:
svnserve, version 1.6.17 (r21228)
compiled Feb 12 2012, 10:18:56Copyright (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_fs : Module for working with a plain file (FSFS) repository.
2. svn配置建立svn版本库目录 可建多个:
mkdir -p /home/xzp/svndata/xingzhenganjian
mkdir -p /home/xzp/svndata/xingshianjian
svnadmin create
svnadmin create
版本库1:
vim
内容修改为:
[general]
anon-access = none
auth-access = write
password-db = /home/xzp/svn/conf/passwd.conf
authz-db = /home/xzp/svn/conf/authz.conf
realm = xingzhenganjian
版本库2:
vim /home/xzp/svndata/xingshianjian/conf/svnserve.conf
内容修改为:
[general]
anon-access = none
auth-access = write
password-db = /home/xzp/svn/conf/passwd.conf
authz-db = /home/xzp/svn/conf/authz.conf
realm = xingshianjian
即除realm = xingshianjian外,其他与版本库1配置文件完全相同。如果有更多的版本库,依此类推。
配置允许访问的svn用户vi /home/xzp/svn/conf/passwd.conf
为了简化配置,2个版本库共用1个用户配置文件。如有必要,也可以分开。
注意:对用户配置文件的修改立即生效,不必重启svn。
文件格式如下:
[users]
<用户1> = <密码1>
<用户2> = <密码2>
其中,[users]是必须的。下面列出要访问svn的用户,每个用户一行。示例:
[users]
xzp= henu_xzp
king = henu_king
vi /home/xzp/svn/conf/authz.conf
为了简化配置,2个版本库共用1个权限配置文件/home/xzp/svn/conf/passwd.conf。如有必要,也可以分开。文件中定义用户组和版本库目录权限。
注意:
* 权限配置文件中出现的用户名必须已在用户配置文件中定义。
* 对权限配置文件的修改立即生效,不必重启svn。
用户组格式:
[groups]
<用户组名> = <用户1>,<用户2>
其中,1个用户组可以包含1个或多个用户,用户间以逗号分隔。
版本库目录格式:
[<版本库>:/项目/目录]
@<用户组名> = <权限>
<用户名> = <权限>
其中,方框号内部分可以有多种写法:
/,表示根目录及以下。根目录是svnserve启动时指定的,我们指定为/home/xzp/svndata。这样,/就是表示对全部版本库设置权限。
xingzhenganjian:/,表示对版本库1设置权限
xingshianjian:/application, ,表示对版本库2中的application项目设置权限
xingshianjian:/abc/aaa, ,表示对版本库2中的abc项目的aaa目录设置权限
权限主体可以是用户组、用户或*,用户组在前面加@,*表示全部用户。权限可以是w、r、wr和空,空表示没有任何权限。
示例:
[groups]
php= xzp,ldm,wfy,king
[/]
@php= rw
[xingzhenganjian:/abc/aaa]
king = rw
[xingshianjian:/pass]
king = r
rm /home/xzp/svndata/xingzhenganjian/conf/authz
rm /home/xzp/svndata/xingzhenganjian/conf/passwd
rm /home/xzp/svndata/xingshianjian/conf/authz
rm /home/xzp/svndata/xingshianjian/conf/passwd
useradd svn
passwd svn
根据提示为用户svn设置密码
chown -R php:users /home/xzp/svndata
su - svn -c “svnserve -d --listen-port 3336 -r /home/xzp/svndata”
其中:
su - svn表示以用户svn的身份启动svn
-d表示以daemon方式(后台运行)运行
--listen-port 3336表示使用3336端口,可以换成你需要的端口。但注意,使用1024以下的端口需要root权限
-r /home/xzp/svndata指定根目录是/home/xzp/svndata
检查:
ps -ef|grep svnserve
如果显示如下,即为启动成功:
svn 6941 1 0 15:07 ? 00:00:00 svnserve -d --listen-port
注:如果以上这些操作用的是root账户,则安装成功后需要重新设置一下版本库下/xingzhenganjian/db的读写权限,否则客户端无法提交
完成配置后,在客户端,选中某个项目后TortiseSVN->import导入到配置的版本库的路径中即可