通过git log命令可以查看详细的历史版本信息。

git log命令非常强大而好用,在复杂系统的版本管理系统中扮演着重要的角色,这也说明git log命令在日常工作当中还是非常有用的。

例如:

  • 在提交了若干更新,又或者克隆了某个项目之后,你也许想回顾下提交历史。
  • 如果需要回退到之前的版本,首先我们就会查看版本库的历史版本。

1、查看详细的历史版本记录

使用git log命令列出历史提交记录如下:

$ git log
commit 3c2eabe9de439f1cc794a1672291e95a31c84c36 (HEAD -> master)
Author: sun_wk <sun_wk@126.com>
Date: Tue Apr 13 19:04:22 2021 +0800 继续新增一行数据 v8 commit 7e7006a18f22f9f73bf2475a1b23c1403b30b32f
Author: sun_wk <sun_wk@126.com>
Date: Tue Apr 13 19:03:15 2021 +0800 test.txt 文件新增一行数据 # 以下省略...

说明:

执行git log命令,不加任何参数的话,每一个版本记录单元的显示,均由五行构成:.

  • 第1行:commitid,由于Git是分布式版本控制系统,整个系统中存在有多个版本库,为了保证各个版本库中commitid不重复,所有Git中的commitid不是顺序递增的,而是与版本库,提交者,提交时间等相关的内容计算出来的一个值。
  • 第2行:作者的信息。
  • 第3行:提交的时间。
  • 第4行:分隔行,即空行。将前面所述基本信息与后面的提交说明内容进行分隔。
  • 第5行:提交说明信息。

注意:git log后不加分支名称的话,是显示当前工作分支的版本历史。(分支内容后边文章详解)

2、简化显示历史版本记录

常用参数如下:

(1)列表的形式查看历史版本记录

添加--pretty=oneline选项,以单行形式简单展示历史记录信息。

L@DESKTOP-T2AI2SU MINGW64 /j/git-repository/learngit (master)
$ git log --pretty=oneline
3c2eabe9de439f1cc794a1672291e95a31c84c36 (HEAD -> master) 继续新增一行数据 v8
7e7006a18f22f9f73bf2475a1b23c1403b30b32f test.txt 文件新增一行数据
92cf82d74084977f17976e37c69681a71f64d4fc rename readme.txt -> test.txt
fe20ce40a67a48e7f6b3bc3495bdde7a25dae61d rename test.txt -> readme.txt
995fbbe6ea16aceb9e14bdc959d6150d90d585d5 add test.txt file

(2)commit-id简写形式

使用--pretty=oneline --abbrev-commit选项或者--oneline参数。

abbrev:缩写,简写)

# --pretty=oneline --abbrev-commit
L@DESKTOP-T2AI2SU MINGW64 /j/git-repository/learngit (master)
$ git log --pretty=oneline --abbrev-commit
3c2eabe (HEAD -> master) 继续新增一行数据 v8
7e7006a test.txt 文件新增一行数据
92cf82d rename readme.txt -> test.txt
fe20ce4 rename test.txt -> readme.txt
995fbbe add test.txt file # --oneline
L@DESKTOP-T2AI2SU MINGW64 /j/git-repository/learngit (master)
$ git log --oneline
3c2eabe (HEAD -> master) 继续新增一行数据 v8
7e7006a test.txt 文件新增一行数据
92cf82d rename readme.txt -> test.txt
fe20ce4 rename test.txt -> readme.txt
995fbbe add test.txt file

以上都是我们比较常用的查看历史版本记录的方式。

3、历史版本记录常用操作

(1)指定查看最近几次提交的内容

查看最近2次的提交内容,执行命令:$ git log -n2

注意:-n2 可以直接写-2

