一、提交历史
- 在使用Git提交了若干更新之后,又或者克隆了某个项目,想回顾下提交历史,我们可以使用gitlog命令查看。
命令格式:git log
举例使用gitlog命令列出历史提交记录如下:
$gitlog
commit88afe0e02adcdfea6844bb627de97da21eb10af1
Merge:14b4dcad7e7346
Author:Leon1023<liangzc1124@163.com>
Date:SunMar115:03:422018+0800
Mergebranch'change_site'
Conflicts:
test.txt
commit14b4dcadbdc847207651d5a9fae0d315057f346e
Author:Leon1023<liangzc1124@163.com>
Date:SunMar114:53:152018+0800
A new line
commitd7e734640da06055e107eaf29cf350b3f1de1c2c
Author:Leon1023<liangzc1124@163.com>
Date:SunMar114:48:572018+0800
changedthesite
commit556f0a0637978097b82287ac665a717623b21f3f
Author:Leon1023<liangzc1124@163.com>
Date:SunMar114:40:342018+0800
removedtest2.txt
---oneline选项,查看历史记录的简洁版本
$gitlog--oneline
88afe0eMergebranch'change_site'
14b4dcaA new line
d7e7346changedthesite
556f0a0removedtest2.txt
2e082b7addtest2.txt
048598faddtest.txt
85fc7e7testcommentfromrunoob.com
---graph选项,开启了拓扑图显示历史提交关系
$gitlog--oneline--graph
*88afe0eMergebranch'change_site'
|
|*d7e7346changedthesite
*|14b4dcaA new line
|/
*556f0a0removedtest2.txt
*2e082b7addtest2.txt
*048598faddtest.txt
*85fc7e7testcommentfromrunoob.com
- --reverse选项,逆向显示所有日志。
$gitlog--reverse--oneline
85fc7e7testcommentfromrunoob.com
048598faddtest.txt
2e082b7addtest2.txt
556f0a0removedtest2.txt
d7e7346changedthesite
14b4dca新增加一行
88afe0eMergebranch'change_site'
- --author=[username]选项,只查找指定用户的提交日志
如下为只找Git源码中Linus提交的部分:
$gitlog--author=Linus--oneline-5
81b50f3Move'builtin-*'intoa'builtin/'subdirectory
3bb7256make"index-pack"abuilt-in
377d027make"gitpack-redundant"abuilt-in
b532581make"gitunpack-file"abuilt-in
112dd51make"mktag"abuilt-in
- 指定日期,可以有几个选项:
--since和--until
--before和--after
例如,如果我要看Git项目中三周前且在四月十八日之后的所有提交,我可以执行这个(我还用了--no-merges选项以隐藏合并提交):
$gitlog--oneline--before={3.weeks.ago}--after={2010-04-18}--no-merges
5469e2dGit1.7.1-rc2
d43427dDocumentation/remote-helpers:Fixtyposandimprovelanguage
272a36bFixup:Secondargumentmaybeanyarbitrarystring
b6c8d2dDocumentation/remote-helpers:Addinvocationsection
5ce4f4eDocumentation/urls:Rewritetoaccomodatetransport::address
00b84e9Documentation/remote-helpers:Rewritedescription
03aa87eDocumentation:Describeothersituationswhere-zaffectsgitdiff
77bc694rebase-interactive:silencewarningwhennocommitsrewritten
636db2ct3301:addteststouse--format="%N"
二、Git标签
如果你达到一个重要的阶段,并希望永远记住那个特别的提交快照,你可以使用gittag给它打上标签。
比如说,我们想为我们的项目发布一个"1.0"版本。我们可以用gittag-av1.0
命令给最新一次提交打上(HEAD)"v1.0"的标签。
-a选项意为"创建一个带注解的标签"。不用-a选项也可以执行的,但它不会记录这标签是啥时候打的,谁打的,也不会让你添加个标签的注解。我推荐一直创建带注解的标签。
$gittag-av1.0
当你执行gittag-a
命令时,Git会打开你的编辑器,让你写一句标签注解,就像你给提交写注解一样。
- 当我们执行gitlog--decorate时,我们可以看到我们的标签了:
$gitlog--oneline--decorate--graph
*88afe0e(HEAD,tag:v1.0,master)Mergebranch'change_site'
|
|*d7e7346(change_site)changedthesite
*|14b4dca新增加一行
|/
*556f0a0removedtest2.txt
*2e082b7addtest2.txt
*048598faddtest.txt
*85fc7e7testcommentfromrunoob.com
- 如果我们忘了给某个提交打标签,又将它发布了,我们可以给它追加标签。
例如,假设我们发布了提交85fc7e7(上面实例最后一行),但是那时候忘了给它打标签。我们现在也可以:
$gittag-av0.985fc7e7
$gitlog--oneline--decorate--graph
*88afe0e(HEAD,tag:v1.0,master)Mergebranch'change_site'
|
|*d7e7346(change_site)changedthesite
*|14b4dca新增加一行
|/
*556f0a0removedtest2.txt
*2e082b7addtest2.txt
*048598faddtest.txt
*85fc7e7(tag:v0.9)testcommentfromrunoob.com
- 查看所有标签可以使用以下命令:
$gittag
v0.9
v1.0
- 指定标签信息命令:
gittag-a<tagname>-m"Leon1023.git标签"
- PGP签名标签命令:
gittag-s<tagname>-m"Leon1023.git标签"