linux下svn的安装和配置

《linux 下svn 的安装和配置》一、相关的几个安装包Apr : apr-1.3.8.tar.gz 和 apr-util-1.3.9.tar.gzApache : httpd-2.2.13.tar

《linux 下svn 的安装和配置》

一、相关的几个安装包

Apr : apr-1.3.8.tar.gz 和 apr-util-1.3.9.tar.gz

Apache : httpd-2.2.13.tar.gz

Subversion: subversion-1.5.6.tar.gz 和 subversion-deps-1.5.6tar.gz *说明: SVN 依赖的APR 版本要正确。

Apache 为2.0.x ,对应的APR 版本应为0.9.x ;

Apache 为2.2.x ,对应的APR 版本应为1.2.x 。

二、 安装步骤

1. 安装apr-1.3.8.tar.gz

# tar –zvxf apr-1.3.8.tar.gz (解压)

# cd apr-1.3.8 (进入apr…所在的目录)

# ./configure (安装不指定路径时 默认安装到/usr/local/apr) # make ; # make install (安装)

2. 安装 apr-util-1.3.9.tar.gz

# tar –zvxf apr-util-1.3.9.tar.gz

# cd apr-util-1.3.9

# ./configure - -with-apr=/usr/local/apr

# make ; # make install

3. 安装httpd-2.2.13.tar.gz

# tar xzvf httpd-2.2.6.tar.gz

# cd httpd-2.2.6

# ./configure --prefix=/usr/local/apache2

--enable-dav

--enable-modules=so

--enable-maintainer-mode

--enable-rewrite

--with-apr=/usr/local/apr/bin/apr-1-config

--with-apr-util=/usr/local/apr/bin/apu-1-config

# make # make install

,

安装之后重新启动apache 服务:# /usr/local/apache2/bin/apachectl –k start / restart * apache的默认端口为80(更改端口号:/etc/…/)

4. 安装subversion

# tar –zvxf subversion-1.5.6.tar.gz

# tar –zvxf subversion-deps-1.5.6.tar.gz (这两个自动解压成一个包 subversion-1.5.6) # cd subversion-1.5.6

(如果linux 系统上已经装有apr 或者apr-util ,移除 apr 存在的版本,

subversion 解压 后的文件里有apr 相关的文件,需要移除)

# rm –rf apr

# rm -rf apr-util

说明:由于subversion-deps 包里的APR 是0.9.x 的,

因此编译svn 时要删除从deps 里解压出来的apr, apr-util,改而使用apache 2.2里提供的

# cd subversion-1.5.6

#./configure

--with-apxs=/usr/local/apache2/bin/apxs

--prefix=/usr/local/svn

--with-apr=/usr/local/apr/bin/apr-1-config

--with-apr-util=/usr/local/apr/bin/apu-1-config

--with-ssl

--with-zlib

--enable-maintainer-mode

#make ; #make install

(如果apache 不是安装在默认路径,configure 必須加上--with-apxs 选项, 如:./configure

--with-apxs=/usr/local/apache2/bin/apxs)

* configure可能存在的问题及解决方法

1. configure: error: could not find library containing RSA_new

-- yum install openssl-devel

2. configure: error: no XML parser was found: expat or libxml 2.x required

-- yum install expat-devel

3. configure: error: --with-zlib requires an argument.

-- 去掉此选项。

