Git实战(五)| 让工作更高效,搞定Git的分支管理

简介: 上一篇讲到Git的分支管理实操,在线合并和本地合并都进行了实操。毕竟:光说不练是假把式。而只练不整理,只能是傻把式了。分支管理到底如何进行管理呢?先以GitLab上的一张经典的图打头,作为一个总体概览,也方便理解分支的管理和走向:现假设公司有名为Hogwarts_Online2的开发项目,其中包含了上线分支master,开发分支develop,测试分支release,和个人开发的特性
更多技术文章分享和免费资料领取
https://qrcode.ceba.ceshiren.com/link?name=article&project_id=qrcode&from=Aliyun&timestamp=1651203654

上一篇讲到Git的分支管理实操,在线合并和本地合并都进行了实操。毕竟:光说不练是假把式。而只练不整理,只能是傻把式了。分支管理到底如何进行管理呢?
先以GitLab上的一张经典的图打头,作为一个总体概览,也方便理解分支的管理和走向:

现假设公司有名为Hogwarts_Online2的开发项目,其中包含了上线分支master,开发分支develop,测试分支release,和个人开发的特性分支

1.1)与远程仓库建立连接,在本地创建自己的分支,并拉取develop分支的文件:

1.2)在当前分支中创建新的文件gitflowDemo.txt,输入内容“study git”;然后add,commit

#修改分支
vi gitflowDemo.txt
#提交修改
git add gitflowDemo.txt
git commit -m "add demo"
AI 代码解读

1.3) 通过git pull命令检查远程develop分支是否和当前分支有冲突:

$ git pull origin develop
From ssh://47.95.238.18:10022/root/hogwarts_online2
 * branch            develop    -> FETCH_HEAD
Already up to date.
AI 代码解读

注: push之前先拉去远程代码,以防在开发过程中,远程被别人更新过新版本代码。如有代码冲突,两人协商冲突解决办法。多人开发的时候,冲突是不可避免的。

1.4) git push将修改推至远程特性分支origin gitflowDemo:

1.5) 在GitLab上进行merge request,并在develop分支上进行merge:
如果想要撤回这次merge可用git merge --abort

create merge request:

选择develop分支:

没有冲突,可直接merge:

最终我们可以看到成功merge进develop分支中:

我们还可以在graph中查看分支的走向:

修改gitflowDemo.txt文件为

study git
update
AI 代码解读

add,commit,push

git add gitflowDemo.txt
git commit -m "update gitflowDemo.txt"
git push -u origin gitflowDemo
AI 代码解读

切换到本地develop分支,pull最新代码,merge本地gitflowDemo分支代码,push进远程develop分支

git checkout develop
git pull origin develop
git merge gitflowDemo
git push -u origin develop
AI 代码解读

这个是在GitLab上检查更新情况:

develop分支变动频繁,master分支属于上限版本,因此需要一个内测的分支版本,这个就是release分支了
具体的提交操作根据权限范围,和1中develop的操作一致。

有的时候出现的非常紧急的bug,需要立即修改上线,来不及在各个分支上进行merge测试了;这个就是就需要用hotfixes模式,建立一个bugfix分支,直接绕开其他分支,修改合并到master中。
3.1) 建立bugfix分支,并修改文件push到远程分支:

git checkout master
git checkout -b bug_02fix

vi bugfix02.txt
fix bug02

git commit -a -m "bug_01 fix"
git push -u origin bug_01fix

git add bugfix02.txt
git commit -m "fix bug02"
git push origin bug_02fix

AI 代码解读

3.2) 这个时候检查GitLab,会发现多了一条从master分支拉出来的修改bug02的分支:

3.3)最后由最终的master权限拥有者来进行合并。

3.4)修改了bug直接上线master后,很有可能让master分支的修改已经领先其他分支了;这个时候就需要将其他分支更新,对master分支进行合并;同时将bugfix分支删除,尽量保证分支的整洁度。

git log --graph --all --decorate=short
git grep "pattern"  $(git rev-list --all)
git log f13297
AI 代码解读
git checkout feature
git rebase master
AI 代码解读

与merge后的分支走向对比:

git checkout feature
git merge master
#或者写在一行
git merge feature master
AI 代码解读