L@DESKTOP-T2AI2SU MINGW64 /j/git-repository/learngit (master)
$ git log -n2
commit 3c2eabe9de439f1cc794a1672291e95a31c84c36 (HEAD -> master)
Author: sun_wk <sun_wk@126.com>
Date: Tue Apr 13 19:04:22 2021 +0800 继续新增一行数据 v8 commit 7e7006a18f22f9f73bf2475a1b23c1403b30b32f
Author: sun_wk <sun_wk@126.com>
Date: Tue Apr 13 19:03:15 2021 +0800 test.txt 文件新增一行数据

(2)以简单图形的方式查看分支版本历史

执行命令:$ git log -all --graph,可以更清楚的查看所有分支的演进历史。

如下图:

(3)翻页与退出

当执行git log命令显示的内容太多时,是无法在一页内显示完毕所有历史版本内容的,其最后一行会出现一个冒号,我们可以输入命令,也可以操作键盘。

常用的命令有:

  • 上下键:可以看上一行或下一行。
  • 回车:显示下一行。
  • 空格:显示下一页。
  • q键:退出git log命令显示界面。

提示:出现(END),表示历史版本信息结束。

4、查看分支相关的版本历史记录

虽然我们还没有学习分支,这里先简单了解一下。

(1)查看指定分支版本历史

执行命令:git log + 分支名称

我们就以master主分支为例:

(2)查看所有分支历史版本

执行命令:git log --all

注意:--all参数后在指定查看某个分支,他就不会在起作用了,结果会显示全部分支的提交日志。

5、总结

(1)以上的几个命令可以叠加使用。

如下:

但是注意,-n4表示的是所有分支记录总共的最后4条。

(2)如果前边用了参数--all,后边又添加了执行想看哪个分支的日志,这个执行分支是无效的,还是查看所有的分支日志。

取掉--all参数就可以查看到指定的分支。

提示:Git的指令是非常丰富的,通过git help log 或者git help --web log,可以以浏览器的方式查看更多关于log的指令。

6、拓展:git blame命令

如果要查看指定文件的修改记录可以使用git blame命令,格式如下:

git blame <file>

git blame命令是以列表形式显示修改记录,如下示例:

# 查看test.txt内容
L@DESKTOP-T2AI2SU MINGW64 /j/git-repository/learngit (master)
$ cat test.txt
hello git
hello git v4
v8 # 查看test.txt历史修改记录
L@DESKTOP-T2AI2SU MINGW64 /j/git-repository/learngit (master)
$ git blame test.txt
^995fbbe (sun_wk 2021-04-12 23:18:13 +0800 1) hello git
7e7006a1 (sun_wk 2021-04-13 19:03:15 +0800 2) hello git v4
3c2eabe9 (sun_wk 2021-04-13 19:04:22 +0800 3) v8