(如果: 执行了configure,make 后 make install时出错:

/bin/sh /usr/local/httpd-2.2.3/srclib/apr/libtool --mode=install /usr/bin/install -c -m 755 libaprutil-1.la /usr/local/apache2/lib

,

libtool: install: error: cannot install `libaprutil-1.la' to a directory not ending in /usr/local/apache22/lib

make[2]: *** [install] Error 1

则在./configure 后

make clean

make

make install

确定一下svn 有没有安装成功

# /usr/local/svn/bin/svnserve --version

# vi /usr/local/apache2/conf/httpd.conf

看到下面两个模块说明安装成功

LoadModule dav_svn_module modules/mod_dav_svn.so

LoadModule authz_svn_module modules/mod_authz_svn.so

5. 开始建立版本库

/usr/local/svn/bin/svnadmin create /svn/project/www (创建仓库"www" )

ls /svn/project/www (查看有没有创建好, 如果多了一些文件则说明版本库已经创建好) (如果出现“无法创建顶级目录”的错误,请先

cd /

mkdir svn

)

导入项目文件到版本库

/usr/local/svn/bin/svn import /home/test file:///svn/project/www -m "init"

这条语句将把路径/share/www下找到的项目文件导入到你创建的/svn/project/www 仓库中去,提交后的修订版为1

配置提高svn 版本库的安全性

chmod –R 700 /svn/project/www (不让其他人有该目录的权限)

注意:直接这么chmod 会导致svn 客户端无法访问, 同时需要修改apache 配置文件./conf/httpd.conf文件,(如果你的水平不够高的话, 这一步可以先跳过, 以免给自己找麻烦! 等把服务完全搞定后再来进一步提高安全性) 在httpd.conf 文件中有这么一段内容: User daemon

Group daemon

,

把上述内容改成:

User apache

Group apache

(我的系统在安装apache 的时候, 自动增加了apache 用户和apache 组, 如果你系统没有这个用户和组, 则请自己添加该用户和组)

修改svn 仓库的所有者

chown -R apache:apache /svn/project

6. Apache配置:

配置步骤

1 单资源库,如果打算只建立一个资源库,用这种方式。打开命令提示符,输入svnadmin create E:ResourcesSVNRepositories�A,回车。其中

E:ResourcesSVNRepositories�A为你的资源库路径。

2 多资源库,如果要创建多个资源库,用这种方式。打开命令提示符,输入svnadmin create E:ResourcesSVNRepositories�A,回车;输入三vsndmin

create E:ResourcesSVNRepositories�B,回车...

首先应保证Apache 能正常运行。将SVN 根目录的bin 目录下的mod_dav_svn.so和 mod_authz_svn.so两个文件拷贝到Apache 根目录下的modules 目录下;

打开Apache 配置文件httpd.conf ,找到

#LoadModule dav_fs_module modules/mod_dav_fs.so

#LoadModule dav_module modules/mod_dav.so

将前面的#去掉,并添加两行:

LoadModule dav_svn_module modules/mod_dav_svn.so

LoadModule authz_svn_module modules/mod_authz_svn.so

在文件末尾加上

如果是单资源库:

DAV svn

SVNPath E:¥Resources¥SVN¥Repositories

AuthType Basic

AuthName "Subversion Reporsitory"

,

AuthUserFile E:¥Resources¥SVN¥conf¥passwd

AuthzSVNAccessFile E:¥Resources¥SVN¥conf¥authz

Require valid-user

如果是多资源库:

DAV svn

SVNListParentPath on

SVNParentPath E:¥Resources¥SVN¥Repositories

AuthType Basic

AuthName "Subversion Reporsitory"

AuthUserFile E:¥Resources¥SVN¥conf¥passwd

AuthzSVNAccessFile E:¥Resources¥SVN¥conf¥authz

Require valid-user

( 其中:是指SVN 服务的实例路径,需要用的方式才可以访问;E:¥Resources¥SVN¥Repositories 是资源库主目录;E:¥Resources¥SVN¥conf 是存放用户文件和权限文件的目录;E:¥Resources¥SVN¥conf¥passwd 就是存放用户信息的文件,它是一个没有后缀的文件,用Apache 的htpasswd.exe 来维护,负责将用户的密码用MD5加密成暗文;E:¥Resources¥SVN¥conf¥authz 就是存放访问权限的文件,它也是一个没有后缀的文本文件可以用文本工具直接编辑;AuthType Basic是认证类型,此处采用基本类型,即采用用户名 密码的方式;AuthName "Subversion Reporsitory"是指认证时代表示,起到提示作用;Require valid-user表示SVN 必须提供用户和密码才可以访问,不能匿名登录

重启Apache ,查看Apache Service Monitor状态栏是否包含“SVN/1.6.0 DAV/2”字样。在浏览器中输入http://******/svn/(其中******为你的主机域名地址或者IP 地址),验证配置。)

方法1:配置svn 权限管理

1). 添加用户:

# /usr/local/apache/bin/htpasswd –c /svn/passwd user1

第一次设置用户时使用-c 表示新建一个用户文件。回车后输入用户密码,完成对用户的增加, 第二次添加用户不需要带-c 参数

2). 权限分配:

vi /svn/auth.conf (进入文件auth.conf ,对其进行编辑)

,

[groups]

Admin=usr1,user2 (这个表示admin 群组里的成员 user1,user2)

Develop=u1, u2 (这个表示Develop 群组里的成员 u1,u2)

[www:/] (这表示,仓库www 的根目录下的访问权限)

user1 = rw (www 仓库user1用户具有读和写权限)

user2 = r ( www 仓库userl 用户具只有读权限)

@develop=rw (这表示 群 develop 的成员都具有读写权限)

[/] (这个表示在所有仓库的根目录下)

* = r (这个表示对所有的用户都具有读权限)

注意:在编辑authz.conf 文件时,所有行都必须要顶头写,否则会报错

3). 配置提高svn 版本库的安全性

chmod –R 700 /svn/project/www (不让其他人有该目录的权限)

注意:直接这么chmod 会导致svn 客户端无法访问, 同时需要修改apache 配置文件./conf/httpd.conf文件, 在httpd.conf 文件中有这么一段内容:

User daemon

Group daemon

把上述内容改成:

User apache

Group apache

(我的系统在安装apache 的时候, 自动增加了apache 用户和apache 组, 如果你系统没有这个用户和组, 则请自己添加该用户和组)

修改svn 仓库的所有者

chown -R apache:apache /svn/project

方法2:配置svn 权限管理(即authz.conf 的配置)

1. 添加用户:

/usr/local/apache/bin/htpasswd –c /svn/passwd user1

第一次设置用户时使用-c 表示新建一个用户文件。回车后输入用户密码,完成对用户的增加,第二次添加用户不需要带-c 参数

2. 权限分配:

vi /svn/auth.conf (进入文件auth.conf ,对其进行编辑)

,

[groups]

Admin=usr1,user2 (这个表示admin 群组里的成员 user1,user2)

Develop=u1, u2 (这个表示Develop 群组里的成员 u1,u2)

[www:/] (这表示,仓库www 的根目录下的访问权限)

user1 = rw (www 仓库user1用户具有读和写权限)

user2 = r ( www 仓库userl 用户具只有读权限)

@develop=rw (这表示 群 develop 的成员都具有读写权限)

[/] (这个表示在所有仓库的根目录下)

* = r (这个表示对所有的用户都具有读权限)

注意:在编辑authz.conf 文件时,所有行都必须要顶头写,否则会报错

7、重启apache 服务和启动svn 服务

/usr/local/apache/bin/apachectl –k restart

就可以通过 http://192.168.18.110/svn/project/www 这个URL 来访问仓库了,当然,受权限的限制,必须是合法用户才能访问且具有相应的权限

客户端

windows 客户端用TortoiseSVN-1.4.4.9706-win32-svn-1.4.4.msi 也许有更高版本,我没有测试

Eclipse 插件:software update > url=http://subclipse.tigris.org/update_1.0.x

注意:

如果输入用户名密码后出现:

Could not open the request SVN filesystem

请检查你的/usr/local/apache/conf/httpd.conf 是否正确

如果客户端出现:

org.tigris.subversion.javahl.clientexception ra layer request failed

请检查你的url.username password

如果系统时间和现实时间相差太大,可能会导致安装出问题,修改系统时间的命令: Date –s (修改linux 系统时间)

,

访问过程中出现的两个问题:

1. svn: Can‟t create directory „/subversion/main/db/transactions/0-1.txn‟: Permission denied

解答:设置svn 配置库库文件夹的权限(chmod -R 777 /svn/project/www) 2. Error: 服务器发送了意外的返回值(403 Forbidden),在响应 “CHECKOUT” 的请求

[Linux]svn服务的安装和启动设置

在CentOS 系统下,使用以下命令进行SVN 服务的安装

# yum -y install subversion

安装完毕后,svnserve 服务就被添加到了系统的自动启动进程里面,但是尚未开启,所以依然无法随系统自动启动服务。为了安全起见,我们需要修改SVN 服务端口,及自定义版本库所在目录。所以需要对以下文件进行相应的修改。

# vi /etc/rc.d/init.d/svnserve

找到以下内容

pidfile=${PIDFILE-/var/run/svnserve.pid}

lockfile=${LOCKFILE-/var/lock/subsys/svnserve}

args="--daemon --pid-file=${pidfile} $OPTIONS"

修改为

pidfile=${PIDFILE-/var/run/svnserve.pid}

lockfile=${LOCKFILE-/var/lock/subsys/svnserve}

logfile=/var/log/svnserve.log

args="--daemon --root /storage/repos --listen-port 621 --pid-file=${pidfile} --log-file=${logfile} $OPTIONS"

--root 是版本库所在的目录

--listen-port 是SVN 服务端口号

--log-file 是SVN 日志文件

修改完成后使用以下命令将自动跟随系统启动功能进行激活

# chkconfig svnserve on

也可以使用以下方式进行手工操作

# service svnserve start 启动服务

# service svnserve stop 停止服务

# service svnserve restart 重启服务

标签: