编程

Git使用之Git-flow

chenmo · 10月8日 · 2021年 · 本文共32014个字 · 预计阅读107分钟328次已读
朗读本文
git

前言

在9月的最后一天,面临着即将的国庆小长假,内心就像脱缰的野马在草原上肆无忌惮地放肆。永伟大哥似乎发现了这一点,因此打算给我们几个新人讲一下关于Git的事情,也算是补上之前挖的坑。特此记录。

简介

Git目前是世界上最先进的分布式版本控制系统(没有之一)。

所谓的版本控制系统,简而言之则是对于需要改动的文件每次修改的版本进行一个记录的系统。

写论文的时候经常会出现一个情况:想删除一个段落,又怕将来想恢复找不回来怎么办?有办法,先把当前文件“另存为……”一个新的Word文件,再接着改,改到一定程度,再“另存为……”一个新文件,这样一直改下去,最后一篇论文变成了:

Git使用之Git-flow

过了几天,再想找回被删除的段落,但是早已记不住忘记删除前保存在哪个文件里,只好一个个凭借记忆去找,非常麻烦。这还只是一个文档,且仅有自己一个人参与编辑,如果有多个人编辑多个文档的情况下,想要找回之前的内容,非常困难。

而所谓的版本控制系统,则是可以记录每一次文件的改动,待日后需要找到之前的版本时,非常的清晰:

版本文件名用户说明日期
1paper.doc陈默删除了软件服务条款57/12 10:38
2paper.doc陈默增加了License人数限制7/12 18:09
3paper.doc陌尘财务部门调整了合同金额7/13 9:51
4paper.doc陈默延长了免费升级周期7/14 15:17

这样,当我们想要管理多个版本的时候,非常容易。

历史

Git的历史

很多人都知道,Linus在1991年创建了开源的Linux,从此,Linux系统不断发展,已经成为最大的服务器系统软件了。

Linus虽然创建了Linux,但Linux的壮大是靠全世界热心的志愿者参与的,这么多人在世界各地为Linux编写代码,那Linux的代码是如何管理的呢?

事实是,在2002年以前,世界各地的志愿者把源代码文件通过diff的方式发给Linus,然后由Linus本人通过手工方式合并代码!

你也许会想,为什么Linus不把Linux代码放到版本控制系统里呢?不是有CVS、SVN这些免费的版本控制系统吗?因为Linus坚定地反对CVS和SVN,这些集中式的版本控制系统不但速度慢,而且必须联网才能使用。有一些商用的版本控制系统,虽然比CVS、SVN好用,但那是付费的,和Linux的开源精神不符。

不过,到了2002年,Linux系统已经发展了十年了,代码库之大让Linus很难继续通过手工方式管理了,社区的弟兄们也对这种方式表达了强烈不满,于是Linus选择了一个商业的版本控制系统BitKeeper,BitKeeper的东家BitMover公司出于人道主义精神,授权Linux社区免费使用这个版本控制系统。

安定团结的大好局面在2005年就被打破了,原因是Linux社区牛人聚集,不免沾染了一些梁山好汉的江湖习气。开发Samba的Andrew试图破解BitKeeper的协议(这么干的其实也不只他一个),被BitMover公司发现了(监控工作做得不错!),于是BitMover公司怒了,要收回Linux社区的免费使用权。

Linus可以向BitMover公司道个歉,保证以后严格管教弟兄们,嗯,这是不可能的。实际情况是这样的:

Linus花了两周时间自己用C写了一个分布式版本控制系统,这就是Git!一个月之内,Linux系统的源码已经由Git管理了!牛是怎么定义的呢?大家可以体会一下。

Git迅速成为最流行的分布式版本控制系统,尤其是2008年,GitHub网站上线了,它为开源项目免费提供Git存储,无数开源项目开始迁移至GitHub,包括jQuery,PHP,Ruby等等。

历史就是这么偶然,如果不是当年BitMover公司威胁Linux社区,可能现在我们就没有免费而超级好用的Git了。

——廖雪峰

集中式与分布式

集中式

集中式版本控制系统,版本库是集中存放在中央服务器的。客户端需要先从中央服务器获取最新的版本,然后再开始干活。当工作完成了,再将自己的版本推送到一个中央服务器。

Git使用之Git-flow

集中式版本控制系统,主要以SVNCVS等为主。

优点:

  • 版本统一:大家都是从中央服务器获取版本,因此版本都是统一的。

缺点

  • 需要网络:集中式版本控制系统最大的毛病就是必须联网才能工作,如果在局域网内还好,带宽够大,速度够快,可如果在互联网上,遇到网速慢的话,可能提交一个10M的文件就需要5分钟,效率非常慢。
  • 安全性低:中央服务器坏掉了就完蛋了。

分布式

分布式与集中式最大的区别就是没有中央服务器,每个人的电脑都具备一个完整的版本库。

这样的好处就是,即使在没有网络的情况下,也可以获取版本然后工作。即使是多人协作,也只需要把对方修改的版本推送给对方,然后就可以看到彼此的修改。

Git使用之Git-flow

分布式主要有Git, Mercurial,Bazaar,以及IBM的ClearCase(收费)。

优点

  • 安全性高:即使某一个人的电脑坏掉了,也可以从其他人复制过来;

