标签:
cd /usr/local/svn
svnadmin create test
其中test是版本仓库的名字,仓库建立好了以后会有出现一个仓库名字的文件夹,文件夹下面有conf等几个目录和文件,
修改conf文件夹下的authz文件:
[groups]
<用户组名> = <用户1>,<用户2>
其中,1个用户组可以包含1个或多个用户,用户间以逗号分隔。
版本库目录格式:
[<版本库>:/项目/目录]
@<用户组名> = <权限>
<用户名> = <权限>
其中,方框号内部分可以有多种写法:
/,表示根目录(仓储目录)及以下。根目录是svnserve启动时指定的,我们指定/opt/svndata。这样,/就是表示对全部版本库设置权限。
权限主体可以是用户组、用户或*,用户组在前面加@,*表示全部用户。权限可以是w、r、wr和空,空表示没有任何权限。
在[groups]下增加你的用户组(记得等号前后留空格)
在[/]下面增加对用户或者用户组的权限设置;最后如下图:
添加了用户以后就需要给用户设置密码了,打开conf/passwd文件:
输入以下内容:
需要启动SVN对用户权限、密码的控制,不然的话你就只能读而不能写了。
修改svnserve.conf文件,
[general]
anon-access = none # 使非授权用户无法访问
auth-access = write # 使授权用户有写权限
password-db = passwd # 指明密码文件路径
authz-db = # 访问控制文件
realm = My First Repository # 认证命名空间,subversion会在认证提示里显示,并且作为凭证缓存的关键字。
取消下面几条前面的#号注释并按需修改就OK了:
anon-access = none
auth-access = write
password-db = passwd
authz-db = authz
修改后文件内容为:
启动svn服务命令 sudo svnserve -d -r /usr/local/svn
如果报:svnserve: Can‘t bind server socket: Address already in use
解决办法:
使用 “ ps -e|grep svnserve ” 找到服务对应进程编号 ,使用kill 命令杀死该进程,之后再使用启动命令 ,如图
使用地址访问,如果出现“svnserve.conf:20: Option expected”,导致原因是:subversion读取配置文件
svnserve.conf时,无法识别有前置空格的配置文件,如:
修改为:
即可,不必重启SVN
更多资料请访问:http://www.iyuze.cn/article/489.html
标签:
原文地址:http://blog.csdn.net/justyuze/article/details/43760515