git 撤销本地提交
情形1:只撤销commit,但是不想将commit下的代码撤销
撤销上一次的commit (commitId 可以通过 git reflog
进行查看,下面所有的HEAD~x 都可以换成相应的commitId)
- git reset HEAD~
或者
- git reset HEAD~1
或者
- get reset
commitId
如果提交了多个commit,那么可以通过修改HEAD~后的数字,如撤销前3次的commit
- git reset HEAD~3
情境2:撤销commit,并且将commit下的代码也撤销掉
- git reset --hard HEAD~1 或者 git reset --hard
commitId
注:使用了 --hard 之后,最新的commit命令下修改的内容将会完全被撤销,慎用。
git 撤销远程提交
- git reflog 查找需要回退的版本号
- git reset --hard
commitId
回退到 commitId 版本
- git push -f 强制推送到远程分支(因为此时本地分支滞后于远程分支,必须-f 强制推送才行)
还有一个命令 git revert 也可以用来进行版本回退,需要特别注意是:
它会产生一个新的提交,虽然代码回退了,但是版本是向前的。当需要回滚公共远程分支的时候,可以使用该命令进行回滚。git revert 命令的好处就是不会丢掉别人的提交。
前面讲的撤销远程分支是只有自己一个人提交到远程分支的情况,还有一种情况是公共远程分支,如果别人也提交了,这个时候就不能简单的回滚了,否则会把别人的提交也给覆盖掉,
这个时候就需要使用到git revert 命令了,可以查看下面的参考文章
参考文章