# Git 常用使用方式

本文总结一下常用到的 git 方法,和一些自己的思考。

# 基本使用

先来看一个 github 仓库,多人开发的案例。

  • git clone github/xxx 克隆仓库。
  • git checkout -b feature/xxx 新建自己的分支。
  • 修改代码。
  • git add xxx 暂存一段代码。
  • git commit -m 'feat: xxx' 把暂存区的所有修改提交到分支上。
  • git push 推送到远程仓库。
  • 在 github 上提交 pull request 。
  • 合并后删除 feature/xxx 分支。

如果你是个新手,上面的 git 命令已经可以满足日常开发的需要了,但为了深入了解 git,我们接着往下看。

# 基本操作 API

这些命令在代码回滚,合并产生冲突时,使用率很高。

  • git status 查看状态。
  • git diff 查看工作区和版本库里面最新版本的区别。
  • git log 查看提交记录。
  • git reflog 查看每一次命令记录。
  • git reset --hard commit_id 切换到指定提交版本。
  • git revert HEAD 发起一个新的 commit,用来撤销最后一次 commit。
    • git revert 不能操作文件
  • git stash 将当前改动先存起来。git stash pop 释放之前存入的改动。

# 分支管理

规范化的开发需要严格按照分支规范来进行,我们一般这样管理分支。

  • master 线上代码分支。
  • develop 主开发分支。
    • 当无项目开发时,和 master 分支保持一致。
    • 当有项目开发时,会包含正在开发的项目代码。
  • feature/xxx 个人开发分支。
    • 从 develop 分支上拉取代码,进行功能开发。
    • 开发完成后,合并到 develop 分支。
  • release 预发布分支。
    • 从 develop 分支上拉取代码,交给测试去测。
    • 测试发现比较大的 bug,在 feature 分支上修改后,合到 develop 分支上,在重新拉取。
    • 测试发现的小 bug,直接在 release 分支上修改。
    • 合并到 master 和 develop 分支上。
  • hotfix 线上紧急修复分支。
    • 从 master 分支拉取,修改代码
    • 测试完毕后,直接合回 master 和 develop 分支。

# 分支相关的 API

  • 查看分支:git branch
  • 创建分支:git branch [name]
  • 切换分支:git checkout [name]
  • 创建 + 切换分支:git checkout -b [name]
  • 合并某分支到当前分支:git merge [name]
  • 删除分支:git branch -d [name]
  • 建立本地分支和远程分支的关联:git branch --set-upstream branch-name origin/branch-name

常规的 git 方法已经满足大部分的需求了,在多人开发的项目中,只要做好明确分工,减少代码冲突,就不会有多大的问题。

# 进阶用法

常规的 git 命令只能在理想情况下使用,面对一些其他情况,我们应该如何应对呢?

  • 怎么获取其他分支的 commit?
  • 怎么合并多个 commit?
  • 什么时候使用 git rebase?

# 获取其他分支的 commit

在 git 分支中有两个重要的概念:流水线,head 头。我们可以把 git 中的每一个分支想象成一条流水线。每一次 commit 都会在流水线上产生一个记录,同时 head 会指向最新的 commit。不同的分支控制着不同的流水线,可以通过 git merge 或者 git rebase 将流水线合并在一起。

使用 git cherry-pick 操作 commit,可以将别的分支的一个或多个 commit 合到当前分支上来。

git cherry-pick commit_id
1

# 合并多个 commit

如果要合并最后 5 次提交记录为 1 次提交记录,可以先撤销过去的 5 个 commit,然后再建一个新的。

git reset HEAD~5
git add .
git commit -am "这是合并后的commit msg"
git push --force
1
2
3
4

使用 git rebase 也可以达到同样的效果,下文将进行介绍。

# 使用 git rebase

git rebase 和 git merge 都可以用来合并分支,但合并方式不相同。

  • git merge 是将要合并的分支流水线和当前分支流水线汇合成后一条新的流水线。
  • git rebase 是将要合并的分支流水线,直接接到当前分支的流水线上。

git rebase img

图中可以看到,git rebase 过后的分支是一条流水线,而 git merge 会是两条流水线汇合成成一条。

git rebase 使用场景:

  • 如果父分支落后太多,使用 git rebase 先拉取一下。
  • 合并多个 commits。
# 合并最后5个commit
git rebase -i HEAD~5
1
2

git rebase 命令的 i 参数表示互动(interactive),这时 git 会打开一个互动界面,进行下一步操作。互动界面中,先列出当前分支最新的几个 commit(越下面越新)。每个 commit 前面有一个操作命令,默认是 pick,表示该行 commit 被选中,要进行 rebase 操作。还有一些其他操作命令:

  • pick:正常选中。
  • reword:选中,并且修改提交信息。
  • edit:选中,rebase 时会暂停,允许你修改这个 commit。
  • squash:选中,会将当前 commit 与上一个 commit 合并。
  • fixup:与 squash 相同,但不会保存当前 commit 的提交信息。
  • exec:执行其他 shell 命令。

git rebase 黄金准则

不要在公共分支上使用 git rebase。

# 参考链接