标签:reset 回滚 git HEAD 撤销 commitId Git 版本 commit
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 命令了,可以查看下面的参考文章
参考文章
标签:reset,回滚,git,HEAD,撤销,commitId,Git,版本,commit 来源: https://www.cnblogs.com/tangjian07/p/12193507.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。