第一步:通过yum命令安装svnserve,命令如下
yum -yinstall subversion
此命令会全自动安装SVN服务器相关和依赖,安装完成会自动停止命令运行 若需查看SVN安装位置,可以用以下命令:
rpm-qlsubersion
第二步:创建版本库目录(此仅为目录,为后面创建版本库提供存放位置)
选择在var路径下创建版本库,当前处于根目录下,一次性创建如下:
mkdir-p /var/svn/svnrepos
在第二步建立的路径基础上,创建版本库,命令如下:
svnadmin create/var/svn/svnrepos/demo01 (demo01为你预期的版本库名称,可自定义)
创建成功后,进入xxxx目录下
cd/var/svn/svnrepos/demo01
进入目录,可以看见如下文件信息
进入已经创建好的版本库目录下,也就是前文说创建的xxxx 进入conf
cd/var/svn/svnrepos/demo01/conf
conf目录下,一共存放三份重要的配置文件,如下
auth:负责账号权限的管理,控制账号是否读写权限
passwd:负责账号和密码的用户名单管理
svnserve.conf:svn服务器配置文件
细节修改如下:
vi authz
在文件末尾添加如下代码
rw表示赋予此账号可读写的权限,请注意[]中的斜杠,一定是反斜杠,这样写允许访问的权限更大,避免一些错误
vi passwd
账号密码文件无需做修改,也是直接将账号和密码信息追加到文件中即可,注意格式为:账号 = 密码 例如:admin=123456
vi svnserve.conf
原始文件内容,都被注释掉的,我们只需要去掉4条指定内容前注释即可,如下:
大多数网络资料,都会让大家将authz-db = authz这条给去掉注释,经过我本人多次被坑经验,此条去掉后,虽然svn服务器可以连接,但一直会提示“认证失败”,注释掉即可正常
还有多数资料会让大家在realm = My First Repository处填写服务器ip,经过测试,填写后并无什么用处,所以大家去掉注释即可,无需做任何修改
到此,配置已经全部完成,账号信息已经添加成功
多数情况下服务器安装完成,配置完成后,无法连接svn服务器,均是防火墙问题,需要按照以下三条指令逐一执行即可
iptables防火墙添加3690:/sbin/iptables -I INPUT -p tcp --dport 3690 -j ACCEPT/etc/init.d/iptables saveservice iptables restartfirewall防火墙添加3690:firewall-cmd--zone=public--add-port=3690/tcp --permanentfirewall-cmd --reload注意:云服务器外面还要添加安全组,把3690开放并重启服务器才行哦
在根目录下,执行如下命令:
svnserve -d -r /var/svn/svnrepos这时如果我们在开启一个版本库svnserve -d -r /var/svn/repositoryB开启版本库repositoryB时,会提示svnserve: Can’t bind server socket: Address alreadyinuse因为svn默认使用的端口是3690,而之前在开启版本库repositoryA已经使用,所以这里提示已经使用所以我们应该换个端口,这里假设端口3691未被使用,则可以使用svnserve -d -r /svn/repositoryB --listen-port 3691
启动成功后,可用ps -aux | grep svn查看服务器是否成功
在windows客户端,输入地址:svn://公网地址:3690/demo01 (iP地址为你linux的ip,xxxx为前文创建的版本库名称,3690为svn默认端口)
弹出输入用户名和密码,输入即可访问