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可以查看所有标签。