开发学院,分享开发教程和最新动态

实例:linux系统下搭建SVN服务器

实例:linux系统下搭建SVN服务器 

  操作系统系统环境:Centos 7.4

第一步:通过yum命令安装svnserve,命令如下:

yum -y install subversion

  系统会全自动安装svn服务器相关服务和依赖,安装完成会自动停止命令运行

第二步:创建版本库目录

  选择在data路径下创建版本库,当前处于根目录下,一次性创建如下:

mkdir /data/svn

第三步:创建svn版本库

  在第二步建立的路径基础上,创建版本库,命令如下:

svnadmin create /data/svn/projectname

  创建成功后,进入项目目录下

 cd /data/svn/projectname

  进入目录,使用ls可以看见如下文件:

conf  db  format  hooks  locks  README.txt

第四步:修改配置文件

  进入conf目录

cd /data/svn/projectname/conf

  conf目录下,一共存放三份重要的配置文件,如下:

  authz:负责账号权限的管理,控制账号是否读写权限

  passwd:负责账号和密码的用户名单管理

  svnserve.conf:svn服务器配置文件

  修改authz文件信息,如下:

vim authz

  在文件内容的末尾,添加如下:

[\]
账号1 = rw
账号2 = rw

  rw表示赋予此账号可读写的权限,请注意[]中的斜杠,一定是反斜杠,有些教程说,需添加版本库名称在括号内,我直接建议就这写,这样写允许访问的权限更大,避免一些错误

  修改passwd文件信息

vim passwd

  账号密码文件直接将账号和密码信息追加到文件中即可,格式为:

账号 = 密码
例如:admin = 123456

修改svnserve.conf

vim svnserve.conf

  原始文件内容,都被注释掉的,我们只需要去掉4条指定内容前注释即可,如下:

anon-access = read
auth-access = write
password-db = passwd
realm = My First Repository(名字随便起)

  这是从另一篇博客里面看到的说明:大多数网络资料,都会让大家将authz-db = authz这条给去掉注释,博主多次被坑经验,此条去掉后,虽然svn服务器可以连接,但一直会提示“认证失败”,注释掉即可正常

到此,配置已经全部完成,账号信息已经添加成功

第五步:防火墙开启

  多数情况下服务器安装完成,配置完成后,无法连接svn服务器,均是防火墙问题,大家按照如下3条命令逐一执行即可

iptables -I INPUT -p tcp --dport 3690 -j ACCEPT

六:启动svn服务器

  在根目录下,执行如下命令:

svnserve -d -r /var/svn

-r 代表指定根目录,如果有多个项目,一定要指定项目的上一级目录而非项目目录本身

  注释:启动成功后,可用ps -aux查看服务启动是否成功

七:停止svn服务器

killall svnserve

  注释:每次修改后需要重新加载配置文件,否则无法生效

八:客户端访问svn服务器

  在svn客户端,输入地址:svn://ip地址:3690/xxxx   (iP地址为svn服务器所在的ip,xxxx为前文创建的版本库名称,3690为svn默认端口)

  客户端会提示输入用户名和密码,输入即可访问

  补充:如果需要使用非默认的3690端口提供服务,可以在-d参数后面加--listen-port xxxx,xxxx可以替换为任何合法的端口号,例如我们想使用13690提供服务,可以使用如下命令,:

svnserve -d --listen-port 13690 -r  /data/svn