缺点:

  • 版本不一致:由于分布式可以在不用联网的情况下工作,因此可能导致同一份工作不同人的版本大相径庭。

    • 在实际使用分布式版本控制系统的时候,通常都会有一台充当“中央服务器”的电脑,但是这服务器的作用仅仅是方便大家交换大家的修改。需要注意的是,没有它也可以继续工作,只是交换修改的时候不是很方便,因此也算不上缺点。

由于并非所有人工作的时候都可以有多台电脑,然后使用其中一台充当“中央服务器”,纵然我们也可以在一台电脑上的不同文件夹充当不同的电脑。但是当电脑硬盘坏掉的时候,所有的数据还是都消失了,所以这样意义不大。

因此,Github应运而生(当然国内的Gitee也不错),大家可以把Github当成自己分布式版本控制系统的“中央服务器”。Github还有像社区一般的功能,大家可以在上面分享自己的工作成果。有人可能会想到,为什么要把自己的代码交给第三方的平台保管,不能放在自己的服务器上自己保管吗?答案是当然可以,因此也就是以Gitlab为首的“Github私有云”版本。大部分公司应该都是使用的Gitlab将公司的代码保存在公司的服务器上,以确保数据安全性。

分支管理

Git中除了安全性与无需网络这些优点以外,最不可忽视的就是强大而分支管理系统,纵然其他版本控制系统,例如SVN也有分支管理系统,但是这些版本控制系统创建分支和切换分支比蜗牛还慢,简直让人无法忍受,最后成了摆设,大家都不用。

简述Git工作流程

在介绍分支管理系统之前,需要简单简述一下Git的工作流程。

  1. 创建Git仓库;
  2. 新增,修改文件;
  3. 将文件添加到暂存区;
  4. 将文件提交到版本库;
  5. 将文件推送到远程仓库(Github,Gitlab)

当然实际工作过程中的步骤,在不同的场景下远不止这些,但这些可以构成基础的Git工作流程。

分支管理

分支就是科幻电影里面的平行宇宙,当你正在电脑前努力学习Git的时候,另一个你正在另一个平行宇宙里努力学习SVN。

如果两个平行宇宙互不干扰,那对现在的你也没啥影响。不过,在某个时间点,两个平行宇宙合并了,结果,你既学会了Git又学会了SVN!

Git使用之Git-flow

分支在实际中有什么用呢?假设你准备开发一个新功能,但是需要两周才能完成,第一周你写了50%的代码,如果立刻提交,由于代码还没写完,不完整的代码库会导致别人不能干活了。如果等代码全部写完再一次提交,又存在丢失每天进度的巨大风险。

现在有了分支,就不用怕了。你创建了一个属于你自己的分支,别人看不到,还继续在原来的分支上正常工作,而你在自己的分支上干活,想提交就提交,直到开发完毕后,再一次性合并到原来的分支上,这样,既安全,又不影响别人工作。

分支模型

根据上述描述,应该可以知道分支是多么的重要。但由于不同人有着不同的工作习惯,即使是对于创建一个文件的名字,也会出现各种各样。例如大驼峰,小驼峰,下划线,中划线等。因此对于复杂的分支管理,也应当有清晰的流程与规划。

Vincent Driessen 为了解决这个问题提出了 A Successful Git Branching Model 以下是基于Vincent Driessen提出的Git Flow 流程图

Git使用之Git-flow

Git flow

核心分支

Git flow模型的最最核心的分支其实只有两个,Develop分支Master(Production)分支.

  • Master(Production)分支:这个分支最近发布到生产环境的可以稳定运行的代码。
  • Develop分支: 开发分支,用于开发时提交代码的分支。

对于一些小的项目或是小的开发者,有这两个分支就已经可以胜任工作了。开发一个项目时,只需要在Develop分支中开发,等到要发布版本时,再将版本发布后,Develop分支的代码合并到Master。

规范的项目上线流程:

Git使用之Git-flow

注意:项目上线时,务必要按照黑色箭头流程进行,这样即使当项目上线后,如若立马发现紧急bug,还可以将此时Master的代码(此时Master为上个版本的代码)重新再上线。因此在3-4之间应当保持一定时间间隔。

辅助分支

Git flow模型的辅助分支有三大类:Feature分支Release分支Hotfix分支

  • Feature分支:开发新需求时可以使用,等需求开发完成合并会develop,此时删除Feature分支;
  • Release分支:开发完成时可以基于Develop分支创建,创建后可以在Release分支上测试和修改bug。发布Release分支是,合并Release到Master和Develop,同时在Master分支上打个Tag记住Release版本号,然后可以删除Release分支了。
  • HotFix分支:当Master上出现了紧急bug时,需要基于Master分支创建hotfix分支,开发完成之后合并回Master分支和Develop分支,随后删掉hotfix分支。

Git Flow 命令示例

创建 Develop

开始 Feature

完成 Feature

开始 Release

完成 Release

开始 Hotfix

完成 Hotfix

 

Git常用命令

常用操作:

远程仓库:

分支命令:

标签(tag)操作:

Stash

工作中经常会出现一种情况:目前的需求未完成,突然来了一个非常紧急的需求要求立马做。此时由于之前的需求并未完成,因此最好不要执行commit提交操作。这种情况下,就可以使用stash将目前进度存储到堆栈(“抽屉”)里。

 

参考文献

 

0 条回应
这是一个很笨的机器人,别指望它能为你做点什么
  1. 你叫什么
  2. 你是男生还是女生