乐趣区

关于git:git标签管理

备注:

本文参考于廖雪峰老师的博客 Git 教程。按照其博客进行学习和记录,感激其自私分享,也欢送各位查看原文。

知识点

  • git tag <name>新建一个标签,默认示意的是HEAD,以后提交.
  • git tag v0.9 commit_id在指定提交上创立标签
  • git tag -a <tagname> -m "blablabla..."指定标签信息;
  • git tag -s <tagname> -m "blablabla..."PGP 签名标签;
  • 命令 git tag 查看标签列表。
  • git show <name>显示标签信息
  • 删除标签git tag -d <tagname>
  • 将本地标签推送到近程git push origin <tagname>
  • 一次性推送全副标签到近程git push origin --tags
  • 删除近程标签git push origin :refs/tags/<tagname>

标签

  • 标签相似版本库的一个快照。当公布一个版本时,通常先在版本库中打一个标签(tag),用以惟一确定打标签时刻的版本。
  • 通过获取某个标签的版本,就能够把过后的历史版本取出来
  • Git 的标签实质也是指向某个 commit 的指针,相似于分支,然而标签不能挪动,分支能够挪动。创立和删除标签都是霎时实现
  • Git 标签不便标识。因为本来的 commit 是一串数字(6a5819e...),然而 tag v1.2 就很不便查找和标识

Git 上打标签

  • 切换到须要打标签的分支上:
$ git checkout master
切换到分支 'master'
您的分支与上游分支 'origin/master' 统一。
  • 创立标签 tag
$ git tag v1.0
  • 查看标签 tag 历史
$ git tag
v1.0
  • 标签 tag 默认打在最新提交的 commit 上。

如果忘了打标签,能够查找历史提交的 commit_id,在指定commit_id 上打标签

  • 指定 commit_id 上打标签, 如下,在提交 merged fixed bug 上打新标签

查看commit_id

$ git log --pretty=oneline --abbrev-commit
af1b0b3 add some word on master
faaaaa6 merged fixed bug
afc33ef fixed a bug
0df6e43 Merge branch 'dev'

commit_id 上打标签,查看 tag 历史

$ git tag v0.9 faaaaa6
$ git tag
v0.9
v1.0
  • tag标签是按字母程序排序的,应用 git show <tagname> 查看标签信息
$ git show v0.9
commit faaaaa6756a8d04c269b7b5ddccfc2a9e67108db
Merge: 0df6e43 afc33ef
Author: findmoon <1286637198@qq.com>
Date:   Wed Feb 21 22:25:03 2018 +0800
    merged fixed bug
  • 创立带有阐明的标签,-a指定标签名,-m指定标签阐明
$ git tag -a v0.8 -m"version 0.8 released" 7c4d427
  • git show显示标签阐明和信息
$ git show v0.8
tag v0.8
Tagger: findmoon <1286637198@qq.com>
Date:   Thu Feb 22 10:39:40 2018 +0800

version 0.8 released

commit 7c4d4271b7bbd7a9898574ff3cfa795f40f9bbe3
Merge: 8f69de8 44dffc0
Author: findmoon <1286637198@qq.com>
Date:   Wed Feb 21 14:54:46 2018 +0800

    merge with no-ff
  • 应用 -s 参数,用私钥签名一个标签
$ git tag -s v0.7 -m"version 0.7 released" afc33ef
gpg: 钥匙环‘/home/liu/.gnupg/secring.gpg’已建设
gpg: 钥匙环‘/home/liu/.gnupg/pubring.gpg’已建设
gpg:“findmoon <1286637198@qq.com>”已跳过:私钥不可用
gpg: signing failed: 私钥不可用
error: gpg 无奈为数据签名
error: 无奈签订标签

因为签名采纳 PGP 签名,所以必须首先装置 gpg(GnuPG),没有gpg 或者 gpgp 密钥对,就会报错。

PGP 签名的标签是不可伪造的

标签的治理

  • 删除标签git tag -d <tagname>
$ git tag -d v0.8
已删除标签 'v0.8'(曾为 08825cf)
  • 将本地标签推送到近程git push origin <tagname>
$ git push origin v1.0
Total 0 (delta 0), reused 0 (delta 0)
To git@github.com:findmoon/newrepo.git
 * [new tag]         v1.0 -> v1.0
  • 一次性推送全副为推送的标签到近程git push origin --tags
$ git push origin --tags
对象计数中: 1, 实现.
写入对象中: 100% (1/1), 164 bytes | 0 bytes/s, 实现.
Total 1 (delta 0), reused 0 (delta 0)
To git@github.com:findmoon/newrepo.git
 * [new tag]         0.8 -> 0.8
 * [new tag]         v0.9 -> v0.9
  • 标签推送到近程后的删除
  1. 先删除本地标签
$ git tag -d 0.8
已删除标签 '0.8'(曾为 4dcd55c)
  1. 删除近程标签git push origin :refs/tags/<tagname>
$ git push origin :refs/tags/0.8
To git@github.com:findmoon/newrepo.git
 - [deleted]         0.8
退出移动版