git之reflog命令的使用

 更新时间:2023年08月23日 09:42:14   作者:一户董  
git reflog 命令可以用来查看本地仓库的所有操作记录,包括所有分支的提交、合并、重置等操作,本文就详细的介绍一下如何使用,感兴趣的可以了解一下

写在前面

本文一起看下reflog命令。

1:场景描述

在开发的过程中,因为修改错误,想要通过git reset命令恢复到之前的某个版本,但是选择提交ID错误,导致多恢复了一个版本,假定,该版本对应的内容还没有push到远端仓库,并且该提交十分重要,可能决定了一个将要倒闭的公司是否能够继续 苟延残喘 ,怎么办?肯定要恢复回来,git reflog就可以帮你轻松搞定。本文从纯命令操作方式和sourcetree界面操作方式来进行模拟。

2:纯命令操作

2.1:初始化git仓库

$ pwd
/d/test/testreflog
JHP+Administrator@jhp MINGW64 /d/test/testreflog
$ git init
Initialized empty Git repository in D:/test/testreflog/.git/

2.2:执行3次提交

添加a.txt并提交

$ touch a.txt
JHP+Administrator@jhp MINGW64 /d/test/testreflog (master)
$ echo "a" > a.txt
JHP+Administrator@jhp MINGW64 /d/test/testreflog (master)
$ git add a.txt
warning: LF will be replaced by CRLF in a.txt.
The file will have its original line endings in your working directory
JHP+Administrator@jhp MINGW64 /d/test/testreflog (master)
$ git commit -m'add a.txt'
[master (root-commit) 0c70790] add a.txt
 1 file changed, 1 insertion(+)
 create mode 100644 a.txt

添加b.txt并提交

$ touch b.txt
JHP+Administrator@jhp MINGW64 /d/test/testreflog (master)
$ echo 'b' > b.txt
JHP+Administrator@jhp MINGW64 /d/test/testreflog (master)
$ git add b.txt
warning: LF will be replaced by CRLF in b.txt.
The file will have its original line endings in your working directory
JHP+Administrator@jhp MINGW64 /d/test/testreflog (master)
$ git commit -m'add b.txt'
[master b68fdbe] add b.txt
 1 file changed, 1 insertion(+)
 create mode 100644 b.txt

添加c.txt并提交

$ touch c.txt
JHP+Administrator@jhp MINGW64 /d/test/testreflog (master)
$ echo 'c' > c.txt
JHP+Administrator@jhp MINGW64 /d/test/testreflog (master)
$ git add c.txt
warning: LF will be replaced by CRLF in c.txt.
The file will have its original line endings in your working directory
JHP+Administrator@jhp MINGW64 /d/test/testreflog (master)
$ git commit -m'add c.txt'
[master 1b263f8] add c.txt
 1 file changed, 1 insertion(+)
 create mode 100644 c.txt

查看提交日志

$ git log -9 --pretty=oneline
1b263f8227fbb8050cee5bde301c11fa6a4d3467 (HEAD -> master) add c.txt
b68fdbe04611a68e16f538f1efb63727c1fc5e64 add b.txt
0c70790e7d7b54a582c81defe27a49b47df1e6db add a.txt

模拟错误操作

假定 add c.txt 是我们误操作,因此我们需要执行命令 git reset --hard b68fdbe046 来恢复到其之前的一个版本,但是操作失误,一直还原到了 add a.txt 对应的提交,如下:

$ git reset --hard 0c70790e7d7b
HEAD is now at 0c70790 add a.txt
JHP+Administrator@jhp MINGW64 /d/test/testreflog (master)
$ git log -n9 --pretty=oneline
0c70790e7d7b54a582c81defe27a49b47df1e6db (HEAD -> master) add a.txt

在准备工作中,当我们执行 git reset --hard 后,被恢复代码之后的提交通过git log就看不到了,但是git reflog其实是可以看到的,因为该命令看到的是进行过的所有的操作,对比如下图:

如下:

$ git reflog -n9 --pretty=oneline
0c70790 (HEAD -> master) HEAD@{0}: reset: moving to 0c70790e7d7b
1b263f8 HEAD@{1}: reset: moving to HEAD
1b263f8 HEAD@{2}: commit: add c.txt
b68fdbe HEAD@{3}: commit: add b.txt
0c70790 (HEAD -> master) HEAD@{4}: commit (initial): add a.txt

注意这里的 HEAD@{n} 表示head指针在n次移动之前的情况,比如我们要恢复到 add b.txt 的提交,只需要执行如下操作即可:

