Git: 删除commit记录方法(删除push失败的记录)

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/quiet_girl/article/details/79487966

一、问题描述

push大文件失败,在将大文件删除之后,其余小文件仍然受到之前大文件push失败的影响,无法正常push。

二、解决方案

需要将之前含有大文件的commit记录删除(全部删除)

三、详细过程

1、将git切换到之前提交的git项目所在目录
2、使用git log命令查看commit的历史记录及其对应的commit_id,查看结果如图:
这里写图片描述
3、复制commit_id,使用Ctrl+C退出log查看页面,进入正常git可输入命令界面,输入下面命令,使git回退到commit_id的状态。

git reset --hard <commit_id>   //前面3个单词不需改变,将<commit_id>改成对应的commit_id的值

这里写图片描述
4、使用下列命令使本地和远程的内容都回退到commit_id对应的状态。

git push origin HEAD --force  //固定模式,不需要改变单词

这里写图片描述

四、参数解释

1、根据–soft –mixed –hard,会对working tree和index和HEAD进行重置:
1)git reset –mixed:此为默认方式,不带任何参数的git reset,即时这种方式,它回退到某个版本,只保留源码,回退commit和index信息。
2)git reset –soft:回退到某个版本,只回退了commit的信息,不会恢复到index file一级。如果还要提交,直接commit即可。
3)git reset –hard:彻底回退到某个版本,本地的源码也会变为上一个版本的内容。
2、
1)HEAD 最近一个提交
2)HEAD^ 上一次提交
3) 每次commit的SHA1值. 可以用git log 看到,也可以在页面上commit标签页里找到。




参考文章:
git 删除错误提交的commit

猜你喜欢

转载自blog.csdn.net/quiet_girl/article/details/79487966