Linux 搭建 SVN 服务器 及使用教程

  1. 检查环境

    • 查看系统下有没有安装过或有安装过老版本的SVN

      rpm -qa subversion		//如果没安装过则什么都不显示
      
    • 如果有老版本先运行一下,删除老版本

      yum -y remove subversion
      
  2. 搭建SVN服务器

    • linux服务器安装svn
    yum -y install subversion
    
    • 检查是否安装成功
    svn --version
    
    • 如果显示如下内容说明安装成功
    svn, version 1.10.2 (r1835932)
       compiled Nov  3 2020, 23:13:15 on x86_64-redhat-linux-gnu
    
  3. 创建SVN仓库

    • 创建版本库目录(目录地址可以自定义)
    #(此目录为后面创建版本库提供存放位置,repository默认是把/var/svn作为数据根目录的,开机启动默认也是从这里):
    mkdir -p /home/svn/repository
    
    • 非root用户需要更改目录权限
    chmod 755 -R /home/svn/repository
    
    • 创建版本仓库
    #repository为项目名称,checkout项目时会用到
    svnadmin create /home/svn/repository
    

    ​ 创建完成之后进入刚才的目录就能看到下面几个文件:

    conf   db   format    hooks    locks    README.txt
    
    • conf:是这个仓库配置文件(仓库用户访问账户,权限)
    • format:是一个文本文件,里边只放了一个整数,表示当前文件库配置的版本号
    • hooks:放置hook脚步文件的目录
    • locks:用来放置subversion的db锁文件和db_logs锁文件的目录,用来追踪存取文件库的客户端
    • db:使用命令创建SVN仓库之后上传的文件并不能直接看到,因为文件被svn管理起来了储存在db目录。

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

    • authz:负责账号权限的管理,控制账号是否读写权限
    • passwd:负责账号和密码的用户名单管理
    • svnserve.conf:svn服务器配置文件
  4. 修改SVN仓库的配置文件

    • 修改passwd文件信息,用户添加密码

      直接将账号和密码信息追加到文件中即可,格式为:账号 = 密码,用户权限如果是设的分组,仍需设置每个角色对应的密码

      [users]
      panyma=123456
      
    • 修改authz文件:设置用户权限

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

      # 表示根目录下用户panyma拥有读和写的权限
      第一种方式:单个添加:
      [/]
      panyma=rw
      
      第二种方式:用户分组,再设权限
      [groups]
      # 按用户组分权限
      admin = admin,admin1 # admin为用户组,等号之后的为用户
      
      [/] 			# 表示svn仓库根目录(/home/svn/repository)
      @admin = rw 	# 表示admin组对仓库目录有读写权限
      
      备注:版本库的目录格式如下:
      
      [<版本库>:/项目/目录]
      
      @<用户组名> = 权限
      
      <用户名> = 权限
      
      1.权限的主体可以是用户组,用户或者*,用户组在前面要以@开头,*表示全部用户
      
      2.权限分为:r ,w, rw和null ,null空表示没有任何权限。
      
      
      3.auhtz配置文件中的每个参数,开头不能有空格,对于组要以@开头,用户不需要。
      
      注意[/]中的斜杠,这里如果斜杠反了,authz-db = authz 一直会提示“认证失败”
      其中[]內容有許多写法:
      
      [/],表示根目录及其一下的路径,根目录是svnserver启动时指定好的,上述实例中我们指定为:/svn/svndata([/]=/svn/svndata).[/]就是表示对全部版本设置的权限
      
      [test:/],表示对版本库test设置权限;
      
      [test:/svnadmin],表示对版本库test中的svnadmin项目设置权限;
      
      [test:/svnadmin/second],表示对版本库test中的svnadmin项目的目录设置权限;
      
    • 修改svnserve.conf文件

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

      # 鉴权:是指验证用户是否拥有访问系统的权利。
      # 取值范围"write"为可读可写,"read"为只读,"none"表示无访问权限。
      
      #控制非鉴权用户访问版本库的权限
      #anon-access = none
      # 控制鉴权用户访问版本库的权限。
      auth-access = write
      
      # 指定用户名口令文件名,即访问时要输用户名和密码,如果在同一目录下,就等于文件名即可
      password-db = passwd
      
      # authz 文件的位置,如果在同一目录下,就等于文件名即可
      authz-db = authz
      
      realm = /home/svn/repository 【指定版本库的认证域,即在登录时提示的认证域名称,改成自己的版本库】
      
  5. 开启防火墙

    多数情况下服务器安装完成,配置完成后,无法连接svn服务器,均是防火墙问题

    首先要明确CentOS7的默认防火墙为firewallD。subversion的默认端口为3690,如果没有打开会报错:

    sudo firewall-cmd --permanent --add-service=telnet
    sudo firewall-cmd --permanent --add-port=3690/tcp
    sudo firewall-cmd --reload
    

    centOS 7 防火墙开启、关闭与查看状态:

    systemctl start firewalld
    systemctl stop firewalld
    systemctl status firewalld
    
  6. 启动svn服务器

    # -d : 守护进程  -r : svn数据根目录
    svnserve -d -r /home/svn/repository #用root权限启动
    

    查看SVN服务

    ps aux|grep svnserve #默认端口为:3690
    

    开始svn服务

    start svnserve.service	#开始服务
    stop svnserve.service	#停止服务
    
  7. 检出项目

进入windows 检出项目:

地址栏输入 svn://项目ip:3690/repository

项目ip可以通过 ip addr 或者 ifconfig 查看 inet,repository为当初建立的SVN版本库

Logo

腾讯云面向开发者汇聚海量精品云计算使用和开发经验,营造开放的云计算技术生态圈。

更多推荐