对于高级Git使用,我通常用github或BitBucket的GUI。但是GUI方法可能不能很好地解决一些需求。

所以呢,我就在本文中说几个Git基本概念。它们很有用,但可能没几个人知道。

一文带你读懂git(8个有用但不为人所知的Git概念)(1)

1、什么是 .gitkeep文件?

大家可能都了解gitignore。但是什么是gitkeep?

默认情况下,Git不跟踪空目录。文件必须存在于其中。我们可以使用.gitkeep文件将空目录添加到git repo中。

2、什么是git cherry-pick?

从另一个分支中选择更改,然后将其应用于当前分支。

这通常发生在分支合并之前。

$ git checkout $ my_branch $ git cherry-pick $ git_revision

在下图中,我们从branch2中选择了cd到branch1。

一文带你读懂git(8个有用但不为人所知的Git概念)(2)

3、如何为一个本地git repo 设置两个远程repo URL。

在测试的时候都会先推送试试看,但不想让每个人都有太多的git推送或者推送通知。所以就用到下面的。

(警告:就代码安全而言,这对于某些项目而言可能不是一个好的方法。)

为一个本地git仓库设置两个远程仓库。一个用来测试,一个用来群发。

git clone git @ github.com:devops / denny-repo.git git config remote.myremote.url git @ bitbucket.org:devops / denny-repo.git git config remote.origin.url git @ github.com:devops / denny-repo.git cat .git /config git push origin master #原始点指向github git push bitbucket master #myremote指向bitbucket

4、什么是git stash?

在不使用git提交或git推送的情况下保存本地更改。切换到另一个分支,然后稍后再回来。

#搁置并恢复不完整的更改 #临时存储所有已修改的跟踪文件 $ git stash #恢复最近保存的文件 $ git stash pop #列出所有隐藏的变更集 $ git存储列表 #丢弃最近隐藏的变更集 $ git隐藏

5、什么是git rebase?

git-rebase:在另一个基本提示之上重新应用提交。如果你不关心你的git提交历史,你可以跳过“git rebase”,但是如果你有强迫症,想要一个干净的、没有不必要的合并提交的历史,就可以在集成来自另一个分支的变更时使用git rebase而不是git merge。

6、什么是git revert??

可能有几个本地git commit。现在运行“ git push”,它将生成几个git commit历史记录。为了将它们合并为一个,我们可以使用“ git squash”技术。

#获取本地3个最新提交 $ git rebase -i HEAD~3 # 在编辑器中,将“pick”改为“squash”。将第一个保存为“pick” $ git rebase --continue $ git push origin $branch_name


7、什么是git revert?

一个有趣的比喻是将Git看作时间轴管理工具。提交是时间点或兴趣点的快照。此外,可以通过使用分支来管理多个时间线。

在Git中“撤消”时,通常会回到过去,或者回到没有发生错误的另一个时间轴。

如果我想完全放弃本地更改,则将使用git checkout。当仓库很小时,我甚至可以运行“ git clone”,然后运行git checkout。

$ git checkout $ branch_name

$ git log -n 5 $ git恢复$ git_revision $ git push origin $ branch_name

一文带你读懂git(8个有用但不为人所知的Git概念)(3)

8、什么是git reflog?

Git维护可以使用reflog访问的检查点列表。

也可以使用reflog 撤消合并,恢复丢失的提交或分支等等。

下面也是常用的Git命令速查表:

一文带你读懂git(8个有用但不为人所知的Git概念)(4)

,