GIt后悔药:还原提交操作(谨慎操作)
一、背景:
偶尔会遇到git的版本分支的文件被误改的情况,需要还原,此篇文章可能会帮助到你。
PS:
来理解下 Git 工作区、暂存区和版本库概念,可以更好的理解以下的还原操作。
* 工作区:就是你在电脑里能看到的目录。
* 暂存区:英文叫 stage 或 index。一般存放在 .git 目录下的 index 文件(.git/index)中,所以我们把暂存区有时也叫作索引(index)。
* 版本库:工作区有一个隐藏目录 .这个不算工作区,而是 Git 的版本库。
详解的流程图如下:
data:image/s3,"s3://crabby-images/4ba41/4ba412b9e6e4fc3e5c3abd8ab527f737024c4fdd" alt=""
二、git常用命令详解
1.git status:
查看工作区代码相对于暂存区的差别
2.git add .:
将当前目录下修改的所有代码从工作区添加到暂存区,.代步当前目录
3.git commit -m 'message':
将缓存区的内容添加至本地仓库
4.git pull orgin master:
先将远程仓库master中的信息同步到本地仓库master中
5.git push orgin master:
orgin是远程主机,master表示是远程服务器上的master分支和本地分支重名的简写,分支名是可以修改的
6.git checkout -- test001.txt (或还原全部 git checkout -- *)
将工作区修改的文件直接还原为最新版本
7.git reset HEAD
回退至当前版本(本地仓库,并移出暂存区)
8.git reset HEAD^
回退至上个版本(本地仓库,并移出暂存区)
9.git reset --hard HEAD^
回退至上一个版本(本地仓库,并移出暂存区,同时更新工作区的文件)
10.git reset --hard HEAD^^
回退至上上个版本(本地仓库,并移出暂存区,同时更新工作区的文件)
11.git reset –hard commitID
回退到某一次提交记录(不可逆,之前的提交记录会清除)
12.git revert commitID -m 1
撤销某一次的提交记录
三、还原至上一次的提交后(工作区修改了文件,未提交至暂存区)
1.举例说明,git仓库内修改文件test001.txt从 001 -> 001modify
此时界面查看文件包含感叹号.未入暂存区
echo -e 001modify > test001.txt
data:image/s3,"s3://crabby-images/c4b32/c4b322fc6ee87b4a1efe0dfc783b32f4e0a3a90d" alt=""
2.使用git checkout -- test001.txt 将工作区修改的文件直接还原.
此时查看:界面文件为绿色标记,命令行git status状态正常,无提交内容
git checkout -- test001.txt
data:image/s3,"s3://crabby-images/b0f89/b0f89ee5e41c1446381f3732eb72ae8bfc6d6acb" alt=""
data:image/s3,"s3://crabby-images/7e1f9/7e1f9a1b91d7ca5a7ebf73ebad6cb59bff35118e" alt=""
data:image/s3,"s3://crabby-images/e88fa/e88fad32393b5bdb365af9c5ac68bc9970515d73" alt=""
四、还原至上一次的提交后(工作区修改了文件,并提交至暂存区,未提交到本地仓库)
1.举例说明,git仓库内修改文件test001.txt从 001 -> 001modify,并add加入暂存区:
echo -e 001modify > test001.txt
data:image/s3,"s3://crabby-images/334a0/334a0d0775fc2718b4b2337ea1774e143e4d17dd" alt=""
2.回退当前的版本:
界面文件为感叹号标记, 查看状态暂存区内容被移出,本地文件任为修改后.
git reset HEAD
data:image/s3,"s3://crabby-images/3b4bf/3b4bfa039398cc2b4bd9c15cc41509b9ffd3b0aa" alt=""
data:image/s3,"s3://crabby-images/05ea7/05ea7024447e603991bcf6416dedb35047e7069a" alt=""
data:image/s3,"s3://crabby-images/b143f/b143f63b1dc625ffabaf795a755412bb543da3f4" alt=""
3.使用git checkout -- test001.txt 将工作区修改的文件直接还原.
此时界面文件为绿色标记,查看状态无提交内容.
git checkout -- test001.txt
data:image/s3,"s3://crabby-images/d6f53/d6f530729f5f35945f4315334ee19c1b840eb40e" alt=""
data:image/s3,"s3://crabby-images/e5d46/e5d4652acab6819077219bae8ed1d30fe7a33cf2" alt=""
五、还原至上一次的提交后(工作区修改了文件,并提交至暂存区,已提交到本地仓库,未推送远程仓库)
1.举例说明,git仓库内修改文件test001.txt从 001 -> 001modify,并add加入暂存区:
此时界面文件为感叹号标记
echo -e 001modify > test001.txt
data:image/s3,"s3://crabby-images/3d260/3d26000b1901bcf6fa368a61868a44e96de30703" alt=""
data:image/s3,"s3://crabby-images/d2a97/d2a979104a9416e575ddda481302430b1377f342" alt=""
2.使用git commit将修改提交至本地仓库,此时文件状态无感叹号,提示未push远程仓库
data:image/s3,"s3://crabby-images/12784/1278452e92d989f4573cdb48fa1e61d5b7ed32e9" alt=""
data:image/s3,"s3://crabby-images/1a775/1a775998a0c2ff01097fc00687a2d7f700668f2e" alt=""
3.使用git reset HEAD^回退到上一个版本:
此时文件状态为感叹号,修改移出暂存区
git reset HEAD^
data:image/s3,"s3://crabby-images/a3385/a3385afb9bb7665e8a68ba121fcc4159ac30c712" alt=""
data:image/s3,"s3://crabby-images/dde8d/dde8dc933cf7661896d698574612efaaa6b08c7a" alt=""
4. 使用git checkout -- test001.txt 将工作区修改的文件直接还原.
此时文件状态绿色
git checkout -- test001.txt
data:image/s3,"s3://crabby-images/c7714/c77145707feb3acf9b0de1923efa1e0689af4700" alt=""
5.git push无法将本地仓库推送至远程仓库
使用git push提示报错,因为本地仓库与远程仓库不一致
此时需要推送的话使用强制提交
git push --force
data:image/s3,"s3://crabby-images/a3ca8/a3ca8d25f5285a96ab2befb19515bc014e716123" alt=""
data:image/s3,"s3://crabby-images/e8447/e84471606cd374993b3e5d9e3be40b7de00a7a2e" alt=""
六、还原至上一次的提交后(工作区修改了文件,并提交至暂存区,已提交到本地仓库,并已推送远程仓库)
1.本地文件修改,add加入暂存区,commit提交至本地仓库,push推送到远程仓库
此时文件内容被修改,windows文件为绿色标记,状态无提交内容.
data:image/s3,"s3://crabby-images/408d3/408d349f0330a37b9a37feff813ad594db6c54e7" alt=""
data:image/s3,"s3://crabby-images/57a85/57a857a44abec999ff4e4cdc902b24aebfc07e24" alt=""
2.使用git reset HEAD^直接回退至上个版本:
此时工作区文件仍为修改后,文件状态显示已移出暂存区
git reset HEAD^
data:image/s3,"s3://crabby-images/7a51a/7a51a5eb791ea4c9aba4ab6ebdeab27666ff25e3" alt=""
3.使用git checkout -- test001.txt 将工作区修改的文件直接还原.
此时界面文件为绿色标记,查看状态无提交内容.
git checkout -- test001.txt
data:image/s3,"s3://crabby-images/385f4/385f4e3aafcbef5818b4b1281c2783965e62c84f" alt=""
data:image/s3,"s3://crabby-images/0a218/0a2182ac42539acff0882f493abebd5cacc4a628" alt=""
4.使用git push --force强制提交本地仓库至远程仓库
git push --force
data:image/s3,"s3://crabby-images/573ae/573aedbff4846ae7fa02da8557c96f554b8271ed" alt=""
七、还原至上一次的提交后(当前版本已push,一步操作)
1.本地文件修改,add加入暂存区,commit提交至本地仓库,push推送到远程仓库
此时文件内容被修改,windows文件为绿色标记,状态无提交内容.
data:image/s3,"s3://crabby-images/408d3/408d349f0330a37b9a37feff813ad594db6c54e7" alt=""
2.使用git reset --hard HEAD^还原至上一个版本
git reset --hard HEAD^
此时同时将文件从暂存区移除,并替换工作区为上个版本,界面标记为绿色
data:image/s3,"s3://crabby-images/47d96/47d9612dc5b5882ee28996f1397871c5973956ec" alt=""
data:image/s3,"s3://crabby-images/c7231/c7231333aecac889ea185da9571bb5fecdf30523" alt=""
3.使用git push --force强制提交本地仓库至远程仓库
git push --force
data:image/s3,"s3://crabby-images/573ae/573aedbff4846ae7fa02da8557c96f554b8271ed" alt=""
八.还原至上上次的提交的版本
1.两次提交记录文件修改test001.txt与test002.txt,并分别push远程仓库
通过git log查看提交的记录:
data:image/s3,"s3://crabby-images/fef1b/fef1b09a799c085f12a3d9b8c648f2daef456e46" alt=""
2.使用git reset --hard HEAD^^还原至上一个版本
git reset --hard HEAD^^
此时同时将文件从暂存区移除,并替换工作区为上个版本
data:image/s3,"s3://crabby-images/00caf/00cafcfcfa3ce5eab1e53bc942b275071f401293" alt=""
3.如需要将本地仓库推送至远程仓库使用强制提交
git push -f
九、还原至某一次提交记录
1.使用git log查看提交的记录信息
data:image/s3,"s3://crabby-images/ff309/ff30913006f1aebfc0583c67bccb8bcb10d6859e" alt=""
2. 使用git reset –hard commitID 还原到某一次提交
git reset --hard 508523eb52ffd6ca274cb01605503fb8bd6bc65a
data:image/s3,"s3://crabby-images/8b655/8b6555ad3f0ad1a836efe4492ccfab134ff168c1" alt=""
此时只会把远程版本(对应的commitId)覆盖到本地仓库,然后如果本地做了修改想要提交现修改后的版本到远程就必须强行推送
3.git push -f强制推送本地仓库直远程仓库
git push -f
data:image/s3,"s3://crabby-images/805bc/805bc663ccd77d6264e022604f968113fcf2d24d" alt=""
4.注意:操作不可逆,此时查看git log,还原版本后的记录不复存在
data:image/s3,"s3://crabby-images/e3cc6/e3cc619afd9c39b76a5bfedbe413966c6eb604b4" alt=""
十.还原掉其中一次提交并保留其余的提交
1.git log查看日志并找到需要撤销的记录
data:image/s3,"s3://crabby-images/09d81/09d81b1fcccb2ca2944dafe9acd2e778cf2b332e" alt=""
2.使用git revert commitID -m 1 命令来撤销某一次的提交
git revert 44e1cf32e0d914865d3476d3a765a83a7253586c -m 1
进入对话框保存后记录被撤销
data:image/s3,"s3://crabby-images/653f7/653f7a2d585a232fc4368c396bae6e0a7eaa66a1" alt=""
data:image/s3,"s3://crabby-images/b6a9d/b6a9d63c8205eeb663ca1bcff08694b875153b60" alt=""
3.查看git log已经撤销,无需推送
data:image/s3,"s3://crabby-images/566de/566deed8b5fd44b0d9de31db0de4f4ddf1e8247d" alt=""
ps:当存在分支合并的情况下慎用git revert,会还原已经合并记录的提交.