1. 极牛网首页
  2. 编程开发

终于有人把 Git 分支讲清楚了!

终于有人把 Git 分支讲清楚了!

工作中git是一项必不可少的技能,在项目的开发进程中起着至关重要的作用,下面介绍一些git在工作中的一些使用实践~

一、前言

Git的定义是:分布式版本控制系统,用于项目开发中的版本控制。

从本质上来讲 Git 是一个内容寻址(content-addressable)文件系统,并在此之上提供了一个版本控制系统的用户界面。

git管理的项目工作目录下的每一个文件都不外乎这两种状态:已跟踪或未跟踪。

  • 已跟踪的文件是指那些被纳入了版本控制的文件,在上一次快照中有它们的记录,在工作一段时间后,它们的状态可能处于未修改,已修改或已放入暂存区。
  • 工作目录中除已跟踪文件以外的所有其它文件都属于未跟踪文件,它们既不存在于上次快照的记录中,也没有放入暂存区。
  • 初次克隆某个仓库的时候,工作目录中的所有文件都属于已跟踪文件,并处于未修改状态。

Git 保存的不是文件的变化或者差异,而是一系列不同时刻的文件快照。在进行提交操作时,Git 会保存一个提交对象(commit object)。该提交对象会包含一个指向暂存内容快照的指针。但不仅仅是这样,该提交对象还包含了作者的姓名和邮箱、提交时输入的信息以及指向它的父对象的指针。

二、git存储

git将项目的存储分为4部分,每部分有自己作用,见下图

终于有人把 Git 分支讲清楚了!
  • Workspace:工作区(当前用户操作修改的区域)
  • Index / Stage:暂存区 (add后的区域)
  • Repository:仓库区或本地仓库(commit后的区域)
  • Remote:远程仓库(push后的区域)

整体过程可以简述为:

  • 工作区–>add–>暂存区–>commit–>本地仓库区–>push–>远程仓库区
  • 远程仓库区–>fetch–>使用refsremotes下对应分支文件记录远程分支末端commit_id 和 本地仓库区 →merge–>工作区
  • 远程仓库区–>pull–>使用refsremotes下对应分支文件记录远程分支末端commit_id and 本地仓库区 and 工作区

git pull和git fetch有什么不同呢?下面简单说一下

想要知道他们得不同,我们需要先了解两个概念

  • FETCH_HEAD:可以看做是一个版本链接,记录在本地的refsremotes下对应分支文件中,指向着目前已经从远程仓库取下来的分支的最新版本的commit_id。
  • commit-id:在每次本地commit来保存当前工作到本地仓库区后, 会产生一个commit-id,这是一个能唯一标识一个版本的序列号。在使用git push后,这个序列号还会同步到远程仓库。

所以他们之间的不同在于:

  • git pull 直接将远程分支的修改更新到本地仓库区和本地工作区,我们就可以在本地工作区中看到最新代码
  • git fetch 只将远程分支的修改拉取到本地仓库,并更新到FETCH_HEAD,记录远程分支最新的commit_id,不会更新本地工作区代码,只有使用了git merge 才会将提交更新到本地仓库区和工作区

git status中的体现,见下图:

终于有人把 Git 分支讲清楚了!
  • Changes to be committed::代表被add的文件,被加载到了暂存区
  • Changes not staged for commit:代表在当前分支中被修改的文件,还没有被add,存储在工作区
  • Untracked files :代表不被git追踪的文件,可以理解为不被git管理的文件
  • 如果没有Changes to be committed和Changes not staged for commit说明现阶段所有的修改已经被commit到本地仓库
  • 如果git status后出现下述情况,说明还有已经的commit到本地仓库的还未被push到远程仓库

Git 作为一个系统,是以它的一般操作来管理并操纵(HEAD、index、Working Directory)三棵树的

  • HEAD:是当前分支引用的指针,它总是指向该分支上的最后一次提交。这表示 HEAD 将是下一次提交的父结点。通常,理解 HEAD 的最简方式,就是将它看做 你的上一次提交的快照。
  • index:index索引是你的 预期的下一次提交。我们也会将这个概念引用为 Git 的 “暂存区域”,这就是当你运行 git commit 时 Git 看起来的样子。Git 将上一次检出到工作目录中的所有文件填充到索引区,它们看起来就像最初被检出时的样子。之后你会将其中一些文件替换为新版本,接着通过 git commit 将它们转换为树来用作新的提交。
  • Working Directory:最后,你就有了自己的工作目录。另外两棵树以一种高效但并不直观的方式,将它们的内容存储在 .git 文件夹中。工作目录会将它们解包为实际的文件以便编辑。
终于有人把 Git 分支讲清楚了!

三、git提交规则

首先,有个问题需要确认一下,提交信息是使用中文还是英文呢?

如果你的项目是开源项目并且面向国际的开源项目,类似于阿里的DruidPingCAP的TiDB等,那么一定要是用英文提交信息的!

如果你的项目是公司内部使用或者只会被公司内部开发修改,那么中文也是不错的,更加便于查看和管理。当然,开发组中的英文能力都不错的话,用英文也是可以的。

分支Branch管理: 如果没有一个好的 branch管理的话,可能会有下述图的情况,刺不刺激~

终于有人把 Git 分支讲清楚了!

推荐的分支管理:

  • master 分支为主分支(保护分支),禁止直接在master上进行修改代码和提交,此分支的代码可以随时被发布到线上;
  • develop 分支为测试分支或者叫做合并分支,所有开发完成需要提交测试的功能合并到该分支,该分支包含最新的更改;
  • feature 分支为开发分支,大家根据不同需求创建独立的功能分支,开发完成后合并到develop分支;
  • fix 分支为bug修复分支,需要根据实际情况对已发布的版本进行漏洞修复;