此外,rebase还可以对提交的历史进行修改(不常用也不建议使用)

git rebase -i HEAD~2
AI 代码解读

注意: rebase的使用规则
1、不要在公用的分支上执行rebase
2、主要的分支进行保护

git diff
git diff HEAD~3
git diff master develop
AI 代码解读

常见diff工具:

  • diff ——仅展示某一行的增加(+)或减少(-)
  • vimdiff ——比diff看起来要更直接
  • IDE ——强大的工具,展示清晰,使用方便
vimdiff bugfix01.txt bugfix02.txt
AI 代码解读

参考链接:

git的基本使用流程:
https://www.atlassian.com/git/tutorials/setting-up-a-repository
特性分支工作流:
https://www.atlassian.com/git/tutorials/comparing-workflows/feature-branch-workflow
gitlab工作流:
https://docs.gitlab.com/ee/workflow/gitlab_flow.html
多种工作流对比:
https://www.atlassian.com/git/tutorials/comparing-workflows
gitlab私服搭建:
https://docs.gitlab.com/omnibus/docker/

原文链接

https://qrcode.ceba.ceshiren.com/link?name=article&project_id=qrcode&from=Aliyun&timestamp=1651203654

目录
打赏
0
0
0
0
5
分享
相关文章
Git进阶笔记系列(01)Git核心架构原理 | 常用命令实战集合
通过本文,读者可以深入了解Git的核心概念和实际操作技巧,提升版本管理能力。
图解Git——分支管理《Pro Git》
分支管理是 Git 中的重要机制,支持并行开发和清晰的工作流。常用命令包括:`git branch` 列出所有分支,`git branch -v` 查看最后一次提交,`git branch --merged` 和 `git branch --no-merged` 分别查看已合并和未合并的分支。创建新分支用 `git branch <branch-name>`,删除分支用 `git branch -d`(已合并)或 `-D`(强制删除)。建议定期清理已完成任务的分支,保持代码库整洁,并使用有意义的分支命名规范。注意强制删除未合并分支时可能丢失数据。
23 5
代码管理的艺术:你的团队是否还在为 Git 分支管理头疼?
本文回顾了作者从2~3人初创团队到百人技术团队的经历,分享了代码管理工具从无到SVN再到Git的演变。重点介绍了Git Flow和GitHub Flow两种常用的Git分支管理模型,分析了它们的适用场景和优缺点。Git Flow适合中大型项目,而GitHub Flow则更适合小型团队和Web应用开发。
83 0
|
2月前
|
git分支管理master/hotfix/develop/feature/release
采用合理的Git分支管理模型可以显著提升团队协作效率和代码管理的质量。本文介绍的 `master`、`develop`、`feature`、`release`和 `hotfix`分支模型是一个行之有效的方法,适用于大多数软件开发项目。通过清晰地划分各个分支的职责,团队成员可以更专注于各自的开发任务,同时确保代码库的稳定性和可维护性。
115 2
掌握Git分支管理,提升团队协作效率
掌握Git分支管理,提升团队协作效率
52 0
【Git快速入门】Git代码管理手册与协同开发之分支管理与协作(五)
【Git快速入门】Git代码管理手册与协同开发之分支管理与协作(五)
企业级Git管理工作流分析--GIT实战详解
企业级Git管理工作流分析--GIT实战详解
63 0
【规范】Git分支管理,看看我司是咋整的
本文介绍了Git分支管理规范的重要性及其在企业中的应用。通过规范化的分支管理,可加速团队协作、确保代码质量、维护主分支稳定,并支持敏捷开发。文中详细描述了主分支(如master、develop)和辅助分支(如feature、hotfix)的作用,并提供了实际开发流程示例,包括开发前、开发中、提测、预生产和部署上线等阶段的操作方法。旨在帮助团队提高效率和代码质量。
594 0
【规范】Git分支管理,看看我司是咋整的
|
5月前
|
Git 高手之路:高级特性与实战技巧揭秘
【8月更文第16天】在日常开发工作中,Git 已成为版本控制不可或缺的工具。本文将介绍 Git 的一些高级特性和实战技巧,帮助你更好地管理项目和团队协作。
66 1

相关实验场景

更多