玖叶教程网

前端编程开发入门

8个有用但不为人所知的Git概念(git用来干嘛的)

对于高级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

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 pull?

8、什么是git reflog?

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

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

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

发表评论:

控制面板
您好,欢迎到访网站!
  查看权限
网站分类
最新留言