『現學現忘』Git基礎 — 24、Git中檢視歷史版本記錄

繁華似錦Fighting 發表於 2022-05-10
Git

通過git log命令可以檢視詳細的歷史版本資訊。

git log命令非常強大而好用,在複雜系統的版本管理系統中扮演著重要的角色,這也說明git log命令在日常工作當中還是非常有用的。

例如:

  • 在提交了若干更新,又或者克隆了某個專案之後,你也許想回顧下提交歷史。
  • 如果需要回退到之前的版本,首先我們就會檢視版本庫的歷史版本。

1、檢視詳細的歷史版本記錄

使用git log命令列出歷史提交記錄如下:

$ git log
commit 3c2eabe9de439f1cc794a1672291e95a31c84c36 (HEAD -> master)
Author: sun_wk <[email protected]>
Date:   Tue Apr 13 19:04:22 2021 +0800

    繼續新增一行資料 v8

commit 7e7006a18f22f9f73bf2475a1b23c1403b30b32f
Author: sun_wk <[email protected]>
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選項,以單行形式簡單展示歷史記錄資訊。

[email protected] 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
[email protected] 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
[email protected] 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

[email protected] MINGW64 /j/git-repository/learngit (master)
$ git log -n2
commit 3c2eabe9de439f1cc794a1672291e95a31c84c36 (HEAD -> master)
Author: sun_wk <[email protected]>
Date:   Tue Apr 13 19:04:22 2021 +0800

    繼續新增一行資料 v8

commit 7e7006a18f22f9f73bf2475a1b23c1403b30b32f
Author: sun_wk <[email protected]>
Date:   Tue Apr 13 19:03:15 2021 +0800

    test.txt 檔案新增一行資料

(2)以簡單圖形的方式檢視分支版本歷史

執行命令:$ git log -all --graph,可以更清楚的檢視所有分支的演進歷史。

如下圖:

image

(3)翻頁與退出

當執行git log命令顯示的內容太多時,是無法在一頁內顯示完畢所有歷史版本內容的,其最後一行會出現一個冒號,我們可以輸入命令,也可以操作鍵盤。

常用的命令有:

  • 上下鍵:可以看上一行或下一行。
  • 回車:顯示下一行。
  • 空格:顯示下一頁。
  • q鍵:退出git log命令顯示介面。

提示:出現(END),表示歷史版本資訊結束。

4、檢視分支相關的版本歷史記錄

雖然我們還沒有學習分支,這裡先簡單瞭解一下。

(1)檢視指定分支版本歷史

執行命令:git log + 分支名稱

我們就以master主分支為例:

image

(2)檢視所有分支歷史版本

執行命令:git log --all

image

注意:--all引數後在指定檢視某個分支,他就不會在起作用了,結果會顯示全部分支的提交日誌。

5、總結

(1)以上的幾個命令可以疊加使用。

如下:

image

但是注意,-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內容
[email protected] MINGW64 /j/git-repository/learngit (master)
$ cat test.txt
hello git
hello git v4
v8

# 檢視test.txt歷史修改記錄
[email protected] 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