git标签——附带详细步骤

文章目录

0 总结

本文内容摘自gitCode的git教程。

  1. 命令git push origin <tagname>可以推送一个本地标签;
  2. 命令git push origin --tags可以推送全部未推送过的本地标签;
  3. 命令git tag -d <tagname>可以删除一个本地标签;
  4. 命令git push origin :refs/tags/<tagname>可以删除一个远程标签
  5. 命令git tag -a <tagname> -m 'messages'可以创建一个带附注的标签
  6. 命令git tag -s <tagname> -m 'messages'可以创建一个带 gpg 签名的标签

1 轻量级的标签中(lightweight)

轻量级标签就像是个不会变化的分支,实际上它就是个指向特定提交对象的引用。

1.1 默认标签

默认标签是打在最新提交的commit上的。

打默认标签

$ git tag v1.0

1.2 指定标签

$ git log --pretty=oneline --abbrev-commit

3d97ae0 (HEAD -> master, tag: v1.0, origin/master, origin/HEAD) 提交text.py
082cad1 Merge branch 'master' of https://gitcode.net/qq_33375598/git-learning-course
0113c18 修改冲突
d56e63b Merge branch 'feature1' into 'master'
31b4c13 (origin/feature1) Creating a new branch is quick and simple.
7f34e0e & simple
13dcd3e (feature1) ADD A SAMPLE
9024f59 ADD A SAMPLE
f2f9a97 Update README.md
5d7e8d4 Initial commit

$ git tag v0.9 13dcd3e

1.3 查看标签

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

(base) mac@macbook git-learning-course % git show v0.9
commit 13dcd3e90e3a604c93ffea800e9731904ed3498a (tag: v0.9, feature1)
Author: 晋康 <jk@local.lan>
Date:   Fri Jan 14 09:42:57 2022 +0800

    ADD A SAMPLE

diff --git a/README.txt b/README.txt
index 4411722..d768675 100644
--- a/README.txt
+++ b/README.txt
@@ -1 +1,2 @@
-Creating a new branch is quick.
\ No newline at end of file
+Creating a new branch feature1!
+Creating a new branch is quick AND simple.

1.4 创建标签文字说明(本地)

还可以创建带有说明的标签,用-a指定标签名,-m指定说明文字:

$ git tag -a v0.1 -m "version 0.1 released" 187f963

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

$ git show v0.9
commit fb8b190b016f5f19c7758ca21df0a5798a7a5fe1 (tag: v0.9)
Merge: 06e5e3a 2443c95
Author: Miykael_xxm <xiongjiamu@gmail.com>
Date:   Sun Nov 29 20:18:26 2020 +0800

    conflict fixed

(END)

1.5 标签同步到远程

推送固定版本:

$ git push origin v1.0
Total 0 (delta 0), reused 0 (delta 0), pack-reused 0
To codechina.csdn.net:xiongjiamu/learning-git.git
 * [new tag]         v1.0 -> v1.0

一次性推送本地 tag:

$ git push origin --tags
Enumerating objects: 1, done.
Counting objects: 100% (1/1), done.
Writing objects: 100% (1/1), 171 bytes | 171.00 KiB/s, done.
Total 1 (delta 0), reused 0 (delta 0), pack-reused 0
To codechina.csdn.net:xiongjiamu/learning-git.git
 * [new tag]         remove -> remove
 * [new tag]         v0.1 -> v0.1
 * [new tag]         v0.9 -> v0.9

1.6 删除标签(本地/远程)

本地:

$ git tag -d remove
Deleted tag 'remove' (was c47983c)

远程:

$ git push origin :refs/tags/remove
To codechina.csdn.net:xiongjiamu/learning-git.git
 - [deleted]         remove

2 含附注的标签(annotated)

附注标签实际上是存储在仓库中的一个独立对象,它有自身的校验和信息,包含着标签的名字,电子邮件地址和日期,以及标签说明,标签本身也允许使用 GNU Privacy Guard (GPG) 来签署或验证。一般我们都建议使用含附注型的标签,以便保留相关信息;当然,如果只是临时性加注标签,或者不需要旁注额外信息,用轻量级标签也没问题。

2.1 创建一个含附注类型的标签

$ git tag -a v1.1 -m 'my version 1.1'
$ git tag
v0.1
v0.9
v1.0
v1.1

-m 选项则指定了对应的标签说明,Git 会将此说明一同保存在标签对象中。如果没有给出该选项,Git 会启动文本编辑软件供你输入标签说明。

使用 git show 命令查看相应标签的版本信息。

$ git show v1.1
tag v1.1
Tagger: Miykael_xxm <xiongjiamu@gmail.com>
Date:   Tue Dec 22 14:29:54 2020 +0800

my version 1.1

commit 22a1da7ef25e09d9c4e7e5ec40a70e4543187067 (HEAD -> master, tag: v1.1, origin/master)
Author: Miykael_xxm <xiongjiamu@gmail.com>
Date:   Tue Dec 22 13:47:00 2020 +0800

    add author

diff --git a/hello.py b/hello.py
index 79e4c5b..d1f1616 100644
--- a/hello.py
+++ b/hello.py
@@ -1,3 +1,4 @@
 print('hello!');
 set exit=1;
 # add comment here~~~
+# author = xxm

如果你有自己的私钥,还可以用 GPG 来签署标签,只需要把之前的选项 -a 改为 -s (译注: 取 signed 的首字母)即可:

上一篇:msyql查看版本号、最大连接数、当前连接数等


下一篇:flex布局简析