git删除错误的commit

文章目录

1、git删除错误的commit

git的流程如图:

当某次失误造成commit的版本有问题,需要回退到正常的版本修改后重新add。

首先通过git log查看commit提交记录,可以看到HEAD->mater是本地最新的commit,而origin/master, origin/HEAD是远程仓库上的最新记录,而一个正常的(指commit后立马push)的log长这样commit cba5300cb0c425c6db6f6bf60412d914e4225194 (HEAD -> master, origin/master, origin/HEAD),本地提交记录和远程仓库的记录是同步的。

现在我们需要将本地HEAD回退到正常版本,比如我这里回退到origin->HEAD,通过命令实现:git reset --soft c92524befc8b7913ed4b6f77fcbaf00fe1ec749e,然后git log查看日志可以看到回退成功

现在我们可以修改后再次git add后通过git status查看文件变动情况,检验是否符合期望。再使用git commit进行提交,最后git push推送到远程仓库

注:git reset 有三种模式:--soft、--hard和不加参数。

  • soft是保留工作区的内容和add提交,只是切换指针
  • hard是什么都不保留(文件夹所有内容退回为上次commit状态,文件消失;可以通过切换到最新的commit恢复,前提是知道id)
  • 不加参数是保留工作区的内容但是不保留add提交

2、.gitignore配置文件不生效的问题

gitignore文件只能作用于Untracked Files的文件,也就是一开始就没有add或者commit过的文件,如果已经进入版本控制中,修改.gitignore就不起作用。

此时可以通过git rm -r --cached .将所有文件都排除到跟踪外,即所有文件都未跟踪状态,此时再修改.gitignore就能跟新。也可以指定排除某些文件,具体可以看https://www.runoob.com/git/git-rm.html,其中--cache就是从跟踪清单中删除

相关推荐
舒一笑3 小时前
GitPulse:让代码的故事自己讲述
git·程序员·intellij idea
5***o5004 小时前
Git在代码中的GitHub
git·github
还是会想她5 小时前
git 常见命令
git
1***y1787 小时前
Git在发布流程中的自动化标签
运维·git·自动化
逻辑棱镜13 小时前
Git 分支管理与提交信息规范 (v1.0)
git·github·团队开发·代码规范·敏捷流程
悦悦欧呐呐呐呐14 小时前
git 设置邮箱和用户名
git
正经教主14 小时前
【Git】Git06:Git 管理 Android 项目教程(含GitHub)
android·git
艾莉丝努力练剑18 小时前
【Git:多人协作】Git多人协作实战:从同分支到多分支工作流
服务器·c++·人工智能·git·gitee·centos·项目管理
liuyao_xianhui1 天前
版本控制器git--gdb/cgdb
linux·运维·服务器·git
徐同保1 天前
如何使用GitKraken把git项目迁移到另一个平台,并保存所有提交记录,例如把github上的项目,迁移到gitee
git·gitee·github