如何使用Git进行回滚

回滚是 Git 的杀手锏,是程序员的后悔药。那如何进行回滚呢?答案是 git revert。接下来进行一步步演示:

  1. 通过 git init 创建仓库
  2. 然后 vi a.txt 创建一个文件,第一行写上 a,提交 gc -am 'feat: first commit'
  3. 继续 vi a.txt 创建一个文件,第二行写上 b,提交 gc -am 'fix: add b'
  4. 继续 vi a.txt 创建一个文件,第二行写上 c,提交 gc -am 'fix: add c'
  5. 继续 vi a.txt 创建一个文件,第二行写上 d,提交 gc -am 'fix: add d'

好了,此时 a.txt 的内容如下:

a
b
c
d

git log 查看历史提交记录:

commit 3ced7b954ec5023b827ba685a96f836bf1acefde (HEAD -> two, one)

    fix: add d

commit 873c8bdb57149fabbd533caa7c4b6ec9ac3adb6a

    fix: add c

commit 93ea0f972d591d54b07edba40a51b28486bbf9fd

    fix: add b

commit c58aa1bbb6d22f6ba19b89252a352abfea8d92c4

    feat: first commit

到目前为止,你的提交长这样:

是不是还挺好看的呢!我们把 commit 链描述如下:

A -> B -> C -> D

假如现在你想把最后一次提交 D 给回滚掉,应该如何操作呢?很简单:

$ git revert HEAD

这个时候,会自动生成一次提交,默认内容为:

Revert "fix: add d"

This reverts commit 3ced7b954ec5023b827ba685a96f836bf1acefde.

当然,这个是可以改的,我们先保持不动,用 :wq 保存并退出。会发现多了一次新的提交,该提交的作用就是把最后一次的提交给撤销了。

那如果不是撤销最后一次提交呢,中间任何一次都可以的,假如我们要回滚 add b 那次提交,可以用:

git revert 93ea0f972d591d54b07edba40a51b28486bbf9fd

这个时候,你期望发生什么呢?是不是 a.txt 的内容变成了:

a
c
d

然而并非如此,而是出现了冲突:

$ git revert 93ea0f972d591d54b07edba40a51b28486bbf9fd
Auto-merging a.txt
CONFLICT (content): Merge conflict in a.txt
error: could not revert 93ea0f9... fix: add b
hint: after resolving the conflicts, mark the corrected paths
hint: with 'git add <paths>' or 'git rm <paths>'
hint: and commit the result with 'git commit'

会变成了这样:

revert B 那一次操作会以 A 的状态为参考基准,即比较当前的状态和 A 状态的区别,发现冲突就会提示让用户自己去解决。

如果要撤销连续的提交,可以用一个范围来表示:

git revert 93ea0f972d591d54b07edba40a51b28486bbf9fd^..HEAD

这个时候你会发现记录变成下面这个样子了:

也就是说把 93ea0f972 和 HEAD 之间的所有提交都给按照顺序撤回了,这就是所谓的 range revert 语法:

git revert B^..D

这样就把 B,C,D 都给revert了,变成:

A-> B ->C -> D -> D'-> C' -> B'

这种方式,每次回滚都会生成一次新的提交。其实我们可以加个 -n 参数把多次合并成一次:

git revert -n 93ea0f972d591d54b07edba40a51b28486bbf9fd^..HEAD

再看提交记录:

是不是看起来就清爽多了,再复习一下语法:

git revert -n OLDER_COMMIT^..NEWER_COMMIT
git commit -m "revert OLDER_COMMIT to NEWER_COMMIT"
Git回滚提交可以通过多种方式实现,具体取决于你的需求和操作场景。以下是几种常见的回滚方式及其使用方法: ### 1. 撤销最近的 `git add` 如果只是想取消最近一次 `git add` 操作,而不影响工作目录中的文件,可以使用以下命令: ```bash git reset ``` 或者 ```bash git restore --staged <file> ``` 这两个命令都可以将暂存区中的文件撤销到工作目录中,而不会影响工作目录的内容[^1]。 --- ### 2. 回滚最近的一次提交(保留更改) 如果已经执行了 `git commit`,但希望撤销该提交,同时保留工作目录中的更改,可以使用: ```bash git reset --soft HEAD^ ``` 此命令会将最近一次提交撤销,但保留所有更改在暂存区中,方便重新提交[^2]。 --- ### 3. 回滚提交并清除更改 如果希望完全丢弃某次提交及其更改,可以使用: ```bash git reset --hard HEAD^ ``` 此命令会直接删除最近一次提交,并且工作目录中的文件也会恢复到最后一次提交前的状态。需要注意的是,这种方式是不可逆的,因此在执行之前应确保不再需要这些更改[^2]。 --- ### 4. 回滚到指定的提交 如果需要回滚到某个特定的提交,可以通过提交的 SHA 码来完成: ```bash git reset --hard dde8c25694f34acf8971f0782b1a676f39bf0a46 ``` 此命令会将当前分支的 HEAD 指针指向指定的提交,并更新工作目录和暂存区的内容。如果已经将更改推送到远程仓库,则还需要强制推送以更新远程分支: ```bash git push origin HEAD --force ``` 需要注意的是,强制推送可能会覆盖其他人的更改,因此在团队协作环境中应谨慎使用[^2]。 --- ### 5. 查看提交历史 在进行回滚操作之前,通常需要查看提交历史以确定要回滚的提交。可以使用以下命令查看提交记录: ```bash git log ``` 该命令会显示所有提交的详细信息,包括提交的 SHA 码、作者、日期和提交信息。通过这些信息可以找到需要回滚的目标提交[^2]。 --- ### 6. 使用 `git revert` 创建新的提交来撤销更改 如果不想修改提交历史,而是希望通过一个新的提交来撤销之前的更改,可以使用: ```bash git revert HEAD ``` 此命令会创建一个新的提交,其内容与最近一次提交的更改相反。这种方式不会改变提交历史,因此更适合在多人协作的项目中使用[^3]。 --- ### 注意事项 - **强制推送的风险**:如果已经将提交推送到远程仓库,并且其他人可能基于这些提交进行了工作,那么使用 `git reset` 和 `git push --force` 可能会导致冲突或数据丢失。在这种情况下,建议优先考虑使用 `git revert`。 - **备份分支**:在执行任何回滚操作之前,最好先创建一个备份分支,以防万一需要恢复原始状态。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值