1.安装
# apt-get update
# apt-get install subversion subversion-tools
2.创建存储库
# mkdir /opt/svn
# svnadmin create –-fs-type fsfs /opt/svn/test
3.设置权限
# chown –R www-data:www-data /opt/svn/*
# chmod –R 770 /opt/svn/*
4.启动svnserve服务
#svnserve -d /opt/svn/xx
5. 配置权限 :authz文件
指令简介:此配置文件采用“基于路径的授权”策略,中括号里指定路径,以下列出对各用户的授权。包括只读r,读写rw。没有列出的用户,则不允许访问。还可以对用户分组,具体请参考svn手册,以下是简单例子:
<!--[if !supportLineBreakNewLine]--> 用户组格式:
[groups]
<用户组名> = <用户1>,<用户2>
其中,1个用户组可以包含1个或多个用户,用户间以逗号分隔。
版本库目录格式:
[<版本库>:/项目/目录]
@<用户组名> = <权限>
<用户名> = <权限>
其中,方框号内部分可以有多种写法:
/,表示根目录及以下。根目录是svnserve启动时指定的,我们指定/opt/svndata。这样,/就是表示对全部版本库设置权限。
repos1:/,表示对版本库1设置权限
repos2:/abc, ,表示对版本库2中的abc项目设置权限
repos2:/abc/aaa, ,表示对版本库2中的abc项目的aaa目录设置权限
权限主体可以是用户组、用户或*,用户组在前面加@,*表示全部用户。权限可以是w、r、wr和空,空表示没有任何权限。
========= 修改配置文件 ===========
/opt/svn/test/conf/svnserve.conf:
[general]
anon-access = read
auth-access = write
password-db = passwd
authz-db = authz
realm = /opt/svn/test # 认证命名空间,subversion会在认证提示里显示,并且作为凭证缓存的关键字。
/opt/svn/test/conf/passwd:
[users]
tom = tom
/opt/svn/test/conf/authz:
[groups]
project_1 = tom
[prj1:/]
@project_1 = rw
访问
svn://192.168.1.105/prj1
则会出现认证失败
原因是:
svn://192.168.1.105/prj1 访问时找不到tom对应的库,就是因为[prj1:/]不是一个有效的库路径
把[prj1:/]改为[/]既可以了,[/]代表根目录下所有的资源,如果要限定资源,可以加上子目录即可。