场景:比如某员工误操作提交到了公司比较重要的develop分支,如何恢复到之前的某一个版本呢,git如何回滚到历史某个版本
方法一:idea里面git操作版本
1、
2、选中某一个版本,右键copy版本号
3、如何指针再指向本地的head版本号
4、提交到远程。push,会报错。应该加上-f 属性,推送ch成功。push的时候有一个小按钮
推送成功。
参考链接:Git恢复之前版本的两种方法reset、revert(图文详解)_git revert 还原-CSDN博客
方法二:命令行版本
1、git log 对应上面的1
2、拷贝版本号 对应上面的2
3、使用“git reset --hard 目标版本号”命令将版本回退: 对应上面的3
4、使用“git push -f”提交更改: 对应上面的4
此时如果用“git push”会报错,因为我们本地库HEAD指向的版本比远程库的要旧:
问题一:master不能强推,用命令行报错GitLab: Deploy key not allowed to push,如下解决
去除中间某一个版本参考
git 优雅的撤销中间某次提交_hint: after resolving the conflicts, mark the corr-CSDN博客
Git恢复之前版本的两种方法reset、revert(图文详解)_git revert 还原-CSDN博客
---------------------------------------------------------------------------------
问题二:如果 强制push 了,然后现在又想恢复刚刚写的代码了。就是取消强制push的意思。
我们可以使用 git reflog 来显示所有历史操作记录
然后使用 git reset --hard 'commit-id' 对 git push --force 进行回滚;