什么是版本控制?
版本控制是一种记录了一个或若干个文件内容的变化,以便将来可以随时查看特定版本的信息或者恢复到某个特定版本的系统。
版本系统的种类
本地版本系统
人们为了方便记录文件的变化以及可以及时恢复到文件之前的某个状态,于是,出现了本地版本系统。
本地版本控制的系统有很多,最为流行的为RCS(Revision Control System)。大多数的本地版本控制系统都是采用某种简单的数据库来记录文件的历史差异,就如同上图所表示的。
集中化的版本控制系统
紧接着人们又遇到了问题,如何让在不同系统上的开发者协同工作呢?因此,集中化的版本控制系统CVCS(Centralized VCS)应运而生。这类系统,比如CVS、Subversion等,都有一个单一的集中管理的服务器,保存所有的修订版本,而协同工作的开发者都通过客户端连接到这台服务器,获取最新的文件或者提交更新。多年一来,这已经成为版本控制系统的标准做法。
这种做法带来了许多好处,特别是相对于老式的本地VCS来说。现在,每个人都可以在一定程度上看到其他人在做些什么。而管理员也可以方便的管理每个开发者的权限,并且管理一个CVCS要远比在各个客户端维护本地数据库要容易的多。
但是,事情都是有两面性的。最显著的问题就是服务器的单点故障。假设服务器宕机一小时,所有人都不能提交更新了,那么就不能协调工作了。如果服务器的硬盘出现损坏,那么所有的历史版本都会消失,只剩下各个客户端本机上的版本。
分布式版本控制系统
于是,分布式版本控制系统DVCS(Distributed VCS)面世了。在这类系统中,像Git、Mercurial等,客户端并不获取最新版本的文件快照,而是把整个代码仓库完整的镜像下来。这样一来,任何一处协同工作用的服务器出现故障,事后都可以用任何镜像出来的本地仓库恢复。因为每一次克隆操作。实际上都是对代码仓库的完整拷贝。