日期:2014-05-16  浏览次数:20689 次

Subversion和Apache搭建版本控制环境
    首先拷贝 SVN 安装路径 bin 目录中的 mod_dav_svn.so 文件至 Apache 安装路径的 modules 目录下。
    接下来就是配置 Apache 的 httpd.conf 文件,让 Apache 在启动的时候加载上述模块。
需要添加的内容如下:
LoadModule dav_module modules/mod_dav.so
LoadModule dav_svn_module modules/mod_dav_svn.so
<Location /repos>
  DAV svn
  SVNPath D:/svn/repos
</Location>

    重新启动 Apache ,打开浏览器,输入 http://服务器IP/repos 来访问版本库。

------------------------

    如果想要指定多个版本库,可以用多个 Location 标签,也可以使用 SVNParentPath 代替 SVNPath ,例如在 D:/svn 下有多个版本库 repos1 , repos2 等等,用如下方式指定:
<Location /svn>
  DAV svn
  SVNParentPath D:/svn
</Location>

    "SVNParentPath D:/svn" 表示 D:/svn 下的每个子目录都是一个版本库。可以通过 http://服务器IP/svn/repos1 , http://服务器IP/svn/repos2 来访问。

------------------------

    现在你的版本库任何人都可以访问,并且有完全的写操作权限。也就是说任何人都可以匿名读取,修改,提交,以及删除版本库中的内容。显然大部分场合这是不符合需求的。那么如何进行权限设置呢, Apache 提供了基本的权限设置:
    首先需要创建一个用户文件。 Apache 提供了一个工具 htpasswd ,用于生成用户文件,可以在 Apache 的安装目录下找到。具体使用方法如下:
htpasswd D:/svn/passwd username

    如果 passwd 不存在,可以加上 -c 选项让 htpasswd 新建一个。创建好的文件内容是用户名加上密码的 MD5 密文。
    接下来修改 httpd.conf ,在 Location 标签中加入如下内容:
AuthType Basic
AuthName "repos"
AuthUserFile D:/svn/passwd
Require valid-user

    重新启动 Apache ,打开浏览器访问版本库。 Apache 会提示你输入用户名和密码来认证登陆了,现在只有 passwd 文件中设定的用户才可以访问版本库。也可以配置只有特定用户可以访问,替换上述 "Require valid-user" 为 "Require user tony robert" 将只有 tony 和 robert 可以访问该版本库。

------------------------

    有的时候也许不需要这样严格的访问控制,例如大多数开源项目允许匿名的读取操作,而只有认证用户才允许写操作。为了实现更为细致的权限认证,可以使用 Limit 和 LimitExcept 标签。例如:
<LimitExcept GET PROPFIND OPTIONS REPORT>
	require valid-user
</LimitExcept>

    如上配置将使匿名用户有读取权限,而限制只有 passwd 中配置的用户可以使用写操作。如果这还不能满足你的要求,可以使用 Apache 的 mod_authz_svn 模块对每个目录进行认证操作。