Git入门
Git是一个免费的、开源的分布式版本控制系统,可以快速高效地处理从小型到大型的各种项目。
Git易于学习,占用内存小,性能极快。它具有廉价的本地库,方便的暂存区域和多个工作流分支等特性。其性能优于Subversion(svn)、CVS、Perforce和ClearCase等版本控制工具。
1. 项目管理概念
1.1 软件配置管理
代码资源管理也就是软件配置管理(SCM)是指通过执行版本控制、变更控制的规程,以及使用合适的配置管理软件来保证所有配置项的完整性和可跟踪性。代码配置管理是对工作成果的一种有效保护。
2. SCM软件工具
主要分为两大类:集中式版本控制工具、分布式版本控制工具。
- 集中化的版本控制系统诸如CVS、SVN等,都有一个单一的集中管理的服务器,保存所有文件的修订版本,而协同工作的人们都通过客户端连到这台服务器,取出最新的文件或者提交更新。多年以来,这已成为版本控制系统的标准做法。这种做法带来了许多好处,每个人都可以在一定程度上看到项目中的其他人正在做些什么。而管理员也可以轻松掌控每个开发者的权限,并且管理一个集中化的版本控制系统,要远比在各个客户端上维护本地数据库来得轻松容易。事分两面,有好有坏。这么做显而易见的缺点是中央服务器的单点故障。如果服务器宕机一小时,那么在这一小时内,谁都无法提交更新,也就无法协同工作。
- 分布式版本控制工具比如Git这种,客户端提取的不是最新版本的文件快照,而是把代码仓库完整地镜像下来(本地库)。这样任何一处协同工作用的文件发生故障,事后都可以用其他客户端的本地仓库进行恢复。因为每个客户端的每一次文件提取操作,实际上都是一次对整个文件仓库的完整备份。分布式的版本控制系统出现之后,解决了集中式版本控制系统的缺陷:
- 服务器断网的情况下也可以进行开发(因为版本控制是在本地进行的)
- 每个客户端保存的也都是整个完整的项目(包含历史记录,更加安全)
2.1 集中式版本控制工具
- Visual Source Safe
美国微软公司出品的版本控制系统,简称VSS。比较老的控制软件,对同一个文件修改会有加锁操作,其他用户需要等待提交释放锁才能修改。 - CVS
老牌的版本控制系统,它是基于客户端/服务器的行为使得其可容纳多用户,构成网络也很方便,简称为CVS。 - SVN
开放源代码的版本控制系统,通过采用分支管理系统的高效管理,简而言之就是用于多个人共同开发同一个项目,实现共享资源,实现最终集中式的管理。CVS和SVN修改同一个文件的锁级别到行,软件内部会自动比较内容是否修改相同位置。修改同一行需要人工解决。 - Rational Clear Case
IBM Rational 公司的旗舰产品之一,是全球领先的软件配置管理工具,它广泛地应用于众多的企业级软件工程实践之中,拥有众多的企业级用户。 - Perforce
一款非常优秀的商业化版本管理工具,特别是对美术资源比较友好,更新速度快安全。
2.2 分布式版本控制工具
- Mercurial
Mercurial(通常简称为hg)是一款分布式版本控制系统,它支持多种操作系统,包括Unix、Linux、Windows和MacOS。Mercurial的设计初衷是为了管理源代码的版本控制,特别适合于处理大规模的软件项目。 - Git
开源的分布式版本控制系统,可以有效、高速地处理从很小到非常大的项目版本管理。也是Linus Torvalds为了帮助管理Linux内核开发而开发的一个开放源码的版本控制软件。 - Bazaar
Bazaar(通常简称为bzr)是一款分布式版本控制系统,由 Canonical Ltd. 开发,旨在支持各种开发工作流程。Bazaar 以其易用性和灵活性而闻名,特别是在社区和开源项目中的应用。 - Darcs
Darcs是一款基于变更集(patches)管理的分布式版本控制系统,它于2002年首次发布。Darcs的设计理念与其他版本控制系统(如Git和Mercurial)有所不同,主要围绕"补丁"概念,使得用户能够以更细粒度管理和应用变更。
3. Git简史
4. 代码托管中心
代码托管中心是基于网络服务器的远程代码仓库,一般我们简单称为远程库。
- 局域网
GitLab、Gitea、Gogs - 互联网
GitHub、BitBucket、Gitee码云