Git找回回滚后的内容和删除的文件

作者: AntDream | 来源:发表于2019-07-19 19:02 被阅读12次

本文首发于公众号“AntDream”,欢迎微信搜索“AntDream”或扫描文章底部二维码关注,和我一起每天进步一点点

Git系列

如果我已经执行了git reset --hard XXX,之前的commit的内容还能找回来吗?

首先,经过之前的学习,我们起码知道,执行完 reset回滚commit以后,之前的commit其实没有被删除,肯定还在的。

要找回之前的 commit 的内容,那我们势必得知道对应的commit 的SHA-1值吧,这个时候用git log是看不到的。

之前我们曾经提到过,就是 .git目录下有一个 logs 目录,里面记录了所有HEAD改变的记录,包括分支操作(新建、切换等),commit操作(新commit,reset等)。那我们之前 reset 也是更改了HEAD,所以这里面肯定会有我们的记录。可以用下面的方法拿到:

//是的,你没看错,加个 -g 参数就看得到了
git log -g
//或者是下面的命令
git reflog

拿到之前的 commit信息之后,我们就能找回对应的提交记录了

//可以新建一个分支指向对应的提交
git branch branchName commitId

找回删除的文件

上面 撤销add 一节中我们用的命令并不会删除工作目录中的文件,但是万一你一不小心漏掉了 --cached 参数,那效果就不一样了,会把工作目录和暂存区中的文件记录都会删除。

可以从垃圾桶里面还原出来吗?

rm 这个命令是linux命令,文件一旦通过 rm 命令删除,则无法恢复。比如:

//这样执行删除,new.txt不会出现在垃圾桶
rm new.txt

要想知道删除的文件能不能找回来,我们先得明白我们的文件信息存在于哪些地方。主要是3个:

  • 工作目录
  • 暂存区也可能有,如果之前 add 过,并且没有做过删除暂存区的操作的话
  • commit信息中,这里如果之前提交过则肯定是有的,而且一般是删除不掉的

如果我们前面是通过上面的 rm 命令删除了工作目录的文件,那我们可以从暂存区里面把文件恢复出来:

git checkout -- new.txt

如果我们是一开头的那种情况,用 git rm 命令,就会把暂存区和工作区都删除了,那还可以从最近的 commit 中恢复(当然前提是你之前已经提交过了):

git checkout HEAD readme.txt

所以综上,还是推荐大家尽量不要用带有 rm 的命令,撤销 add 操作用 reset 命令。

reset 命令操作的都是跟 commit 相关的,比如把分支重置到某次 commit,把某些文件重置到某次 commit对应的文件版本等。

同时,如果不知道怎么操作,可以用 git status 命令,它会提示一些操作:

//在 add 之后执行
git status
//输出
On branch master
Changes to be committed:
    //这句就是提示我们,如果后悔add了,可以用下面的 reset命令
  (use "git reset HEAD <file>..." to unstage)

    modified:   myTest.txt


                         欢迎关注我的公众号查看更多精彩文章!
AntDream

相关文章

  • Git找回回滚后的内容和删除的文件

    本文首发于公众号“AntDream”,欢迎微信搜索“AntDream”或扫描文章底部二维码关注,和我一起每天进步一...

  • git 总结

    参考资料:git 删除本地分支和远程分支、本地代码回滚和远程代码库回滚 git 删除分支 1. 本地分支:git ...

  • Git 常用命令

    git库管理命令 克隆远程仓库 创建本地代码库 查看历史 标签管理 回滚操作 取消对文件的修改 git删除文件 查...

  • Xcode中警告file://XXX: warning: Mis

    产生原因: 产生这个警告是Xcode中git所导致,当你对Xcode中文件或者文件的内容做出修改删除后,git都会...

  • Git 重要操作

    删除文件夹: 硬盘删除文件后,执行$ git status 会提示你仍然需要$ git rm <文件> 此时如果是...

  • git笔记

    删除已提交的文件 也可删除文件夹 回滚结点 代理设置 即使git使用的链接是https,可能使用的代理还是http...

  • rm & git rm & git rm --cached的区别

    rm 删除文件,但是没有将其懂git的记录中删除 git rm 同时从工作区和索引中删除文件,即本地的文件也被删除...

  • 删除git stash后如何恢复

    恢复误删除的git stash记录 git fsck --unreachable(找删除后的悬空对象)1.首先使用...

  • 【术语】一些基础知识

    Git: 版本控制系统,记录文件的新增,删除和修改,方便回滚代码。 GitHub: 开源代码库,有很多开源的代码可...

  • git

    git rebase -i commitid删除/回滚git reset --hard HEAD^git push...

网友评论

    本文标题:Git找回回滚后的内容和删除的文件

    本文链接:https://www.haomeiwen.com/subject/ugaskctx.html