Git - 分支基本实践总结与工作流原理

简介: Git - 分支基本实践总结与工作流原理

【1】分支基础

① 什么是分支

在版本控制过程中,使用多条线同时推进多个任务。

② 分支的好处?

同时并行推进多个功能开发,提高开发效率。

各个分支在开发过程中,如果某一个分支开发失败,不会对其他分支有任何影响。失败的分支删除重新开始即可。

【2】分支操作

① 创建分支

git branch [分支名]


② 查看分支

查看本地分支信息:

git branch -v

查看仓库分支详细:

git branch -a


③ 切换分支

git checkout [分支名]


④ 合并分支

如下所示,修改hot_fix分支中的apple.txt,然后提交:


那么如何合并到master中呢?

第一步:切换到接受修改的分支(被合并,增加新内容)上

git checkout [被合并分支名]
# git checkout master

第二步:执行merge 命令

git merge [有新内容分支名]
# git merge hot_fix



当然也可以将master合并到hot_fix :



⑤ 解决冲突

冲突的表现:

比如master中修改apple.txt第三行如下图:

hot_fix中修改apple.txt第三行如下图:

再次切换到master合并hot_fix,apple.txt将会出现冲突现象:


冲突的解决

第一步:编辑文件,删除特殊符号;
第二步:把文件修改到满意的程度,保存退出;
第三步:git add [文件名];
第四步:git commit -m "日志信息"。
注意:此时commit 一定不能带具体文件名


【3】哈希算法保证数据完整性

哈希是一个系列的加密算法,各个不同的哈希算法虽然加密强度不同,但是有以下

几个共同点:

  • ①不管输入数据的数据量有多大,输入同一个哈希算法,得到的加密结果长度固定。
  • ②哈希算法确定,输入数据确定,输出数据能够保证不变。
  • ③哈希算法确定,输入数据有变化,输出数据一定有变化,而且通常变化很大。
  • ④哈希算法不可逆。

Git 底层采用的是SHA-1 算法。


哈希算法可以被用来验证文件。原理如下图所示:

Git 就是靠这种机制来从根本上保证数据完整性的。

【4】Git 保存版本的机制

① 集中式版本控制工具的文件管理机制

以文件变更列表的方式存储信息。这类系统将它们保存的信息看作是一组基本文件和每个文件随时间逐步累积的差异。

即,获取到的完整文件是基本文件拼接各个“差异”得来的


② Git 的文件管理机制

Git 把数据看作是小型文件系统的一组快照。每次提交更新时Git 都会对当前的全部文件制作一个快照并保存这个快照的索引。

为了高效,如果文件没有修改,Git 不再重新存储该文件,而是只保留一个链接指向之前存储的文件。所以Git 的工作方式可以称之为快照流。



③ Git 文件管理机制细节

Git 的“提交对象”


提交对象及其父对象形成的链条


【5】Git 分支管理机制

Git分支管理的本质是创建和移动指针。

① 分支的创建



② 分支的切换

切换分支后,提交新的内容:

如这里87ab2是testing分支提交的内容。



再次切换回主分支:




主分支提交内容:

主分支提交c2b9e,未来会触发合并操作。

【6】Git工作流

Git工作流其实就是在项目开发过程中使用Git 的方式。

① 集中式工作流

像SVN 一样,集中式工作流以中央仓库作为项目所有修改的单点实体。所有修改都提交到Master 这个分支上。

这种方式与SVN 的主要区别就是开发人员有本地库。Git 很多特性并没有用到。



② GitFlow 工作流(最为经典的方式)

Gitflow 工作流通过为功能开发、发布准备和维护设立了独立的分支,让发布迭代过程更流畅。严格的分支模型也为大型项目提供了一些非常必要的结构。



③ Forking 工作流

Forking 工作流是在GitFlow 基础上,充分利用了Git 的Fork 和pull request 的功能以达到代码审核的目的。更适合安全可靠地管理大团队的开发者,而且能接受不信任贡献者的提交。

1702444116509.png


【7】GitFlow工作流详解

① 分支种类

① 主干分支master

主要负责管理正在运行的生产环境代码。永远保持与正在运行的生产环境完全一致。

② 开发分支develop

主要负责管理正在开发过程中的代码。一般情况下应该是最新的代码。

③ bug 修理分支hotfix

主要负责管理生产环境下出现的紧急修复的代码。从主干分支分出,修理完毕并测试上线后,并回主干分支。并回后,视情况可以删除该分支。

④ 准生产分支(预发布分支) release

较大的版本上线前,会从开发分支中分出准生产分支,进行最后阶段的集成测试。该版本上线后,会合并到主干分支。生产环境运行一段阶段较稳定后可以视情况删除。

⑤ 功能分支feature

为了不影响较短周期的开发工作,一般把中长期开发模块,会从开发分支中独立出来。开发完成后会合并到开发分支。


② GitFlow 工作流举例

③ 分支实战图示

如下图所示 lhc创建分支featureA并推送到远程仓库featureA分支。

ybq从远程仓库拉取下来进行测试并合并到master分支后,推送到远程Master分支。

1.png



④ 分支实战具体操作

首先是lhc的操作。

  • 创建分支

