由于前一段同事需要在内网测试什么东西,需要安装SVN,在网上找些关于SVN的资料,把他们的东西整理了一下,根据自己的环境写的这个文档,难免有想象之处.
svn服务器有2种运行方式:独立服务器和结合apache。
svn存储版本数据也有2种方式:BDB和FSFS。因为BDB方式在服务器中断时,有可能锁住数据,所以还是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.
将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
./configure –prefix=/usr/local/svn -without-berkeley-db -with-zlib
(注:以svnserve方式运行,不加apache编译参数。以fsfs格式存储版本库,不编译berkeley-db)
vi /etc/profile,在/etc/profile最后加入:
svnserve, version 1.4.0 (r21228)
compiled Oct 12 2006, 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.
mkdir -p /home1/svndata/repos
建立svn版本库svnadmin create /home1/svndata/repos
vi /home1/svndata/repos/conf/svnserve.conf
password-db = /home1/svndata/repos/conf/pwd
authz-db = /home1/svndata/repos/conf/authz
配置允许访问的svn用户vi /home1/svndata/repos/conf/pwd
其中,[users]是必须的。下面列出要访问svn的用户,每个用户一行。示例:
配置svn用户访问权限vi /home1/svndata/repos/conf/authz
* 权限配置文件中出现的用户名必须已在用户配置文件中定义。
* 对权限配置文件的修改立即生效,不必重启svn。
其中,1个用户组可以包含1个或多个用户,用户间以逗号分隔。
/,表示根目录及以下。根目录是svnserve启动时指定的,我们指定为/home1/svndata。这样,/就是表示对全部版本库设置权限。
权限主体可以是用户组、用户或*,用户组在前面加@,*表示全部用户。权限可以是w、r、wr和空,空表示没有任何权限。
chown -R svn:svn /home1/svndata
chown –R svn:svn /usr/local/svn
svnserve -d --listen-port 9999 -r /opt/svndata"
-listen-port 9999表示使用9999端口,可以换成你需要的端口。但注意,使用1024以下的端口需要root权限
-r /home1/svndata指定根目录是/home1/svndata
svn 6941 1 0 15:07 ? 00:00:00 svnserve -d –listen-port 9999 -r /opt/svndata
本文转自wiliiwin 51CTO博客,原文链接:http://blog.51cto.com/wiliiwin/199268