首页 > 代码库 > CentOS 6.3上SVN安装过程及使用手册

CentOS 6.3上SVN安装过程及使用手册

一、 SVN 简介

    Subversion(SVN) 是一个开源的版本控制系統, 也就是说 Subversion 管理着随时间改变的数据。 这些数据放置在一个中央资料档案库 (repository) 中。这个档案库很像一个普通的文件服务器, 不过它会记住每一次文件的变动。 这样你就可以把档案恢复到旧的版本, 或是浏览文件的变动历史。

 

SVN中经常用到的一些概念 :

(1)repository(源代码库):源代码统一存放的地方;

(2)Checkout (提取):当你手上没有源代码的时候,你需要从repository checkout一份;

(3)Commit (提交):当你已经修改了代码,你就需要Commit到repository;

(4)Update (更新):当你已经Checkout了一份源代码, Update一下你就可以和Repository上的源代码同步,你手上的代码就会有最新的变更 ;

 

SVN的工作方式:

    日常开发过程其实就是这样的(假设你已经Checkout并且已经工作了几天):Update(获得最新的代码) -->作出自己的修改并调试成功 --> Commit(大家就可以看到你的修改了) 。

    如果两个程序员同时修改了同一个文件呢,  SVN可以合并这两个程序员的改动,实际上SVN管理源代码是以行为单位的,就是说两个程序员只要不是修改了同一行程序,SVN都会自动合并两种修改。如果是同一行,SVN会提示文件Confict, 冲突,需要手动确认。

 

客户端软件:

    Windows下常用的客户端软件常用TortoiseSVN。它是一个免费的开源的客户端。 下载地址:http://tortoisesvn.net/downloads.html

wKioL1P604-i-SluAALJcg565I0261.jpg

 

Subversion提供以下主要功能:

(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)。 所以这些操作只会花费很小, 而且是固定的时间。


二、安装以及使用过程:

1、在Linux环境下直接使用yum安装即可:

[root@node1 ~]# yum install subversion


2、安装好之后就可以配置一下相关的配置文件了、其实说配置主要是先创建一个源代码库(也叫版本库),在哪里创建都可以、创建版本库使用的命令如下:

[root@node1 ~]# svnadmin create /data/www/svn


3、配置版本库中的相关配置,设置用户访问的权限,添加访问用户等,在创建的版本库中我们可以在conf文件夹中看到三个文件,这三个文件就是我们要修改的配置:

authz  passwd  svnserve.conf

wKioL1P61j-A01A4AAA4qtOpP-g229.jpg

(1)svnserve.conf:  svn服务配置文件

(2)passwd: 用户名口令文件。

(3)authz: 权限配置文件。


4、接下来我们修改这三个文件;

[root@node1 conf]# vim svnserve.conf

wKiom1P61e7Q__uAAAI3zMlsKOI089.jpg

    anon-access:控制非鉴权用户访问版本库的权限。

    auth-access:控制鉴权用户访问版本库的权限。

    password-db:指定用户名口令文件名。

    authz-db:指定权限配置文件名,通过该文件可以实现以路径为基础的访问控制。

    realm:指定版本库的认证域,即在登录时提示的认证域名称(也就是版本库的名称)。若两个版本库的认证域相同,建议使用相同的用户名口令数据文件


[root@node1 conf]# vim passwd 

wKiom1P61qjTxtebAABQGf3Y3M4787.jpg


[root@node1 conf]# vim authz 

wKioL1P62KrTB0a-AAEW-Uwxa7M143.jpg


如果版本库有多个文件夹,且都需要分配不同的权限的话,只要再加[版本库名:/文件目录]一项这个就可以了,有多少个用多少个,比如:

wKioL1P62i_SC8yLAAFIHRn2Zv0729.jpg


版本库目录,如果你创建的版本库为/data/www/svn,那这里就写上你的目录名,格式:[目录名:/]

@后面跟上组名,再指定组的权限,*=表示不在这个组内的所有组都没有权限;


好了,到这里我们就可以启动服务了;

[root@node1 ~]# svnserver -d -r /data/www/  

-d:表示在后台运行;-r:指出要运行的版本库的路径,如果你创建的版本库路径为/data/www/svn,那么只需要指定/data/www就可以了、查看端口;

wKioL1P62-SywiMUAAE3QYSjUTQ053.jpg

OK、到这里我们已经安装好了,并配置好相关的权限和用户了,那么接下来我们安装windows客户端来测试一下。


三、安装windows客户端SVN、到官网下载客户端,顺便把汉化包也一起下载下来:http://tortoisesvn.net/downloads.html

wKiom1P62_vRyxR-AAKXuaNr-Os007.jpg


下载好客户端之后就一直next到底就可以了,这个不多说了,安装好客户端之后再安装汉化包就可以了,安装完汉化包就要设置一下,改成中文的去:

wKioL1P63ffRb1PMAAFSOFzYJ3U573.jpg

wKiom1P63TmBcR6RAAKX_c8mJTM891.jpg


好了之后我们就可以使用了,找到一个存放源代码的目录,右键空白处,选择SVN检出:

wKiom1P63jTifT4-AAGdQAj-i3k144.jpg


点击确定之后就会弹出输入用户名和密码的对话框:

wKioL1P63_3zGJ-xAAC-6yNzus8909.jpg

wKiom1P635Hg2WEgAAGsZNwXMpw780.jpg


好了,到这里我们的SVN已经搭建完成了,这样我们就可以完全的使用了。如果有什么不明白的地方欢迎各种在下面留言,我会尽量解答各位的问题,谢谢。

本文出自 “温水煮青蛙” 博客,请务必保留此出处http://tanxw.blog.51cto.com/4309543/1544680

CentOS 6.3上SVN安装过程及使用手册