Debian下SVN服务器安装

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

扫描二维码关注公众号,回复: 287784 查看本文章

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:/]改为[/]既可以了,[/]代表根目录下所有的资源,如果要限定资源,可以加上子目录即可。

猜你喜欢

转载自shuzheng5201314.iteye.com/blog/2324448