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>

希望有帮助~

<think>好的,用户想要找回误删的Git提交记录或文件。我需要根据提供的引用内容来整理解决方案。首先,查看用户提供的四个引用,里面提到了不同的情况和方法。 引用[1]提到两种情况:未提交的删除和已提交的删除。对于未提交的情况,直接用git checkout或者git restore恢复工作区的文件。对于已提交的情况,可以使用git checkout HEAD^ -- filename或者git revert,不过git revert可能不是最佳选择,因为它会生成反向提交。这里可能需要更详细的步骤。 引用[2]提到从提交中删除文件,但用户的问题相反,是恢复文件。不过这里提到回退到之前的提交状态,可能涉及到git resetgit checkout具体的提交哈希来找回文件。 引用[3]和引用[4]主要讨论如何删除已提交的文件,但用户需要的是恢复,所以可能需要反向操作,比如利用git reflog来找回丢失的提交,然后重置到那个提交。 现在需要综合这些信息,分情况讨论:恢复未提交的删除、恢复已提交的删除、恢复整个提交记录。可能需要使用git reflog查找丢失的提交哈希,然后用git reset --hard恢复。此外,如果文件被删除但已经提交,可以通过检出之前的版本来恢复。 还要注意用户可能混淆了恢复文件和恢复提交记录,需要明确区分两种情况,并给出对应的步骤。比如,git fsck可以找到悬空对象,但可能对普通用户来说比较复杂,可能需要作为高级方法提及。 最后,确保步骤清晰,命令正确,并提醒用户备份以防万一。同时生成相关问题,覆盖其他可能的恢复场景,比如分支删除、暂存区文件恢复等。</think>### 恢复Git误删提交记录或文件的分步指南 #### 一、恢复未提交的删除(工作区删除) 1. **直接撤销工作区修改** ```bash git restore <文件名> # Git 2.23+版本 # 或 git checkout -- <文件名> # 旧版本Git ``` #### 二、恢复已提交的删除(历史提交被删除) 1. **从最近一次提交恢复** ```bash git checkout HEAD^ -- <文件名> # 恢复前一次提交中的文件 git add <文件名> && git commit -m "恢复文件" ``` 2. **通过提交哈希找回** ```bash git log -- <文件路径> # 查找删除前的提交哈希 git checkout <commit-hash> -- <文件名> ``` 3. **使用revert撤销删除提交** ```bash git revert <删除操作的提交哈希> # 生成反向提交恢复文件 ``` #### 三、恢复丢失的提交记录 1. **通过reflog找回提交** ```bash git reflog # 查找误删操作的哈希值(如reset/rm操作前状态) git reset --hard <目标提交哈希> # 强制回退到指定提交 ``` 2. **使用fsck找回悬空对象** ```bash git fsck --lost-found # 显示所有悬空对象 git show <dangling-commit-hash> > recovered_commit.txt # 检查内容 git merge <dangling-commit-hash> # 合并回分支 ``` #### 四、恢复被强制推送覆盖的提交 ```bash git reflog # 本地仓库查找历史记录 git push -f origin <commit-hash>:<branch-name> # 重新推送丢失的提交 ``` #### 关键原理说明 Git通过对象数据库保留所有历史操作痕迹,未被垃圾回收(默认30天)的提交均可恢复[^3]。`reflog`记录本地仓库所有HEAD变化,是找回误操作的第一选择;`fsck`可发现未被引用的对象(如删除分支的提交)。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值