项目右键-Team-Switch To-New Branch



  • 在新分支hot_fix中修改代码并提交本地库


  • 将hot_fix推送到远程库


  • 查看GitHub远程库


接下来是ybq的操作。

  • 从远程库拉取到本地
项目-右键-pull

  • 切换分支审查代码
项目-右键-Team-Switch To -Other


  • 选择Remote Tracking下的origin/hot_fix,然后点击Check Out

  • finish

此时项目自动切换到hot_fix,可以看到lhc修改的代码。


  • 审查代码过后,切换回master,准备合并


  • 合并代码
项目-右键-Team-Merge



  • 将合并后的master推送到远程仓库



目录
相关文章
|
3月前
|
开发工具 git
git学习四:常用命令总结,包括创建基本命令,分支操作,合并命令,压缩命令,回溯历史命令,拉取命令
这篇文章是关于Git常用命令的总结,包括初始化配置、基本提交、分支操作、合并、压缩历史、推送和拉取远程仓库等操作的详细说明。
153 1
git学习四:常用命令总结,包括创建基本命令,分支操作,合并命令,压缩命令,回溯历史命令,拉取命令
|
2月前
|
测试技术 持续交付 开发工具
掌握 Git 工作流:高效团队协作的关键
【10月更文挑战第22天】本文介绍了 Git 工作流的核心概念和最佳实践,包括分支策略、提交信息、代码审查和合并策略等。通过优化这些环节,可以提高代码管理效率,促进团队成员之间的有效沟通,从而提升团队整体的开发效率。适合开发者和团队管理者阅读。
|
3月前
|
开发工具 git 开发者
关于git 解决分支冲突问题(具体操作,包含截图,教你一步一步解决冲突问题)
本文通过具体操作和截图,详细讲解了如何在Git中解决分支冲突问题,包括如何识别冲突、手动解决冲突代码、提交合并后的代码,以及推送到远程分支。
661 3
关于git 解决分支冲突问题(具体操作,包含截图,教你一步一步解决冲突问题)
|
2月前
|
开发工具 C# git
C#一分钟浅谈:Git 版本控制与 GitFlow 工作流
【10月更文挑战第22天】本文介绍了 Git 和 GitFlow 的结合使用,从基础概念到具体操作,涵盖了安装配置、基本命令、GitFlow 工作流的核心分支和流程示例。同时,文章还讨论了常见的问题和易错点,如忽略文件、冲突解决、回退提交和分支命名规范,并提供了代码案例。通过学习本文,读者可以更好地理解和应用 Git 及 GitFlow,提高团队协作效率。
67 1
|
4月前
|
缓存 开发工具 git
Git创建分支以及合并分支
在Git中,创建分支使用`git branch [branch_name]`,切换分支使用`git checkout [branch_name]`。修改文件后,通过`git add [file]`添加到暂存区,然后`git commit`提交到本地仓库。如果是新建分支的第一次推送,使用`git push origin [branch_name]`推送到远程仓库,之后可以简化为`git push`。合并分支时,使用`git merge [branch_name]`将指定分支的更改合并到当前分支。
110 2
Git创建分支以及合并分支
|
3月前
|
开发工具 git
Git分支使用总结
Git分支使用总结
57 1
|
4月前
|
测试技术 开发工具 git
掌握 Git 分支策略:提升你的版本控制技能
在现代软件开发中,版本控制至关重要,Git 作为最流行的分布式版本控制系统,其分支管理策略对于高效协作和代码维护尤为重要。本文介绍了几种常用的 Git 分支策略,包括主线开发模型、功能分支模型、Gitflow 工作流和 Forking 工作流,并探讨了如何根据项目需求选择合适的分支模型。通过保持 `master` 分支稳定、及时合并清理分支、使用命名规范、利用 Pull Request 进行代码审查及自动化测试等最佳实践,可以显著提升团队协作效率和软件质量。掌握这些策略将帮助开发者更好地管理代码库,加快开发流程。
|
4月前
|
存储 Linux 开发工具
Git基础命令,分支,标签的使用【快速入门Git】
本文详细介绍了Git版本控制系统的基础概念和常用命令,包括工作区、暂存区和版本库的区别,文件状态的变化,以及如何进行文件的添加、提交、查看状态、重命名、删除、查看提交历史、远程仓库操作和分支管理,还涉及了Git标签的创建和删除,旨在帮助读者快速入门Git。
Git基础命令,分支,标签的使用【快速入门Git】
|
3月前
|
Linux 开发工具 git
企业级Git管理工作流分析--GIT实战详解
企业级Git管理工作流分析--GIT实战详解
56 0
|
测试技术 Linux 开发工具
浅谈基于 Git 的版本控制工作流
现如今,Git 应该算是最受欢迎的版本控制工具了。例如现在世界上最大的两个代码托管平台 GitHub 和 GitLab,都是基于 Git 进行版本控制的;在国内,大家使用较多的中文代码托管平台 Gitee,也是基于 Git 进行版本控制的。由此可见,Git 作为版本控制工具,其速度快、分布式等特性,深受大家喜爱的。因此,了解基于 Git 的版本控制工作流,还是与我们有益的!
1154 0
浅谈基于 Git 的版本控制工作流