1.版本控制
1.1 什么是版本控制
版本控制(Revision control)是一种在开发的过程中,用于管理我们对文件、目录或工程等内容的修改历史,方便查看更改历史记录,备份以便恢复以前的版本的软件工程技术。简而言之:用于管理多人协同开发的项目的技术。
使用版本控制有什么好处呢?
- 实现跨区域多人协同开发。
- 追踪和记载一个或多个文件的历史记录
- 组织和保护你的源代码和文档
- 统计工作量
- 并行开发、提高开发效率
- 跟踪记录整个软件的开发过程
- 减轻开发人员的负担,节省时间,同时降低人为错误
1.2 常见的版本控制工具
-
Git
-
SVN(Subversion)
-
CVS(Concurrent Versions System)
-
VSS(Microsoft Visual SourceSafe)
-
TFS (Team Foundation Server)
-
Visual Studio Online
版本控制产品非常的多(Perforce、Rational ClearCase、RCS(GNU Revision Control System)、Serena Dimention、SVK、BitKeeper、Monotone、Bazaar、Mercurial、SourceGear Vault),现在影响力最大且使用最广泛的是Git与SVN。
1.3 版本控制的分类
1.3.1 本地版本控制
记录文件每次更新,可以对每个版本做一个快照,或是记录补丁文件,适合个人使用,如RCS。
1.3.2 集中版本控制-SVN
集中式版本控制系统有一个单一的集中管理中央服务器,保存所有文件的修订版本,由管理员管理和控制开发人员的权限,而协同开发工作的人们通过客户端连到中央服务器,从服务器上拉取最新的代码,在本地开发,开发完成再提交到中央服务器。
优点:
- 操作简单,只需拉取代码、开发、提交代码。
- 基本解决多人协作问题,每个人都可以从服务器拉取最新代码了解伙伴的开发进度。
- 同时管理员可以轻松控制各个开发者的开发权限。
- 只需要维护中央服务器的数据库即可。
缺点:
- 本地没有全套代码,没有版本信息,提交更新都需要联网与服务器进行交互,对网络的要求较高。
- 集中式通病:风险较大,服务器一旦宕机,所有人无法工作,服务器磁盘一旦损坏,如果没有备份将丢失所有数据。
总言之:所有的版本数据都存在服务器上,用户的本地只有自己以前所同步的版本,如果不连网的话,用户就看不到历史版本,也无法切换版本验证问题,或在不同分支工作。而且所有的数据都保存在单一的服务器上,有很大的风险这个服务器会损坏,这样容易导致丢失所有数据,当然也可以定期备份。代表产品:SVN、CVS、VSS
1.3.3 分布式版本控制-Git
每个人都拥有全部代码!这是个安全隐患!
分布式版本控制系统很好的解决了集中式版本控制系统的缺点。因为分布式版本控制系统保存的不是文件变化的差量,而是文件的快照,即把文件的整体复制下来。所有版本信息仓库全部同步到本地的每个用户,这样就可以在本地查看所有版本历史信息,可以离线在本地提交,只需在连网时push到相应的服务器或其他用户那里。由于每个用户那里保存的都是所有版本数据,只要有一个用户的设备没有问题就可以恢复所有的数据,但这增加了本地存储的空间占用。
不会因为服务器损坏或者网络问题,造成无法正常工作。
1.4 Git与SVN的区别
SVN是集中式版本控制系统,版本库是集中放在中央服务器的,而工作的时候,用的都是自己的电脑,所以首先要从中央服务器得到最新的版本,然后工作,完成工作后,需要把自己的代码推送到中央服务器。集中式版本控制系统是必须联网才能工作,对网络的带宽要求很高。
Git是分布式版本控制系统,没有中央服务器,每个人的电脑就是一个完整的版本库,工作的时候不需要联网,因为版本都在自己的电脑上。协同的方法如下:
自己在电脑上修改了A文件,其他人在电脑上修改了文件B,这时,你们两个人自己只需要把各自修改的推送给对方,就可以互相看到对方的修改了。Git可以直接看到更新了哪些代码和文件。
Git是目前世界上最先进的分布式版本控制系统。