1、svn介绍

SVN(subversion)是近年来崛起的版本管理工具,是CVS的接班人。目前,绝大多数开源软件都使用svn作为代码版本管理软件。作为一个运维人员安装和配置SVN服务器和客户端是必须要掌握的内容。

2、SVN服务器运行模式

模式1:svn服务器单独运行  监听:3690端口    访问:svn://IP

模式2:svn 服务器+ apache   :80 端口  访问:http://IP

3、SVN 的主要功能

1.目录版本控制

CVS 只能跟踪单个文件的历史, 不过 Subversion 实作了一个 "虚拟" 的版本控管文件系统, 能够依时间跟踪整个目录的变动。目录和文件都能进行版本控制。

2.真实的版本历史

自从CVS限制了文件的版本记录,CVS并不支持那些可能发生在文件上,但会影响所在目录内容的操作,如同复制和重命名。除此之外,在CVS里你不能用拥有同样名字但是没有继承老版本历史或者根本没有关系的文件替换一个已经纳入系统的文件。在Subversion中,你可以增加(add)、删除(delete)、复制(copy)和重命名(rename),无论是文件还是目录。所有的新加的文件都从一个新的、干净的版本开始。

3.自动提交

一个提交动作,不是全部更新到了档案库中,就是不完全更新。这允许开发人员以逻辑区间建立并提交变动,以防止当部分提交成功时出现的问题。

4.纳入版本控管的元数据

每一个文件与目录都附有一組属性关键字并和属性值相关联。你可以创建, 并儲存任何你想要的Key/Value对。属性是随着时间来作版本控管的,就像文件內容一样。

5.选择不同的网络层

Subversion 有抽象的档案库存取概念, 可以让人很容易地实施新的网络机制。Subversion 可以作为一个扩展模块嵌入到Apache HTTP 服务器中。这个为Subversion提供了非常先进的稳定性和协同工作能力,除此之外还提供了许多重要功能: 举例来说, 有身份认证, 授权, 在线压缩, 以及文件库浏览等等。还有一个轻量级的独立Subversion服务器, 使用的是自定义的通信协议, 可以很容易地通过 ssh 以 tunnel 方式使用。

6.一致的数据处理方式

Subversion 使用二进制差异算法来表示文件的差异, 它对文字(人类可理解的)与二进制文件(人类无法理解的) 两类的文件都一视同仁。这两类的文件都同样地以压缩形式储存在档案库中, 而且文件差异是以两个方向在网络上传输的。

7.有效的分支(branch)与标签(tag)

在分支与标签上的消耗并不必一定要与项目大小成正比。Subversion 建立分支与标签的方法, 就只是复制该项目, 使用的方法就类似于硬连接(hard-link)。所以这些操作只会花费很小, 而且是固定的时间。

8.Hackability

Subversion没有任何的历史包袱; 它主要是一群共用的 C 程序库, 具有定义完善的API。这使得 Subversion 便于维护, 并且可被其它应用程序与程序语言使用。


4、安装配置 svn server+apache

SVN+Apache的需要subversion的两个动态库支持,同时我们需要密码的验证支持!

 [root@docker-01 ~]# yum install -y subversion httpd mod_dav_svn
 ##有下面svn相关库,就证明安装成功
 [root@docker-01 ~]# vim /etc/httpd/conf.modules.d/10-subversion.conf
 LoadModule dav_svn_module     modules/mod_dav_svn.so
 LoadModule authz_svn_module   modules/mod_authz_svn.so
 LoadModule dontdothat_module modules/mod_dontdothat.so
 ###两个模块对应的物理路径
 [root@docker-01 ~]# ls /etc/httpd/modules/mod_dav_svn.so /etc/httpd/modules/mod_authz_svn.so
 /etc/httpd/modules/mod_authz_svn.so /etc/httpd/modules/mod_dav_svn.so

5、创建一个项目仓库

 [root@docker-01 ~]# mkdir /webdept  ##存放版本库的主目录

6、启动SVN服务器

 [root@docker-01 ~]# svnserve -d -r /webdept
   -d表示以daemon方式(后台运行)运行
   -r/webdept指定根目录是/webdept

7、配置apache通过mod_dav_svn模块访问SVN服务器

 <Location /webdept>
   DAV svn
   SVNParentPath /webdept  ##svn根目录
 #   # Limit write permission to list of valid users.
 #   <LimitExcept GET PROPFIND OPTIONS REPORT>
 #     # Require SSL connection for password protection.
 #     # SSLRequireSSL
 #
     AuthType Basic  ##Basic认证方式
     AuthName "Authorization SVN" ##认证显示信息,提示信息
     AuthzSVNAccessFile /webdept/svn/auth  ##访问控制权限文件
     AuthUserFile /webdept/svn/passwd  ##用户密码文件
     Require valid-user  ##要求正式用户,不能匿名
 #   </LimitExcept>
 </Location>

8、建立本地访问控制文件

 [root@docker-01 ~]# mkdir /webdept/svn/
 [root@docker-01 ~]# htpasswd -c /webdept/svn/passwd user1
 New password: 
 Re-type new password: 
 Adding password foruser tube
 ##第一次用c,创建,第二次就不用
 [root@docker-01 ~]# htpasswd /webdept/svn/passwd user2
 [root@docker-01 ~]# htpasswd /webdept/svn/passwd user2

9、查看用户名和密码

 [root@docker-01 ~]# cat /webdept/svn/passwd 
 user1:$apr1$6Nf85oeK$umg6AU1bvyGrV3Ab5lHf4/
 user2:$apr1$T0m8FRq/$ZMJhYqD/GLbLdDreah7mI0
 user3:$apr1$uJhyqSPN$C10N/kPEpMc4v1jdC9fxi.

10、建立本地项目版本库,权限控制文件

 [root@docker-01 ~]# vim /webdept/svn/authz 
 [groups]
 all = user1,user2
 [/]       ##“/”表示所有仓库的目录下        
 #user1 = rw
 [yunweimao:/]     ##第一个仓库,user1和user2可以读写 
 @all = rw
 [maoxiaopu:/]   ##第二个仓库目录,user2和user3可以读写
 User2 = rw
 User3 = rw

11、给目录权限

 [root@docker-01 ~]# chmod 777 /webdept -R

12、启动服务

 [root@docker-01 ~]# systemctl restart httpd.service

svn的访问地址是:      http://172.17.120.50/webdept/yunweimao

user1和user2可以读取,user3不可以