Git的恢复操作

Git 常用操作 - 恢复篇

Git 项目中恢复节点和代码是一项很重要的技能,但是又比较难学,各种命令容易搞混 =_+

没关系,这篇文章结合实操,直接搞定各种恢复命令!follow me ~~

checkout 命令

放弃本地还未 add 文件的修改

  1. 当你修改了工作区文件,还未 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 命令

revertreset 都可以于作回退操作,但有以下几点不同:

  1. revert 作用意义偏向反向操作,对历史节点进行反向操作;并且会新增 commit ,不会修改历史 commit 信息
  2. reset 作用意思偏向重置操作,当前指针会移至操作节点;并且会删除重置节点之后的所有节点,即修改历史 commit 信息
  3. 使用规范上:已经 push 了使用 revert 回退;还未 push 使用reset 进行回退

下线某一功能

git revert <commit> # commit为该功能的提交id

此时会产生一个新的 revert 提交id

下线后重新上线

取到当时下线的提交id

git revert <commit>

希望有帮助~

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值