『现学现忘』Git基础 — 24、Git中查看历史版本记录的更多相关文章

  1. 『现学现忘』Docker基础 — 24、Docker图形化管理工具Portainer

    目录 1.Portainer介绍 2.Portainer安装启动 3.Portainer初始化配置 4.Portainer汉化 1.Portainer介绍 (1)Portainer 是一款轻量级的图形 ...

  2. 『学了就忘』Linux基础命令 — 36、查看系统痕迹相关命令

    目录 1.w命令 2.who命令 3.last命令 4.lastlog命令 5.lastb命令 系统中有一些重要的痕迹日志文件,如/var/log/wtmp./var/run/utmp./var/lo ...

  3. 『现学现忘』Git基础 — 25、git log命令参数详解

    目录 1.git log命令说明 2.git log命令参数 (1)不带参数 (2)常用显示参数 (3)--pretty参数 (4)--date=参数 (5)筛选参数 git log命令主要用于查看G ...

  4. 『现学现忘』Git后悔药 — 28、版本回退git reset --soft命令说明

    git reset --soft commit-id命令:回退到指定版本.(soft:柔软的) 该命令仅仅修改分支中的HEAD指针的位置,不会改变工作区与暂存区中的文件的版本. 实现上是只做了一件事情 ...

  5. 『现学现忘』Git后悔药 — 29、版本回退git reset --mixed命令说明

    git reset --mixed commit-id命令:回退到指定版本.(mixed:混合的,即:中等回退.) 该命令不仅修改了分支中HEAD指针的位置,还将暂存区中数据也回退到了指定版本. 但是 ...

  6. 『现学现忘』Git后悔药 — 30、版本回退git reset --hard命令说明

    git reset --hardcommit-id命令:回退到指定版本.(hard:强硬,严格的回退) 该命令不仅移动了分支中HEAD指针的位置,还将工作区和暂存区中数据也回退到了指定的版本. (提示 ...

  7. 『现学现忘』Git基础 — 35、Git中删除文件

    目录 1.删除文件说明 2.删除文件操作 (1)仅删除暂存区的文件 (2)完全删除文件 3.本文用到的命令总结 1.删除文件说明 在Git工作目录中要删除某个文件,首先要清楚该文件所处的状态. 若要是 ...

  8. 『现学现忘』Git对象 — 15、blob对象介绍

    目录 (一)Git对象的存放目录 (二)Git中对象类型 (三)blob对象 1.blob对象说明 (1)blob对象定义 (2)blob对象说明 (3)blob对象存储的方式 (4)查看blob对象 ...

  9. 『现学现忘』Git后悔药 — 34、git commit --amend 命令

    目录 1.git commit --amend 命令说明 2.使用场景 (1)场景一 (2)场景二 3.git commit --amend 命令原理 这是我们Git中的第三种后悔药. 1.git c ...

随机推荐

  1. springboot-访问数据库

    在springboot中,默认的JPA实现是Hibernate,JPA是Java Persistence API的简称,中文名Java持久层API <!--数据库--> <depen ...

  2. centos 7环境下安装部署zookeeper

    近一直在看zookeeper的知识,有所收获,打算写些一些关于zookeeper的博客,也当做是自己的复习和笔记. 在上一篇 博客中简单地介绍了centos 7 下如何安装jdk,这一篇将介绍如何在c ...

  3. 学习heartbeat-05 实现web服务高可用

    一.环境介绍 说明:所有案例在虚拟机(VMware)上完成 操作系统:centos 6.5 64bit 高可用软件:heartbeat 3.0.4 Web应用服务器:apache httpd 2.2. ...

  4. 如何在Ubuntu 18.04 LTS上安装和配置MongoDB

    MongoDB是一款非关系型数据库,提供高性能,高可用性和自动扩展企业数据库. MongoDB是一个非关系型数据库,因此您不能使用SQL(结构化查询语言)插入和检索数据,也不会将数据存储在MySQL或 ...

  5. 前端性能优化(Application Cache篇)

    正巧看到在送书,于是乎找了找自己博客上记录过的一些东西来及其无耻的蹭书了~~~ 小广告:更多内容可以看我的博客 之前在segmentfault上刷问题看到一个关于manifest的问题,很好奇就研究了 ...

  6. BeeFramework:以极客的方式开发你的应用

    BeeFramework 是新一代的应用开发框架,它能使应用开发变得更简单更容易,它是由 Gavin Kwoe 和 QFish 开发并维护的.使用 BeeFramework 能像 html 和 css ...

  7. <wx-open-launch-weapp>详解

    demo图, h5跳转小程序 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> ...

  8. input type='file'限制上传文件类型

    前端与后台数据进行对接时,就避免不了要使用ajax进行http请求,常用的请求就两个post与get:然而常见的post请求的需求是文件上传,可能我一说到文件上传大家都觉得so  easy啊,没什么嘛 ...

  9.  CPUs Intel 925X/915 Chipset (925X主板芯片组)

    这个是2004年的intel产品的设计(主板,主板芯片组,北桥,南桥),结构也比较清晰,主要想看南桥和北桥的设计. 一些英文解释 ECC是一种能够实现"错误检查和纠正"的技术D92 ...

  10. defer综合

    A "defer" statement invokes a function whose execution is deferred to the moment the surro ...