Git 查看提交历史

在使用 Git 提交了若干更新之后,又或者克隆了某个项目,想回顾下提交历史,我们可以使用 git log 命令查看。

针对我们前一章节的操作,使用 git log 命令列出历史提交记录如下:

$ git log
commit cc6ec0379eabd58a3b94387fa2c3ed39d8811601
Merge: 845817d 6e61702
Author: jianmax <test@jianmax.com>
Date:   Sun Jul 28 09:41:08 2019 +0800

    Merge branch 'change_site'

commit 845817dcceccfa44b48c3c37a68f5b870d9b35fb
Author: jianmax <test@jianmax.com>
Date:   Sun Jul 28 09:37:50 2019 +0800

    修改代码

commit 6e61702f2fc26ac1218b829c209cce22d42ccabf
Author: jianmax <test@jianmax.com>
Date:   Sun Jul 28 09:35:41 2019 +0800

    changed the jianmax.go

commit 5826642b36a6e3406e1efa2ea34a6554dd32889e
Author: jianmax <test@jianmax.com>
Date:   Sun Jul 28 09:28:27 2019 +0800

    removed test.txt、add jianmax.go

commit e6d8fef51284426353d2985d367be43fa8129089
Author: jianmax <test@jianmax.com>
Date:   Sun Jul 28 09:25:15 2019 +0800

我们可以用 --oneline 选项来查看历史记录的简洁的版本。

$ git log --oneline
cc6ec03 Merge branch 'change_site'
845817d 修改代码
6e61702 changed the jianmax.go
5826642 removed test.txt、add jianmax.go
e6d8fef add test.txt file
68753c2 update README content
23ed256 第一次版本提交

这告诉我们的是,此项目的开发历史。

我们还可以用 --graph 选项,查看历史中什么时候出现了分支、合并。以下为相同的命令,开启了拓扑图选项:

$ git log --oneline --graph
*   cc6ec03 Merge branch 'change_site'
|\
| * 6e61702 changed the jianmax.go
* | 845817d 修改代码
|/
* 5826642 removed test.txt、add jianmax.go
* e6d8fef add test.txt file
* 68753c2 update README content
* 23ed256 第一次版本提交

现在我们可以更清楚明了地看到何时工作分叉、又何时归并。

你也可以用 --reverse 参数来逆向显示所有日志。

$ git log --reverse --oneline
23ed256 第一次版本提交
68753c2 update README content
e6d8fef add test.txt file
5826642 removed test.txt、add jianmax.go
6e61702 changed the jianmax.go
845817d 修改代码
cc6ec03 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={3.weeks.ago} --after={2010-04-18} --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 log 命令可查看:http://git-scm.com/docs/git-log