探索使用Git进行版本控制
创作时间:
作者:
@小白创作中心
探索使用Git进行版本控制
引用
1
来源
1.
https://learn.microsoft.com/zh-cn/training/modules/develop-with-devops/3-explore-version-control-using-git
版本控制系统(VCS)有不同类型,但通常可分类为集中式和分布式。近年来(在某种程度上由于DevOps越来越受欢迎),后一类获得了非常广泛的普及,Git成为现代软件开发中事实上的标准。在我们的示例方案中,这个特定的VCS将是组织最合适的选择,特别是考虑到其打算使用GitHub作为其DevOps过渡的目标平台。本单元将探索如何将Git用作版本控制系统。
集中式与分布式版本控制
集中式版本控制系统(CVCS)和分布式版本控制系统(DVCS)都提供了管理和跟踪软件开发项目中的更改的能力。它们之间的主要区别与它们实现存储库和协作的方式有关。具体而言:
- 存储库位置:在集中式系统中,有一个集中的存储库实例,其中包含项目的完整历史记录。在分布式系统中,每个团队成员通常都会拥有整个存储库的一个功能齐全的本地副本,这可能包括其完整的版本历史记录。
- 网络连接:在集中式系统中,需要访问存储库的集中式实例来执行许多操作,包括更新和历史检索。在分布式系统中,所有活动都可以针对存储库的本地副本执行。
- 协作模型:在集中式系统中,开发人员先在通过网络连接到集中的存储库实例时签出文件,然后再进行修改并提交更改。这样可以防止更改成为其他人签出的文件。在分布式系统中,开发人员对存储库的本地副本进行更改并提交更改,这些更改在稍后的某个时刻与其他副本同步。
- 分支和合并模型:在集中式系统中,分支和合并通常需要与他人协作。在分布式系统中,分支可以在本地副本中独立创建并随后合并。
值得注意的是,虽然分布式模型不依赖于拥有中央存储库(在传统意义上而言),但通常会实现存储库的一个副本,该副本由GitHub、GitLab或Bitbucket等服务托管。此实例充当协作和同步的焦点。
Git术语
为了熟练使用Git,必须熟悉其术语。有些概念是Git所独有的,这将它与其他DVCS区分开来。最基本的Git术语包括:
- 工作树:一个目录结构,其中包含项目的所有文件。
- 存储库(通常称为repo):位于工作树顶层的目录,托管项目的所有文件以及这些文件的版本历史记录。
- 克隆:一种操作,用于在本地计算机上创建远程存储库副本以处理你有权访问的项目。
- 分叉:一种操作,用于创建远程存储库的GitHub托管副本以处理你无权访问的项目。如果你打算为其他人的项目做出贡献或创建你自己的此类项目版本,则通常会使用分叉。虽然你对原始存储库没有写入访问权限,但你可以完全管理你的分叉。
- 提交:在特定时间点对存储库中的文件所做的更改快照。提交用于记录和保存更改。
- 暂存区域:一个中间位置(不是存储库的一部分),对工作树中的文件的更改在提交之前会在该位置准备好。它允许开发人员选择他们要提交的更改。
- 分支:一系列已命名的关联提交。简单而言,分支表示项目的不同版本。通过使用分支,便可以同时处理项目的不同部分,而不会影响其主版本。一个分支内的最新提交称为“head”。初始化存储库时自动生成的默认分支称为“main”或“master”。
- 合并:将更改从一个分支(或提交)合并到另一个分支的过程。这会将更改从一个分支集成到另一个分支中。
- 对象:存储库中可用的四种实体类型之一。这些实体包括:表示各个文件的blob、表示工作树的树、表示工作树的特定版本的提交,以及标签(分配给单个提交的标签)。
- 哈希:一个自动生成的固定长度的唯一标识符,表示对象的内容。每当该对象发生更改时,其哈希也会更改。这使Git可以确定存储库中的哪些内容已更新。
- 远程库:对另一个存储库(非本地存储库)的引用,通常指向存储库的服务托管实例。这充当推送和拉取操作的默认位置。
- 拉取:一种操作,用于从远程存储库提取更改,并将这些更改合并到当前分支中。
- 推送:一种操作,用于将本地提交发送到远程存储库,从而使用本地所做的更改对该存储库进行更新。
- 提取:一种操作,用于从远程存储库检索更改,但不会自动合并这些更改。使用提取操作,便可以在应用合并之前进行审查。
- 拉取请求:基于Git的托管平台(如GitHub)中的一项功能,允许开发人员提议更改并请求将更改合并到目标分支中。
Git还有一组广泛的命令,使用户可以通过Linux Bash或Windows命令提示符等命令行界面完全实现和管理版本控制。也可以通过桌面应用程序(如GitHub Desktop)管理Git。基于Git的托管平台提供了一个Web界面,可促进与服务端存储库的交互。
Git与GitHub
如前所述,Git是一种多平台开源DVCS,它通过使用本地存储库促进协作,可与远程存储库同步。GitHub是一项基于云的服务,为Git存储库提供托管平台。它通过包含对以下各项的支持来扩展Git功能范围:
- 远程存储库:促进分布式团队之间的交互。
- 协作工具:提供问题、讨论、拉取请求、通知、标签、操作、分叉、wiki和项目等功能。
- 基于Web的接口:最大程度地减少使用Git命令的需求
- 分支保护:强制满足在发生合并前必须满足的条件(例如,完成拉取请求审查)。
本文原文来自微软官方文档
热门推荐
视觉盛宴绽放时代之美——评北京国际摄影周2024“云影像”大众手机摄影展
热继电器工作原理动画图解
日本医疗再次被评为全球第一,中国则位居64,差距到底在哪儿?
卡座连接器的特点及应用分析
汽车空气滤芯和空调滤芯是同一种东西吗?
卷卷耳技能(宝可梦——卷卷耳,长耳兔)
内存条双通道对比单通道有哪些优势
函数凹凸性与二阶导数关系的数学证明
美国公司变更地址:步骤、注意事项及费用
鄠邑区口腔医院电话(快速获取鄠邑区口腔医院联系方式)
螺翼式水表的表前阀和表后阀的区别是什么?
戴尔·卡耐基:人际关系学的奠基者
如何看待国际金价的变化情况?这种变化对金融市场有何冲击?
常熟:用“城市温度”,让“福地”更有“福气”
河北省眼科医院测瞳距需要注意什么?瞳距检查的详细过程介绍
2024年南京河西外国语学校小升初招生简章(附收费标准)
核桃一天吃多少?长期食用有补脑作用?营养师拆解核桃功效与禁忌!
激战过后的霸权更迭:英国与纳粹德国的海上较量
新手攀岩全攻略:从岩馆选择到装备技巧
快速办护照指南:加急服务与材料准备常见错误清单
如何计算钢管的理论重量
保持与病原体同步:改善基于基因组数据的铜绿假单胞菌的耐药性预测
最新研究显示,喜欢在聊天中使用表情包的人,情商更高
表情包所有权:探讨表情包在网络文化中的地位与影响
儿童床木材哪种好?挑选安全环保的木质材料
了解你的心率,让运动更简单!
仲裁证据怎么取
合同有仲裁条款必须适用仲裁吗?
反复发烧是什么原因
谷氨酸钠是什么东西