svn apache配置
2009-04-01对于版本控制,我一直看好SVN ,它比CVS 有更先进的特性,并且可通过配置使其能在广域网上访问,非常方便。同时,可以利用TortoiseSVN 很好地进行客户端管理,并搭配Apa
2009-04-01
对于版本控制,我一直看好SVN ,它比CVS 有更先进的特性,并且可通过配置使其能在广域网
上访问,非常方便。同时,可以利用TortoiseSVN 很好地进行客户端管理,并搭配Apache 出色完成各种版管理各种任务。下面讲一下配置过程:
1. 准备:svn-win32-1.6.0.zip(二进制,Apache2.2) ;
apache_2.2.11-win32-x86-no_ssl.msi;
TortoiseSVN-1.6.0.15855-win32-svn-1.6.0.msi
这些软件都可以在网络上找到,搜索一下并下载适合自己的版本,svn-win32-1.6.0.zip 直接解压到某一个目录就可以了(如:D:Program FilesSVN),Apache 默认安装,TortoiseSVN 默认安装
2. 配置
2.1 SVN配置:将SVN 跟目录的bin 目录地址(D:Program FilesSVNbin)添加到系统变量path 中
2.2 创建资源库(两种):
2.2.1 单资源库,如果你打算只建立一个资源库,用这种方式。打开命令提示符,输入svnadmin create E:ResourcesSVNRepositories�A,回车。其中
E:ResourcesSVNRepositories�A为你的资源库路径。
2.2.2 多资源库,如果你要创建多个资源库,用这种方式。打开命令提示符,输入svnadmin create E:ResourcesSVNRepositories�A,回车;输入三vsndmin
create E:ResourcesSVNRepositories�B,回车...
2.3 Apache配置:
首先应保证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:ResourcesSVNRepositories
AuthType Basic
AuthName "Subversion Reporsitory"
AuthUserFile E:ResourcesSVNconfpasswd
AuthzSVNAccessFile E:ResourcesSVNconfauthz
Require valid-user
如果是多资源库:
DAV svn
SVNListParentPath on
SVNParentPath E:ResourcesSVNRepositories
AuthType Basic
AuthName "Subversion Reporsitory"
AuthUserFile E:ResourcesSVNconfpasswd
AuthzSVNAccessFile E:ResourcesSVNconfauthz
Require valid-user
其中:
E:ResourcesSVNconf是存放用户文件和权限文件的目录;
E:ResourcesSVNconfpasswd就是存放用户信息的文件,它是一个没有后缀的文件,用Apache 的htpasswd.exe 来维护,负责将用户的密码用MD5加密成暗文;
E:ResourcesSVNconfauthz就是存放访问权限的文件,它也是一个没有后缀的文本文件可以用文本工具直接编辑;AuthType Basic是认证类型,此处采用基本类型,即采用用户名 密码的方式;AuthName "Subversion Reporsitory"是指认证时代表示,起到提示作用;Require valid-user 表示SVN 必须提供用户和密码才可以访问,不能匿名登录
重启Apache ,查看Apache Service Monitor状态栏是否包含“SVN/1.6.0 DAV/2”字样。在浏览器中输入http://******/svn/(其中******为你的主机域名地址或者IP 地址),验证配置。
3. 管理
3.1 用户管理:将Apache 安装目录的bin 目录路径添加到系统环境变量path 中,打开命令提示符,定位到E:ResourcesSVNconf
创建用户:输入htpasswd -c passwd Sean 回车,将提示输入密码,输入两次之后,用户就添加成功了;如果在E:ResourcesSVNconf下已经存在passwd 文件便要去掉-c 参数 删除用户:输入htpasswd -D passwd Sean 回车
3.2 权限管理:可以复制E:ResourcesSVNconf下的passwd 文件,粘帖,重命名为authz (或者从资源库的conf 目录下复制authz 文件到E:ResourcesSVNconf下),在文件里维护:
[groups]
everyone = admin,Sean,Jack
AAAer = Sean
BBBer = Jack
manager = admin
[AAA:/]
@everyone = r
@AAAer = rw
@manager = rw
,[BBB:/]
@everyone = r
@BBBer = rw
@manager = rw
其中[groups]代表组定义:“组名 = 用户1, 用户2...”;[AAA:/]代表AAA 资源库,@everyone = r代表everyone 这个组的所有用户有读权限。权限有四种:r,w,rw 和空,可以根据实际情况自行配置
4. TortoiseSVN使用:在其他机器上选定某个目录(如F:SVN�A,记得保证是空目录),点击鼠标右键,选择“SVN Checkout”,填写资源库URL (如
6. 创建权限配置文件
vi /code/authz.conf
[test:/]
user1 = rw
user2 = r
保存退出
注:
[test:/] //这表示,仓库test 的根目录下的访问权限
user1 = rw //test仓库user1用户具有读和写权限
user2 = r //test仓库user2用户具有读权限
[test2:/] //test2仓库根目录下的访问权限
user1 = r //user1用户在test2仓库根目录下只有读权限
user2 = //user2用户在 test2仓库根目录下无任何权限
[/] //这个表示在所有仓库的根目录下
* = r //这个表示对所有的用户都具有读权限
#[groups] //这个表示群组设置
#svn1-developers = user1, user2 //这个表示某群组里的成员
#svn2-developers = user1
#[svn1:/]
#@svn1-developers = rw //如果在前面加上@符号,则表示这是个群组权限设置