Linux下创建SVN仓库
Step1:进入SVN根目录
cd /usr/local/svn
Step2:创建版本仓库
svnadmin create test
其中test是版本仓库的名字,仓库建立好了以后会有出现一个仓库名字的文件夹,文件夹下面有conf等几个目录和文件,
Step3:增加用户
修改conf文件夹下的authz文件:
[groups]
<用户组名> = <用户1>,<用户2>
其中,1个用户组可以包含1个或多个用户,用户间以逗号分隔。
版本库目录格式:
[<版本库>:/项目/目录]
@<用户组名> = <权限>
<用户名> = <权限>
其中,方框号内部分可以有多种写法:
/,表示根目录(仓储目录)及以下。根目录是svnserve启动时指定的,我们指定/opt/svndata。这样,/就是表示对全部版本库设置权限。
权限主体可以是用户组、用户或*,用户组在前面加@,*表示全部用户。权限可以是w、r、wr和空,空表示没有任何权限。
在[groups]下增加你的用户组(记得等号前后留空格)
在[/]下面增加对用户或者用户组的权限设置;最后如下图:
Step4:修改用户密码
添加了用户以后就需要给用户设置密码了,打开conf/passwd文件:
输入以下内容:
Step5:对启动SVN对用户权限、密码的控制
需要启动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
修改后文件内容为:
Step6: 重新启动svn服务 :
启动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
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。