subversion(以下简称
svn)是近年来崛起的版本管理工具,是cvs的接班人。
svn服务器有2种运行方式:
独立服务器和
借助apache。2种方式各有利弊。
file:///
|
直接版本库访问(本地磁盘)。 |
http://
|
通过配置Subversion的Apache服务器的WebDAV协议。 |
https://
|
与http:// 相似,但是包括SSL加密。 |
svn://
|
通过svnserve 服务自定义的协议。 |
svn+ssh://
|
与svn:// 相似,但通过SSH封装 |
svn存储版本数据也有2种方式:
BDB和
FSFS。因为BDB方式在服务器中断时,有可能锁住数据,所以还是FSFS方式更安全一点。
1.
svn服务器安装操作系统: centos 5.4
获取svn安装包
下载
和
。
编译svn以
root用户登录。
将subversion-1.6.12.tar.gz和subversion-deps-1.6.12.tar.gz传到服务器。
tar
xfvz subversion-1.6.12.tar.gz
tar xfvz subversion-deps-1.6.12.tar.gz
cd
subversion-1.6.12
./configure –prefix=/opt/svn –without-berkeley-db
–with-zlib
(注:以
svnserve方式运行,不加apache编译参数。以
fsfs格式存储版本库,不编译berkeley-db)
make
clean
make
make install
vi
/etc/profile,在/etc/profile最后加入:
PATH=$PATH:/opt/svn/bin
export
PATH
svn测试svnserve –version
如果显示如下,svn安装成功:
svnserve, version 1.6.12 (r955767)
compiled Aug 13 2010, 15:47:15
Copyright (C) 2000-2009 CollabNet.
Subversion is open source software, see
This product includes software developed by CollabNet ().
The following repository back-end (FS) modules are available:
* fs_fs : Module for working with a plain file (FSFS) repository.
Cyrus SASL authentication is available.
2.
svn配置建立svn版本库目录可建多个:
mkdir -p /data/svndata/repos1
mkdir -p/data/svndata/repos2
建立svn版本库svnadmin create /data/svndata/repos1
svnadmin
create /data/svndata/repos2
修改svn版本库配置文件版本库1:
vi /data/svndata/repos1/conf/svnserve.conf
内容修改为:
[general]
anon-access =
none
auth-access = write
password-db = /data/svndata/repos1/conf/passwd (这里也可不加路径)
authz-db
= /data/svndata/repos1/conf/authz
realm = repos1
版本库2:
vi
/opt/svndata/repos2/conf/svnserve.conf
内容修改为:
[general]
anon-access =
none
auth-access = write
password-db = /data/svndata/repos1/conf/passwd
authz-db
= /data/svndata/repos1/conf/authz
realm = repos2
即除realm =
repos2外,其他与版本库1配置文件完全相同。如果有更多的版本库,依此类推。
配置允许访问的svn用户vi /data/svndata/repos1/conf/passwd
为了简化配置,2个版本库共用1个用户配置文件。如有必要,也可以分开。
注意:对用户配置文件的修改立即生效,不必重启svn。
文件格式如下:
[users]
<用户1>
= <密码1>
<用户2> =
<密码2>
其中,[users]是必须的。下面列出要访问svn的用户,每个用户一行。示例:
[users]
pk = pk
配置svn用户访问权限vi
/data/svndata/repos1/conf/authz
为了简化配置,3个版本库共用1个权限配置文件/data/svndata/repos1/conf/passwd。如有必要,也可以分开。文件中定义用户组和版本库目录权限。
注意:*
权限配置文件中出现的用户名必须已在用户配置文件中定义。
*
对权限配置文件的修改立即生效,不必重启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
= pk
[/]
@admin = rw
[repos1:/aaa]
pk =
rw
[repos2:/pass]
pk2 =
svn配置完毕,
3.
启动svn建立启动svn的用户useradd websvn
passwd websvn
根据提示为用户websvn设置密码
允许用户svn访问版本库chown
-R websvn:websvn /data/svndata/
chown -R websvn:websvn /data/svndata/
启动svnsu - websvn -c
"svnserve -d --listen-port 9999 -r /data/svndata/"
其中:
su - websvn表示以用户svn的身份启动svn
-d表示以daemon方式(后台运行)运行
–listen-port
9999表示使用9999端口,可以换成你需要的端口。但注意,使用1024以下的端口需要root权限
-r /data/svndata/指定根目录是/data/svndata/
检查:
ps -ef|grep
svnserve
如果显示如下,即为启动成功:
svn 6941 1 0 15:07 ? 00:00:00 svnserve -d
–listen-port 9999 -r /opt/svndata
但是有时你会访问svn://localhost/repos1 时会拒绝连接,所以在root的用户下在执行一次 svnserve -d -r /data/svndata 下面可以了用那个xp下的客户端进行版本浏览了哦
客户端设置具体参考官方文档:
我就不一一详细介绍了。
svn 与apache 结合 当我们svn更新一个文件后如何才能是web目录获得呢 ?
很简单 见svn的目录checkout 到web目录就okle
如下:
检出 svn 目录 web目录svn checkout file:///data/svndata/repos1/ /var/www/html/
错误1:在编译svn时make 出错svn libsvn_subr-1.so: undefined reference to `sqlite3_open_v2'collect2: ld returned 1 exit status make: *** [subversion/svnadmin/svnadmin] Error 1解决方法: pwd/root/subversion-1.6.12[root@monitor subversion-1.6.12]# mkdir sqlite-amalgamation下载sqlite-amalgamation-3.6.13.tar.gz解压后将cp sqlite-3.6.13/sqlite3.c sqlite-amalgamation下 在重新编译,正常