和leon一起从头学Git(五)

作者: Leon_Geo | 来源:发表于2019-01-12 08:06 被阅读1次

    一、提交历史

    • 在使用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标签"
    

    相关文章

      网友评论

        本文标题:和leon一起从头学Git(五)

        本文链接:https://www.haomeiwen.com/subject/brsqdqtx.html