通過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行:
commit
的id
,由於Git是分散式版本控制系統,整個系統中存在有多個版本庫,為了保證各個版本庫中commit
的id
不重複,所有Git中的commit
的id
不是順序遞增的,而是與版本庫,提交者,提交時間等相關的內容計算出來的一個值。 - 第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