$ git reset --hard HEAD@{3}
HEAD is now at b68fdbe add b.txt
JHP+Administrator@jhp MINGW64 /d/test/testreflog (master)
$ git log -n3 --pretty=oneline
b68fdbe04611a68e16f538f1efb63727c1fc5e64 (HEAD -> master) add b.txt
0c70790e7d7b54a582c81defe27a49b47df1e6db add a.txt

3:sourcetree界面操作

3.1:初始化git仓库

git init

3.2:使用sourcetree打开仓库

然后选择仓库的文件夹即可。

此时因为我们什么也没有做,所以信息都是空的。

3.3:创建文件a.txt并提交

$ touch a.txt
JHP+Administrator@jhp MINGW64 /d/test/testreflog (master)
$ echo "a" > a.txt

暂存并提交:

接着同样的方式,添加b.txt,c.txt,最终如下图:

3.4:模拟错误操作

假定 add c.txt是我们误操作,因此我们需要恢复到其之前的一个版本,但是操作失误,一直还原到了add a.txt对应的提交,如下:

3.5:恢复操作

同命令行方式。这里sourcetree没有提交对应的UI操作。

写在后面

参考文章列表

【学了就忘】Git操作 — 51.git reflog命令 。

git救急之reflog恢复错误的提交 。

到此这篇关于git之reflog命令的使用的文章就介绍到这了,更多相关git reflog命令内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 科学知识:二进制、八进制、十进制、十六进制转换

    科学知识:二进制、八进制、十进制、十六进制转换

    这篇文章主要介绍了科学知识:二进制、八进制、十进制、十六进制转换,本文只介绍一些理论知识,需要的朋友可以参考下
    2015-05-05
  • Git 标签使用详解

    Git 标签使用详解

    这篇文章主要介绍了Git 标签使用详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-07-07
  • 深入解析HetuEngine实现On Yarn原理

    深入解析HetuEngine实现On Yarn原理

    这篇文章主要介绍了HetuEngine实现On Yarn原理,介绍了HetuEngine On Yarn的原理,其实现主要是借助了Yarn Service提供的能力,感兴趣的朋友一起通过本文学习下
    2022-01-01
  • chatGPT本地部署、运行和接口调用的详细步骤

    chatGPT本地部署、运行和接口调用的详细步骤

    这篇文章主要介绍了chatGPT本地部署、运行和接口调用的详细步骤,文中给大家介绍了cookie 信息写入 config.json的三种方式,每种方式给大家介绍的非常详细,需要的朋友可以参考下
    2023-02-02
  • 用asp与php实现百度ping服务的代码

    用asp与php实现百度ping服务的代码

    分别用asp与php实现百度ping服务的代码,需要的朋友可以参考下
    2012-02-02
  • 详解HBase表的数据模型

    详解HBase表的数据模型

    HBase 是一种列存储模式与键值对存储模式结合的 NoSQL 数据库,它具有灵活的数据模型,不仅可以基于键进行快速查询,还可以实现基于值、列名等的全文遍历和检索,下面给大家介绍HBase表的数据模型,感兴趣的朋友一起看看吧
    2022-05-05
  • Xshell Plus 6 下载及安装使用图文教程(解压即可使用)

    Xshell Plus 6 下载及安装使用图文教程(解压即可使用)

    本文分享一波 Xshell Plus 6 破解版,亲测有效,因为是绿色无安装版本的,下载下来后,解压即可使用,就可以直接使用了,对Xshell Plus 6 破解下载图文教程感兴趣的朋友一起看看吧
    2022-07-07
  • IEEE Spectrum 2014编程语言排行榜

    IEEE Spectrum 2014编程语言排行榜

    这篇文章主要介绍了IEEE Spectrum 2014编程语言排行榜,这不是TIOBE编程语言排行榜哦,需要的朋友可以参考下
    2014-08-08
  • 深入剖析网关gateway原理

    深入剖析网关gateway原理

    这篇文章主要介绍了网关gateway,本文从网关的背景开始讲起,一次论述网关的依赖,负载均衡,网关的选型等等进行深入的剖细,让大家可以更深一步的了解
    2021-08-08
  • vscode安装扩展Volar失败的解决方案

    vscode安装扩展Volar失败的解决方案

    volar扩展的时候,遇到了安装失败的问题,这篇文章主要给大家介绍了关于vscode安装扩展Volar失败的解决方案,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2024-05-05

最新评论