标签Tag管理:

Tag 采用三段式:v版本.里程碑.序号(v2.3.1)

  • 架构升级或架构重大调整,修改第1位
  • 新功能上线或者模块大的调整,修改第2位
  • bug修复上线,修改第3位

当然,可以根据实际情况来设计,比如项目特别大,可以使用四段表达Tag,项目比较小也可以使用二段式Tag,只要符合场景并有实际意义即可.

提交信息格式: 下面只是提供一种建议格式,大家可以根据自己的项目实际情况来定格式,只要能把当前提交表达清楚,格式统一,方便快速阅读和定位即可!

  • 建议中文示例:
    • <新功能>(urllAnalyz) 添加解析url功能l
    • <修改>(TestServiceImpl) 修改某功能的某个实现为另一个实现
    • (TestUnti) 修复url特殊情况下解析失败问题 (issue#12)
    • <重构>(getData) 重构获取数据的方法
    • <测试>(getDataTest) 添加(修改、删除)获取数据的单元测试代码
    • <文档>(doc)修改(添加、删除)文档
  • 对应到英文:
    • feat: 新功能(feature)
    • style: 格式
    • fix: 修补bug
    • refactor: 重构
    • test: 测试相关
    • docs: 文档(documentation)
  • 格式(type:scope:body:issue)

<|新功能|修改|Bug修复|重构|测试>(影响模块)提交描述信息(#issue?)

  • 优点作用
    • 与github数据issue关联,便于通过issue获取更多信息
    • commit 提交时,格式统一,便于后续快速准确定位提交
    • 可以更好的将此次提交表述清楚

四、Git操作过程

初始化项目,并上传到git服务器

基本过程: 创建远程仓库、初始化本地git仓库、将本地仓库与远程仓库关联起来、添加本地仓库想要提交的代码到本地git缓冲区,将本地仓库的本地分支与远程仓库的远程分支关联起来、提交代码。

  1. 在git服务器上创建同名git项目,并获取http地址
  2. 本地git初始化项目git仓库,在项目目录下 git init
  3. 将本地git仓库和远程仓库关联起来,并设置远程仓库名称 git remote add

其中http地址为上述第一步获取的远程仓库的地址,name一般为origin,当然也可以设置其他的名字 例如:git remote add origin http://igit.corp.com/my/test.git

1、添加项目文件到本地git缓冲区

2、将本地分支关联远程分支并提交,git默认在远程分支上创建于本地分支同名的分支

这就是将本地的master分支 与 origin远程仓库关联起来并在远程仓库创建同名master分支,以后本地master都提交到远程仓库中的origin/master分支上。 upstream:上游的意思

3、至此,应该就可以了,我们可以在git服务器上刷新看看是否提交上去了

提交某一分支的修改

查看当前分支的修改

查看想要查看的文件的修改

确认正确后,提交修改到暂存区

提交到本地仓库

提交到远程仓库

拉取远程分支修改到本地分支

当远程分支别人推了一版新的代码时,我们想要将代码拉下来,可以采用两种方式pull 和 fetch+merge:(他们的不同点文章上面已经解释)

  • 使用pull:

将远程分支最新代码更新合并到本地仓库区和工作区

  • 使用fetch:

将远程所有分支最新的commit_id更新到FETCH_HEAD,记录远程分支最新的commit_id 和 本地仓库区

将最新的代码合并到工作区

取消track某一文件

untrack后,使用commit -a 时,不会将其添加到暂存区中

之后会在.ignore文件中将该untrack的文件添加进去,完成

保存账号密码,避免每次push都要输入(简单方法)

确保在git中手动输入过账号和密码

输入下面语句即可

暂存自己的修改,便于接着工作(特别有用)

如果你正在一个分支上工作修改,leader让你改另外的分支的BUG或者对其他的分支做一些操作。 我们知道如果一个分支上有还没有commit的修改的话,不可以切换分支,但是又因为自己的工作还未完成,不想commit,此时git stash 就起作用了。

你要把现在正在工作的分支保存下来,等处理完其他的再回来接着当前分支的修改工作。

将当前分支的修改暂存起来(此处不等于add+commit)

备份当前的工作区的内容,从最新的一次提交中读取相关内容,让工作区保证和上次提交的内容一致。 同时,将当前的工作区修改的内容保存到Git栈中暂存起来。

切换到别的分支工作,完成后切换回原来的工作分支,查看暂存列表

显示Git栈内的所有备份,可以利用这个列表来决定从那个地方恢复

恢复暂存的修改到工作区

从Git栈中读取最新一次保存的内容,恢复工作区的相关内容

从Git栈中读取最新一次保存的内容,恢复工作区的相关内容。之后pop会删除最新的暂存。

删除“暂存”

从Git栈删除最旧的一个暂存

其他

版本的回溯与前进

有时候需要回溯或前进到以前的版本 或 回溯前进到以前的commit

只要记住commit_id就可以在版本之间来回的穿梭,注意是可以“来回”穿梭哦

  1. 获取需要回溯到版本的commit_id

  1. 回退到该版本

  1. 如果想让服务器也回退到该版本的话

 

极牛网精选文章《终于有人把 Git 分支讲清楚了!》文中所述为作者独立观点,不代表极牛网立场。如若转载请注明出处:https://jikenb.com/12164.html

发表评论

登录后才能评论