subversion(svn) 是一个开源的版本控制系統, 也就是说 subversion 管理着随时间改变的数据。 这些数据放置在一个中央资料档案库(repository) 中。 这个档案库很像一个普通的文件服务器, 不过它会记住每一次文件的变动。 这样你就可以把档案恢复到旧的版本, 或是浏览文件的变动历史。
svn 的一些概念
- repository(源代码库):源代码统一存放的地方
- checkout(提取):当你手上没有源代码的时候,你需要从repository checkout一份
- commit(提交):当你已经修改了代码,你就需要commit到repository
- update (更新):当你已经checkout了一份源代码, update一下你就可以和repository上的源代码同步,你手上的代码就会有最新的变更
日常开发过程其实就是这样的(假设你已经checkout并且已经工作了几天):update(获得最新的代码) -->作出自己的修改并调试成功 --> commit(大家就可以看到你的修改了) 。
如果两个程序员同时修改了同一个文件呢, svn 可以合并这两个程序员的改动,实际上svn管理源代码是以行为单位的,就是说两个程序员只要不是修改了同一行程序,svn都会自动合并两种修改。如果是同一行,svn 会提示文件 conflict, 冲突,需要手动确认。
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 便于维护, 并且可被其它应用程序与程序语言使用。
优于cvs之处
1、原子提交。一次提交不管是单个还是多个文件,都是作为一个整体提交的。在这当中发生的意外例如传输中断,不会引起数据库的不完整和数据损坏。
2、重命名、复制、删除文件等动作都保存在版本历史记录当中。
3、对于二进制文件,使用了节省空间的保存方法。(简单的理解,就是只保存和上一版本不同之处)
4、目录也有版本历史。整个目录树可以被移动或者复制,操作很简单,而且能够保留全部版本记录。
5、分支的开销非常小。
6、优化过的数据库访问,使得一些操作不必访问数据库就可以做到。这样减少了很多不必要的和数据库主机之间的网络流量。