对于高级Git使用,我通常用github或BitBucket的GUI。但是GUI方法可能不能很好地解决一些需求。
所以呢,我就在本文中说几个Git基本概念。它们很有用,但可能没几个人知道。
1、什么是 .gitkeep文件?
大家可能都了解gitignore。但是什么是gitkeep?
默认情况下,Git不跟踪空目录。文件必须存在于其中。我们可以使用.gitkeep文件将空目录添加到git repo中。
2、什么是git cherry-pick?从另一个分支中选择更改,然后将其应用于当前分支。
这通常发生在分支合并之前。
$ git checkout $ my_branch
$ git cherry-pick $ git_revision
在下图中,我们从branch2中选择了cd到branch1。
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
在不使用git提交或git推送的情况下保存本地更改。切换到另一个分支,然后稍后再回来。
#搁置并恢复不完整的更改
#临时存储所有已修改的跟踪文件
$ git stash
#恢复最近保存的文件
$ git stash pop
#列出所有隐藏的变更集
$ git存储列表
#丢弃最近隐藏的变更集
$ git隐藏
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 pull?
8、什么是git reflog?
Git维护可以使用reflog访问的检查点列表。
也可以使用reflog 撤消合并,恢复丢失的提交或分支等等。
下面也是常用的Git命令速查表:
,