SVN 配置详解

SVN权限配置

作为一个配置管理员,需要管理用户的权限,本文主要介绍了使用Subversion的授权文件“authz-db”,同时为了叙述的清晰,我首先澄清一些概念。

1.      认证(Authentication)和授权(Authorization)

这两个术语经常一起出现。其中认证的意思就是鉴别用户的身份,最常见的方式就是使用用户名和密码,授权就是判断用户是否具备某种操作的权限,在Subversion里提供了“authz-db”文件,实现了以路径为基础的授权,也就是判断用户是否有操作对应路径的权限。

2.      svnserve下的配置文件

因为本文是以svnserve为例的,所以先介绍一下版本库目录的结构:

D:/SVNROOT/PROJECT1

├─conf

├─dav

├─db

│  ├─revprops

│  ├─revs

│  └─transactions

├─hooks

└─locks

其中conf下面有三个文件:

    authz

    passwd

    svnserve.conf

其中的“svnserve.conf”是这个版本库的配置文件,当使用svnserve时,这个配置文件决定了使用什么认证和授权文件:

    password-db = passwd

    authz-db = authz

上面的配置说明使用“svnserve.conf”同目录的passwd和authz,其中的password-db指定了用户密码文件,authz-db是我们的授权文件,也就是我们本文主要介绍的文件。

3.      基于svnserve的版本库文件布局

使用svnserve时,为了管理的方便,应该使用相同的认证和授权文件,所以应该让所有版本库的配置文件svnserve.conf指向同一个password-db和authz-db文件。下面是一个多版本库的目录:

D:/SVNROOT

├─project1

│  ├─conf

│  ├─dav

│  ├─db

│  │  ├─revprops

│  │  ├─revs

│  │  └─transactions

│  ├─hooks

│  └─locks

└─project2

    ├─conf

    ├─dav

    ├─db

    │  ├─revprops

    │  ├─revs

    │  └─transactions

    ├─hooks

    └─locks

   

D:/SVNROOT下有两个目录project1和project2,都已经创建了版本库,所以我们修改每个conf目录下的svnserve.conf,使之指向同一个password-db和authz-db文件。

password-db = ../../passwd

authz-db = ../../authz

这样,D:/SVNROOT/passwd和D:/SVNROOT/authz就控制了所有版本库的svnserve访问。另外在后面的操作中要关闭匿名访问,应该去掉“anon-access = none”前的“#”号,保证只有认证用户可以访问。

注意:还有一点需要注意,那就是svnserve的“realm”的值,在上面的设置下,应该保证所有的版本库使用相同的realm值,这样,对版本库的密码缓存可以在多个版本库之间共享,更多细节见客户端凭证缓存。

4.      测试用户和组说明

版本库禁止任何匿名用户的访问,只对认证用户有效。

root:配置管理管理员,对版本库有完全的管理权限。

p1_a1:project1的管理员,对project1有完全权限。

p1_d1:project1的开发者,对project1的trunk有完全的权限,但是对其中的/trunk/admin目录没有任何权限。

p1_t1: project1的测试者,对project1的trunk有完全的读权限,但是对其中的/trunk/admin目录没有任何权限。

 

p2_a1:project2的管理员,对project2有完全权限。

p2_d1:project2的开发者,对project2的trunk有完全的权限,但是对其中的/trunk/admin目录没有任何权限。

p2_t1: project2的测试者,对project2的trunk有完全的读权限,但是对其中的/trunk/admin目录没有任何权限。

 

对应的组及组的用户:

p1_group_a:p1_a1

p1_group_d:p1_d1

p1_group_t:p1_t1

p2_group_a:p2_a1

p2_group_d:p2_d1

p2_group_t:p2_t1

5.      修改D:/SVNROOT/passwd文件

前面已经说过了,用户和密码文件应该是在D:/SVNROOT/passwd,所以我们为每一位用户设置权限,文件内容如下:

[users]

p1_a1 = p1_a1

p1_d1 = p1_d1

p1_t1 = p1_t1

p2_a1 = p2_a1

p2_d1 = p2_d1

p2_t1 = p2_t1

为了便于验证,所有密码和用户名一致。

6.      配置授权,修改D:/SVNROOT/authz

[groups]

# 定义组信息

p1_group_a = p1_a1

p1_group_d = p1_d1

p1_group_t = p1_t1

 

p2_group_a = p2_a1

p2_group_d = p2_d1

p2_group_t = p2_t1

 

[/]

# 指定所有的版本库默认只读,root可读写

* = r

root = rw

 

[project1:/]

# 指定对版本库project1根目录的权限

@p1_group_a = rw

@p1_group_d = rw

@p1_group_t = r

 

[project1:/trunk/admin]

# 指定对版本库project1的/trunk/admin根目录的权限,

# p1_group_a读写,p1_group_d和p1_group_t没有任何权限。

@p1_group_a = rw

@p1_group_d =

@p1_group_t =

 

[project2:/]

# 指定对版本库project2根目录的权限

@p2_group_a = rw

@p2_group_d = rw

@p2_group_t = r

 

[project2:/trunk/admin]

# 指定对版本库project2的/trunk/admin根目录的权限

# p2_group_a读写,p2_group_d和p2_group_t没有任何权限。

@p2_group_a = rw

@p2_group_d =

@p2_group_t =

经过以上设置以后,你会发现当使用用户“p1_d1”,检出project1的trunk时,目录是空的,好像admin目录根本不存在一样,当使用p1_d1用户浏览版本库时,能够看到admin目录,但是其中的内容却无法看到。

关于中文目录,也是没有问题的,只是注意要把authz文件转化为UTF-8格式,在我的WINXP的UltraEdit里显示的文件格式为U8-DOS,具体的做法是用UltraEdit打开authz文件,然后选择“文件->转换->ASCII转UTF-8”,然后保存。

再复杂的情况也不过如此,在实际的工作中要首先规划好权限,只赋给用户最小的权限,保证以最小的配置实现最复杂的权限控制。


原文:http://blog.csdn.net/augusdi/article/details/5401602

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值