Git 常用操作 - 恢复篇
Git 项目中恢复节点和代码是一项很重要的技能,但是又比较难学,各种命令容易搞混 =_+
没关系,这篇文章结合实操,直接搞定各种恢复命令!follow me ~~
checkout 命令
放弃本地还未 add 文件的修改
- 当你修改了工作区文件,还未 add 时想放弃这些改动操作了,使用如下命令;该命令会将暂存区内容检出到工作目录:
git checkout -- <filename> # 放弃某文件的修改
git checkout . # 放弃所有文件的修改
恢复某次提交的文件
当你只想使用 / 恢复某个版本的文件时,可以通过如下命令直接检出到当前工作区:
git checkout <branch/commit> <filename>
Reset 命令
放弃暂存区的提交,相当于 add 反向操作
git reset HEAD
commit 之前,放弃本地所有改动,操作后此时工作目录是干净的
git reset --hard HEAD
commit 之后,想修改提交信息
git commit --amend
commit 之后,想修改本次提交内容
git reset --soft HEAD^
# 修改内容add后 ... 重新commit ...
网站出问题,回滚到第N个版本前
git reset --hard <commit>
# 此时工作区是干净的
git push -f # 强制提交
或者
git reset --soft <commit>
# 此时会出现很多该版本之后的改动文件,本地一通合并修改后...
git push
网站问题排查完后,又想回到之前最新的版本:
# 因为 reset 会删除回退版本后的所有commit,需要通过 reflog 查看历史提交引用信息
git reflog
# 取历史对应的commit
git reset --hard <commit>
REVERT 命令
revert 和 reset 都可以于作回退操作,但有以下几点不同:
- revert 作用意义偏向反向操作,对历史节点进行反向操作;并且会新增 commit ,不会修改历史 commit 信息
- reset 作用意思偏向重置操作,当前指针会移至操作节点;并且会删除重置节点之后的所有节点,即修改历史 commit 信息
- 使用规范上:已经 push 了使用 revert 回退;还未 push 使用reset 进行回退
下线某一功能
git revert <commit> # commit为该功能的提交id
此时会产生一个新的 revert 提交id
下线后重新上线
取到当时下线的提交id
git revert <commit>
希望有帮助~