珠峰培训

git实用教程(五)标签管理

作者:

2015-11-23 14:41:50

130

发布一个版本时,我们通常先在版本库中打一个标签,这样,就唯一确定了打标签时刻的版本。将来无论什么时候,取某个标签的版本,就是把那个打标签的时刻的历史版本取出来。所以,标签也是版本库的一个快照。

Git的标签虽然是版本库的快照,但其实它就是指向某个commit的指针(跟分支很像对不对?但是分支可以移动,标签不能移动),所以,创建和删除标签都是瞬间完成的。

在Git中打标签非常简单

首先,切换到需要打标签的分支上:

$ git checkout master
Switched to branch 'master'

然后,敲命令git tag 就可以打一个新标签:

$ git tag v1.0

可以用命令git tag查看所有标签:

$ git tag
v1.0

默认标签是打在最新提交的commit上的。有时候,如果忘了打标签,比如,现在已经是周五了,但应该在周一打的标签没有打,怎么办?

方法是找到历史提交的commit id,然后打上就可以了:

$ git log --oneline
ded3e45 merge issue
2155b11 fixbug
beebf73 merge with no-ff
...

比方说要对fixbug这次提交打标签,它对应的commit id是2155b11,敲入命令:

$ git tag v0.9 2155b11

再用命令git tag查看标签:

$ git tag
v0.9
v1.0

注意,标签不是按时间顺序列出,而是按字母排序的。可以用git show <tagname>查看标签信息:

$ git show v0.9
commit 2155b1164ca64090a2f8e0146ba62bfbddbdf762
Author: zhangrenyang-t510 <zhang_renyang@>
Date:   Mon Oct 12 23:37:02 2015 +0800

    fixbug

diff --git a/index.html b/index.html

可以看到,v0.9确实打在fixbug这次提交上。

还可以创建带有说明的标签

用-a指定标签名,-m指定说明文字:

git tag -a v0.8 -m "merge with no-ff" beebf73

用命令git show 可以看到说明文字:

    $ git show v0.8
    tag v0.8
    Tagger: zhangrenyang-t510 <zhang_renyang@>
    Date:   Tue Oct 13 00:03:46 2015 +0800

    merge with no-ff

最后内容如下

小结

  • 命令git tag <name>用于新建一个标签,默认为HEAD,也可以指定一个commit id;
  • git tag -a <tagname> -m "标签注释..." 可以指定标签信息;
  • 命令git tag可以查看所有标签。