UML软件工程组织

 

 

在RedHat AS下安装配置SVN管理工具
 
2008-05-23 出处:svn8.com
 

subversion(以下简称SVN)是近年来崛起的版本管理工具,是CVS的接班人。

SVN服务器有2种运行方式:独立服务器和借助apache。2种方式各有利弊。

SVN存储版本数据也有2种方式:BDB和FSFS。因为BDB方式在服务器中断时,有可能锁住数据(我在搞ldap时就深受其害,没法根治),所以还是FSFS方式更安全一点。

1. SVN服务器安装

操作系统: Redhat Linux AS4

安装包获取:

下载http://subversion.tigris.org/downloads/subversion-1.4.0.tar.gz和http: //subversion.tigris.org/downloads/subversion-deps-1.4.0.tar.gz。

编译:

以root用户登录。

将subversion-1.4.0.tar.gz和subversion-deps-1.4.0.tar.gz传到服务器。

tar xfvz subversion-1.4.0.tar.gz

tar xfvz subversion-deps-1.4.0.tar.gz

cd subversion-1.4.0

./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

测试:

SVNserve –version

如果显示如下,安装成功:

SVNserve, version 1.4.0 (r21228)

compiled Oct 12 2006, 10:18:56

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_fs : Module for working with a plain file (FSFS) repository.

2. SVN配置

建立版本库目录,可建多个:

mkdir -p /opt/SVNdata/repos1

mkdir -p /opt/SVNdata/repos2

建立版本库:

SVNadmin create /opt/SVNdata/repos1

SVNadmin create /opt/SVNdata/repos2

修改版本库配置文件:

版本库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配置文件完全相同。如果有更多的版本库,依此类推。

配置允许访问的用户:

vi /opt/SVN/conf/pwd.conf

为了简化配置,2个版本库共用1个用户配置文件。如有必要,也可以分开。

注意:对用户配置文件的修改立即生效,不必重启SVN。

文件格式如下:

[users]

<用户1> = <密码1>

<用户2> = <密码2>

其中,[users]是必须的。下面列出要访问SVN的用户,每个用户一行。示例:

[users]

alan = password

king = hello

配置用户访问权限:

vi /opt/SVN/conf/authz.conf

为了简化配置,3个版本库共用1个权限配置文件/opt/SVN/conf/pwd.conf。如有必要,也可以分开。文件中定义用户组和版本库目录权限。

注意:

* 权限配置文件中出现的用户名必须已在用户配置文件中定义。

* 对权限配置文件的修改立即生效,不必重启SVN。

用户组格式:

[groups]

<用户组名> = <用户1>,<用户2>

其中,1个用户组可以包含1个或多个用户,用户间以逗号分隔。

版本库目录格式:

[<版本库>:/项目/目录]

@<用户组名> = <权限>

<用户名> = <权限>

其中,方框号内部分可以有多种写法:

/,表示根目录及以下。根目录是SVNserve启动时指定的,我们指定为/opt/SVNdata。这样,/就是表示对全部版本库设置权限。

repos1:/,表示对版本库1设置权限

repos2:/occi, ,表示对版本库2中的occi项目设置权限

repos2:/occi/aaa, ,表示对版本库2中的occi项目的aaa目录设置权限

权限主体可以是用户组、用户或*,用户组在前面加@,*表示全部用户。权限可以是w、r、wr和空,空表示没有任何权限。

2. SVN配置

建立版本库目录,可建多个:

mkdir -p /opt/SVNdata/repos1

mkdir -p /opt/SVNdata/repos2

建立版本库:

SVNadmin create /opt/SVNdata/repos1

SVNadmin create /opt/SVNdata/repos2

修改版本库配置文件:

版本库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配置文件完全相同。如果有更多的版本库,依此类推。

配置允许访问的用户:

vi /opt/SVN/conf/pwd.conf

为了简化配置,2个版本库共用1个用户配置文件。如有必要,也可以分开。

注意:对用户配置文件的修改立即生效,不必重启SVN。

文件格式如下:

[users]

<用户1> = <密码1>

<用户2> = <密码2>

其中,[users]是必须的。下面列出要访问SVN的用户,每个用户一行。示例:

[users]

alan = password

king = hello

配置用户访问权限:

vi /opt/SVN/conf/authz.conf

为了简化配置,3个版本库共用1个权限配置文件/opt/SVN/conf/pwd.conf。如有必要,也可以分开。文件中定义用户组和版本库目录权限。

注意:

* 权限配置文件中出现的用户名必须已在用户配置文件中定义。

* 对权限配置文件的修改立即生效,不必重启SVN。

用户组格式:

[groups]

<用户组名> = <用户1>,<用户2>

其中,1个用户组可以包含1个或多个用户,用户间以逗号分隔。

版本库目录格式:

[<版本库>:/项目/目录]

@<用户组名> = <权限>

<用户名> = <权限>

其中,方框号内部分可以有多种写法:

/,表示根目录及以下。根目录是SVNserve启动时指定的,我们指定为/opt/SVNdata。这样,/就是表示对全部版本库设置权限。

repos1:/,表示对版本库1设置权限

repos2:/occi, ,表示对版本库2中的occi项目设置权限

repos2:/occi/aaa, ,表示对版本库2中的occi项目的aaa目录设置权限

权限主体可以是用户组、用户或*,用户组在前面加@,*表示全部用户。权限可以是w、r、wr和空,空表示没有任何权限。

示例:

[groups]

admin = alan

[/]

@admin = rw

[repos1:/occi/aaa]

king = rw

[repos2:/pass]

king =

删除无用文件:

rm /opt/SVNdata/repos1/conf/authz

rm /opt/SVNdata/repos1/conf/passwd

rm /opt/SVNdata/repos2/conf/authz

rm /opt/SVNdata/repos2/conf/passwd

3. 启动SVN

建立启动SVN的用户:

useradd SVN

passwd SVN

根据提示为用户SVN设置密码

允许用户SVN访问版本库:

chown –R SVN:SVN /opt/SVNdata

chown –R SVN:SVN /opt/data

启动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

检查:

ps –ef|grep SVNserve

如果显示如下,即为启动成功:

SVN    6941   1 0 15:07 ?    00:00:00 SVNserve -d --listen-port 9999 -r /opt/SVNdata

4. 以服务方式启动SVN

在文件/etc/services

添加一行:

SVN 3690/tcp # SVN

在文件夹/etc/xinetd.d/创建文件SVN,内容为

service vnc

{

disable = no

socket_type = stream

protocol = tcp

wait = no

user = root

server = /usr/local/bin/SVNserve

server_args = -i -r /opt/SVNdata

}

运行/etc/rc.d/init.d/xinetd restart

使上面的配置生效。

通过whereis可以查找文件的位置

 

组织简介 | 联系我们 |   Copyright 2002 ®  UML软件工程组织 京ICP备10020922号

京公海网安备110108001071号