上期提到git的提交,代码提交后,进行合并,然后上线,一系列的过程看起来是那么的和谐。突然在上线后的第二天,发现了P0级别的bug,影响80%的用户使用,这时候leader指示:“马上回退到上个版本!!!“,那这时候怎么操作呢?
首先进行文件的准备:
1、基于a.java文件进行操作。
第一个版本提交
class A {
public static void main(String args []){
System.out.println(“这是第一个版本”);
}
}
修改后进行commit提交。
2、将a.java文件修改一行内容。
修改为:
class A {
public static void main(String args []){
System.out.println(“这是第二个版本”);
}
}
修改后进行commit提交。
3、将a.java文件修改同一个行内容,
修改为:
class A {
public static void main(String args []){
System.out.println(“这是第三个版本”);
}
}
修改后进行commit提交。
开始进行操作:
4、查看提交日志。
可以看到共提交了4次,前三个版本的提交都进行了展示,最后一次提交,重新将a.java改成System.out.println(“这是第四个版本”)。
在git中,HEAD为头部指针,指向表示当前版本,也就是最新的提交。所以当前版本为第4个版本
5、此时需要回退到第三个版本。
使用git reset 命令,上一个版本就是HEAD^,上上一个版本就是HEAD^^,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100。
本地代码回滚:git reset -hard HEAD^
回滚后,将远程服务器的代码也进行回退,强制push到远程服务器,此时远程的代码已回滚。git push -f origin main
6、回退到具体某个版本:
git reset --hard ff27b4b,执行后,回退针对的是本地分支,如果需要将远程分支也回退版本,则需要进行push,但是push时会报错,提示当前本地分支是远程分支的之前的版本,此时可以强制执行push,加上-f
你回退到了某个版本,想恢复到新版本怎么办?找不到新版本的commit id怎么办?
可以使用git reflog来记录每一次命令
补充:
场景1:当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令git checkout – file。
场景2:当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,第一步用命令git reset HEAD <file>,就回到了场景1,第二步按场景1操作。
场景3:已经提交了不合适的修改到版本库时,想要撤销本次提交,参考以上。
以上为git回退到历史版本的操作。多练习,共勉!