git删除文件包括以下几种情况
- 删除本地文件,但是未添加到暂存区;
- 删除本地文件,并且把删除操作添加到了暂存区;
- 把暂存区的操作提交到了本地git库;
- 把本地git库的删除记录推送到了远程服务器github。
git对于删除操作有极大的撤销空间,下面分别针对上面4种情况进行恢复操作。
一、删除了本地文件,但未添加到暂存区;
选择要删除的文件12.md删除本地文件12.md
恢复文件此时发现删除错误了要进行恢复操作
二、删除了本地文件,并且已经把删除操作添加到了暂存区
删除本地文件通过git status查看状态
查看删除状态
看提示可以知道,此时如果操作 git checkout 12.md 可以恢复删除文件
如果操作 git add/rm 12.md 可以把删除状态添加到暂存区
我们进行添加操作
添加到暂存区
查看状态,可以知道删除操作已经被添加到了暂存区,
查看添加状态
此时如果要撤销操作,从提示可以知道,进行 git reset HEAD 12.md可以把删除操作退回到本地删除状态,然后按照上面1的操作就可以恢复文件
从暂存区回滚
恢复文件
三、从暂存区把删除操作提交到了本地git库
提交删除操作查看状态 git status
查看删除状态可以看到有一个提交改动,此时如果要撤销,就必须对git进行版本回滚操作
通过 git log 命令查看git库的所有版本信息
如果感觉信息太多,可以查看简洁log版本 输入 git log --pretty=oneline
简洁版log信息看到一大串类似 6aef622c4……8445f2429f的用16进制表示的字符串是每次 commit 的ID版本号,此时我们进行版本回滚操作
选择ID的前几位字符串就足够表示版本的唯一性,输入命令 git reset --hard 6aef62
四、如果删除操作已经推送到了远程github服务器中,可以通过 git push 操作来进行推送
推送到远程服务器服务器刷新前的状态
服务器刷新前的状态刷新服务器
刷新服务器后的状态可以看到文件被从服务器中删除了,如果此时进行文件恢复操作就需要像上面第三步那样进行版本回滚操作
当然了,这个版本回滚是在本地进行的,然后把回滚后的版本提交
把回滚后的版本提交到远程服务器 git push
版本提交出错可以看到提交出错,因为git默认是高版本覆盖低版本,但不能反过来操作,因为回滚的版本比服务器此时的版本低,所以此时常规手段是无效的,但可以进行版本的暴力提交——force
通过git的提示 git push -h 可以查看到 force的说明
进行暴力提交 git push -f
暴力提交刷新github远程服务器刷新操作
文件失而复得如果要在服务器中回到删除文件的高级git版本版本该怎么操作呢?
- 当然了,最简单的办法就是把费了老劲恢复的文件再次删除就可以,这样效果上是可以的,但是之前的那个git版本号其实是丢失了。
- git中有一个命令 reflog 可以查看每次提交的信息,包括 commit ID和名称,可以通过提交信息找到之前的版本好,然后重新回滚就可以了。
进行回滚操作
版本回滚成功然后再进行暴力提交
暴力提交刷新github服务器
刷新服务器
网友评论