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

avatar
作者
猴君
阅读量:0

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版本库

    广告一刻

    为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!