在使用 git 提交了若干更新之後,又或者轉殖了某個專案,想回顧下提交歷史,我們可以使用 git log 命令檢視。
針對我們前一章節的操作,使用 git log 命令列出歷史提交記錄如下:
$ git log
commit d5e9fc2c811e0ca2b2d28506ef7dc14171a207d9 (head -> master)
merge: c68142b 7774248
author: runoob date: fri may 3 15:55:58 2019 +0800
merge branch 'change_site'
commit c68142b562c260c3071754623b08e2657b4c6d5b
author: runoob date: fri may 3 15:52:12 2019 +0800
修改**
commit 777424832e714cf65d3be79b50a4717aea51ab69 (change_site)
author: runoob date: fri may 3 15:49:26 2019 +0800
changed the runoob.php
commit c1501a244676ff55e7cccac1ecac0e18cbf6cb00
author: runoob date: fri may 3 15:35:32 2019 +0800
我們可以用 --oneline 選項來檢視歷史記錄的簡潔的版本。
$ git log --oneline
$ git log --oneline
d5e9fc2 (head -> master) merge branch 'change_site'
c68142b 修改**
7774248 (change_site) changed the runoob.php
c1501a2 removed test.txt、add runoob.php
3e92c19 add test.txt
3b58100 第一次版本提交
這告訴我們的是,此專案的開發歷史。
我們還可以用 --graph 選項,檢視歷史中什麼時候出現了分支、合併。以下為相同的命令,開啟了拓撲圖選項:
* d5e9fc2 (head -> master) merge branch 'change_site'
|\
| * 7774248 (change_site) changed the runoob.php
* | c68142b 修改**
|/
* c1501a2 removed test.txt、add runoob.php
* 3e92c19 add test.txt
* 3b58100 第一次版本提交
現在我們可以更清楚明了地看到何時工作分叉、又何時歸併。
你也可以用--reverse引數來逆向顯示所有日誌。
$ git log --reverse --oneline
3b58100 第一次版本提交
3e92c19 add test.txt
c1501a2 removed test.txt、add runoob.php
7774248 (change_site) changed the runoob.php
c68142b 修改**
d5e9fc2 (head -> master) merge branch 'change_site'
如果只想查詢指定使用者的提交日誌可以使用命令:git log --author , 例如,比方說我們要找 git 原始碼中 linus 提交的部分:
$ git log --author=linus --oneline -5
81b50f3 move 'builtin-*' into a 'builtin/' subdirectory
3bb7256 make "index-pack" a built-in
377d027 make "git pack-redundant" a built-in
b532581 make "git unpack-file" a built-in
112dd51 make "mktag" a built-in
如果你要指定日期,可以執行幾個選項:--since 和 --before,但是你也可以用 --until 和 --after。
例如,如果我要看 git 專案中三周前且在四月十八日之後的所有提交,我可以執行這個(我還用了 --no-merges 選項以隱藏合併提交):
$ git log --oneline --before= --after= --no-merges
5469e2d git 1.7.1-rc2
d43427d documentation/remote-helpers: fix typos and improve language
272a36b fixup: second argument may be any arbitrary string
b6c8d2d documentation/remote-helpers: add invocation section
5ce4f4e documentation/urls: rewrite to accomodate transport::address
00b84e9 documentation/remote-helpers: rewrite description
03aa87e documentation: describe other situations where -z affects git diff
77bc694 rebase-interactive: silence warning when no commits rewritten
636db2c t3301: add tests to use --format="%n"
如果你達到乙個重要的階段,並希望永遠記住那個特別的提交快照,你可以使用 git tag 給它打上標籤。
比如說,我們想為我們的 runoob 專案發布乙個"1.0"版本。 我們可以用 git tag -a v1.0 命令給最新一次提交打上(head)"v1.0"的標籤。
-a 選項意為"建立乙個帶註解的標籤"。 不用 -a 選項也可以執行的,但它不會記錄這標籤是啥時候打的,誰打的,也不會讓你新增個標籤的註解。 我推薦一直建立帶註解的標籤。
$ git tag -a v1.0
當你執行 git tag -a 命令時,git 會開啟你的編輯器,讓你寫一句標籤註解,就像你給提交寫註解一樣。
現在,注意當我們執行 git log --decorate 時,我們可以看到我們的標籤了:
* d5e9fc2 (head -> master) merge branch 'change_site'
|\
| * 7774248 (change_site) changed the runoob.php
* | c68142b 修改**
|/
* c1501a2 removed test.txt、add runoob.php
* 3e92c19 add test.txt
* 3b58100 第一次版本提交
如果我們忘了給某個提交打標籤,又將它發布了,我們可以給它追加標籤。
例如,假設我們發布了提交 85fc7e7(上面例項最後一行),但是那時候忘了給它打標籤。 我們現在也可以:
$ git tag -a v0.9 85fc7e7
$ git log --oneline --decorate --graph
* d5e9fc2 (head -> master) merge branch 'change_site'
|\
| * 7774248 (change_site) changed the runoob.php
* | c68142b 修改**
|/
* c1501a2 removed test.txt、add runoob.php
* 3e92c19 add test.txt
* 3b58100 (tag: v0.9) 第一次版本提交
如果我們要檢視所有標籤可以使用以下命令:
$ git tag
v0.9
v1.0
指定標籤資訊命令:
git tag -a -m "runoob.com標籤"
pgp簽名標籤命令:
git tag -s -m "runoob.com標籤"
Git檢視提交歷史
在使用 git 提交了若干更新之後,又或者轉殖了某個專案,想回顧下提交歷史,我們可以使用 git log 命令檢視。針對我們前一章節的操作,使用 git log 命令列出歷史提交記錄如下 git log commit 88afe0e02adcdfea6844bb627de97da21eb10af1 ...
git檢視提交歷史
git日誌的檢視 在使用 git 提交了若干更新之後,又或者轉殖了某個專案,想回顧下提交歷史,我們可以使用 git log 命令檢視。檢視日誌資訊 1 git log 可以用 oneline 選項來檢視歷史記錄的簡潔的版本 1 git log oneline 我們還可以用 graph 選項,檢視歷史...
Git 提交歷史檢視
參考 基礎 檢視提交歷史 可以看到對應的分支和更新時間,以及提交時候的commit 只用log命令有個致命問題 輸出條數太多!git log 4 4 對應著只顯示最新的4條提交記錄,同理 2 是最新兩條。git push stat stat 選項可以顯示簡略統計資訊。git log p p 選項會顯...