[转]恢复 git reset -hard 的误操作
2015-11-17 09:45
369 查看
转帖:http://hi.baidu.com/configuration/item/97fddeea252818d0eb34c964
有时候使用Git工作得小心翼翼,特别是涉及到一些高级操作,例如
reset, rebase 和 merge。甚至一些很小的操作,例如删除一个分支,
我都担心数据丢失。
不
久之前,我在做一些大动作(rebasing)之前,我总是备份整个版本库,以防万一。直到最近我才发现git的历史记录是不可修改的,
也就是说你不能更改任何已经发生的事情。你做的任何操作都只是在原来的操作上修改。也就是说,即使你删除了一个分支,修改了一个提交,
或者强制重置,你仍然可以回滚这些操
作。
让我们来看一些例子:
$ git init
$ touch
foo.txt
$ git add
foo.txt
$ git commit -m
"initial commit"
$ echo 'new data'
>> foo.txt
$ git commit -a -m
"more stuff added to foo"
你现在看git的历史记录,你可以看到两次提交:
$ git log
* 98abc5a (HEAD,
master) more stuff added to foo
* b7057a9 initial
commit
现在让我们来重置回第一次提交的状态:
$ git reset --hard
b7057a9
$ git log
* b7057a9 (HEAD,
master) initial commit
这看起来我们是丢掉了我们第二次的提交,没有办法找回来了。但是 reflog
就是用来解决这个问题的。简单的说,它会记录所有HEAD的历史,
也就是说当你做
reset,checkout等操作的时候,这些操作会被记录在reflog中。
$ git
reflog
b7057a9 HEAD@{0}:
reset: moving to b7057a9
98abc5a HEAD@{1}:
commit: more stuff added to foo
b7057a9 HEAD@{2}:
commit (initial): initial commit
所以,我们要找回我们第二commit,只需要做如下操作:
$ git reset --hard
98abc5a
再来看一下 git
记录:
$ git log
* 98abc5a (HEAD,
master) more stuff added to foo
* b7057a9 initial
commit
所以,如果你因为reset等操作丢失一个提交的时候,你总是可以把它找回来。除非你的操作已经被git当做垃圾处理掉了,一般是30天以后。
有时候使用Git工作得小心翼翼,特别是涉及到一些高级操作,例如
reset, rebase 和 merge。甚至一些很小的操作,例如删除一个分支,
我都担心数据丢失。
不
久之前,我在做一些大动作(rebasing)之前,我总是备份整个版本库,以防万一。直到最近我才发现git的历史记录是不可修改的,
也就是说你不能更改任何已经发生的事情。你做的任何操作都只是在原来的操作上修改。也就是说,即使你删除了一个分支,修改了一个提交,
或者强制重置,你仍然可以回滚这些操
作。
让我们来看一些例子:
$ git init
$ touch
foo.txt
$ git add
foo.txt
$ git commit -m
"initial commit"
$ echo 'new data'
>> foo.txt
$ git commit -a -m
"more stuff added to foo"
你现在看git的历史记录,你可以看到两次提交:
$ git log
* 98abc5a (HEAD,
master) more stuff added to foo
* b7057a9 initial
commit
现在让我们来重置回第一次提交的状态:
$ git reset --hard
b7057a9
$ git log
* b7057a9 (HEAD,
master) initial commit
这看起来我们是丢掉了我们第二次的提交,没有办法找回来了。但是 reflog
就是用来解决这个问题的。简单的说,它会记录所有HEAD的历史,
也就是说当你做
reset,checkout等操作的时候,这些操作会被记录在reflog中。
$ git
reflog
b7057a9 HEAD@{0}:
reset: moving to b7057a9
98abc5a HEAD@{1}:
commit: more stuff added to foo
b7057a9 HEAD@{2}:
commit (initial): initial commit
所以,我们要找回我们第二commit,只需要做如下操作:
$ git reset --hard
98abc5a
再来看一下 git
记录:
$ git log
* 98abc5a (HEAD,
master) more stuff added to foo
* b7057a9 initial
commit
所以,如果你因为reset等操作丢失一个提交的时候,你总是可以把它找回来。除非你的操作已经被git当做垃圾处理掉了,一般是30天以后。
相关文章推荐
- centos linux 6.5 yum 从本地光盘安装system-config-kickstart
- poi 读取excel 2003 及 2007 精简版
- C++STL::两种方式实现STL容器的reference语义
- Jsp页面点击量统计
- Codeforces Round #331 (Div. 2) C. Wilbur and Points
- Linux文件系统(四)---三大缓冲区之inode缓冲区 (内存inode映像 )
- 移动Web单页应用开发实践——页面结构化
- postgreSQL
- ASCII, LATIN1, UTF8 简介
- SVN提交提示添加注释
- C++Managed中加入fiddler的BeforeRequest
- 随机森林 & GBDT
- 软件项目管理与素质拓展-序
- git分支合并到master
- 学习点1:可选择的复选框
- 你必须知道的10个提高Canvas性能技巧
- Linux 文件系统(三)---dup和fork函数执行后的文件情况
- java synchronized详解
- 毫秒转成时分秒
- Unity 配置使 .prefab 可以文本化阅读修改