Subversion版本控制

一、简介:
Subversion是一款自由开放的版本控制软件。Subversion可以管理文件、文件夹以及记录它们的修改状况。Subversion常用来帮助我们管理软件开发的源代码或是公司手册文档。
Subversion通过将文档导入至版本库中进行管理,版本库类似于文件服务器,但比文件服务器更强大的是它可以记录你每一次对文件或目录的修改状况,并提供还原数据至老版本的功能。

 

 

客户端访问服务端时可以通过简单的svnserve访问、file本地访问、Apache间接访问。
1.svnserve是一个小巧、轻便的服务器程序,通过它客户端可以使用Subversion专有的协议进行访问,其特点是设置简单。
2.由于svnserve本身并不提供加密通讯的功能,所以如果你需要更安全的连接,可以使用svnserve+ssh的方式,通过连接SSH服务器建立在SSH隧道,在通过SSH调用svnserve程序。
3.Apache通过mod_dav_svn访问版本库,使得客户可以通过访问Apache取得版本库资料进行版本控制。Subversion服务器对比图:

wKioL1PtnpPhkWJYAAIyaoT3lyI954.jpg

Apache+SVN 实现代码管理

 Apache是非常流行的Web服务器软件。它可以运行在几乎所有的计算机平台上。通过Apache发布Subversion的版本库,使得用户可以通过HTTP协议访问版本库。
    以下为使用Apache发布Subversion版本库的若干理由:
    1.Subversion可以使用Apache自身集成的多种认证方式。
    2.不需要创建系统用户。
    3.完善的Apache日志可。
    4.可以通过SSL加密网络传输的数据。
    5.HTTP(S)可以穿越企业防火墙。
    6.坚定地通过浏览器访问版本库。
    准备工作:安装Apache,加载mod_dav及mod_dav_svn模块,Apache需要这两个模块管理Subversion版本库。
    本文以yum方式安装这些软件,环境为CentOS6.4。

[root@centos6 ~]# yum -y install httpd
    [root@centos6 ~]# yum -y install mod_dav_svn
    安装完成后你可以通过以下方法查看dav模块是否加载成功:
    vim /etc/httpd/conf/httpd.conf
    查看是否包含LoadModule dav_module modules/mod_dav.so
    vim /etc/httpd/conf.d/subversion.conf
    查看是否包含LoadModule dav_svn_module modules/mod_dav_svn.so

如果你还需要Subversion自带的基于目录的权限控制的话,可以通过加载mod_authz_svn实现。
    接下来通过修改Apache配置文件实现网络化版本库:
    root@centos6 ~]# mkdir /var/svn
    [root@centos6 ~]# svnadmin create /var/svn/project1
    [root@centos6 ~]# svn import /shells  file:///var/svn/project1 -m "Initial DATA"
    [root@centos6 ~]# vim /etc/httpd/conf.d/subversion.conf  在配置文件最后增加一段代码

<Location /svn>                         //Location可以根据特定的URL执行特定的处理 
//这里当用户的RUL以/svn开始时,将控制权交于DAV处理(http://hostname/svn/...) 
   DAV svn 
   SVNParentPath /var/svn               //通过SVNParentPath指定所有版本库的主目录(发布所有版本库) 
                                        //也可以通过SVNPath指定某个特定版本库的路径(发布特定版本库) 
      AuthType Basic                    //认证方式 
      AuthName "Please Input passwod"  //提示字符 
      AuthUserFile /var/svn/.pass       //帐号文件的路径,为了安全隐藏该文件 
      AuthzSVNAccessFile /var/svn/project1/conf/authz  //此处修改为访问版本库权限的文件 
       Require valid-user                //指定仅有效用户可以访问 
</Location>

 [root@centos6 ~]# chown -R apache.apache  /var/svn/                //修改权限
    [root@centos6 ~]# chcon -R -t httpd_sys_content_t  /var/svn   //仅在SELinux开启时使用
    [root@centos6 ~]# htpasswd -c /var/svn/.pass  jerry        //创建帐号文件,并添加用户jerry,注意第二次增加用户不要加-c参数,否则会覆盖原有的配置文件。

[root@centos6 ~]# htpasswd -c /var/svn/.pass  admin        //增加admin用户并设置密码为123456

[root@localhost svn]# vim /var/svn/project1/conf/authz       //权限分配

[groups]  这个表示群组设置

group1=admin,jerry  这个表示group1群组里的成员 admin,jerry  多个用户用逗号分隔。
     
[/]    这个表示在所有仓库的根目录下
  
admin = rw  仓库下admin用户具有读和写权限 
 
jerry = r   仓库下jerry用户具有读权限   

 * = r      这个表示对所有的用户都具有读权限

注意:在编辑authz.conf文件时,所有行都必须要顶头写,不能有缩行出现,否则会报错:"Access denied: ''user1'' ",里面的内容可以根据自己的需要自行添加,不必与我上面所写的相同!    

 

[root@centos6 ~]# service httpd start
    客户端访问效果如图:

wKiom1PtoQjDXmP-AAJloCBzk1I285.jpg

wKiom1PtoTbjcyUwAAG8L_ADHDY814.jpg

wKioL1Ptok_Tqb5HAAFsmqrDvho500.jpg

wKioL1Ptok-ylmpiAAFvgcehDcg729.jpg