發(fā)布一個(gè)版本時(shí),我們通常先在版本庫(kù)中打一個(gè)標(biāo)簽(tag),這樣,就唯一確定了打標(biāo)簽時(shí)刻的版本。將來(lái)無(wú)論什么時(shí)候,取某個(gè)標(biāo)簽的版本,就是把那個(gè)打標(biāo)簽的時(shí)刻的歷史版本取出來(lái)。所以,標(biāo)簽也是版本庫(kù)的一個(gè)快照。
Git的標(biāo)簽雖然是版本庫(kù)的快照,但其實(shí)它就是指向某個(gè)commit的指針(跟分支很像對(duì)不對(duì)?但是分支可以移動(dòng),標(biāo)簽不能移動(dòng)),所以,創(chuàng)建和刪除標(biāo)簽都是瞬間完成的。
Git有commit,為什么還要引入tag?
“請(qǐng)把上周一的那個(gè)版本打包發(fā)布,commit號(hào)是6a5819e…”
“一串亂七八糟的數(shù)字不好找!”
如果換一個(gè)辦法:
“請(qǐng)把上周一的那個(gè)版本打包發(fā)布,版本號(hào)是v1.2”
“好的,按照tag v1.2查找commit就行!”
所以,tag就是一個(gè)讓人容易記住的有意義的名字,它跟某個(gè)commit綁在一起。
在Git中打標(biāo)簽非常簡(jiǎn)單,首先,切換到需要打標(biāo)簽的分支上:
$ git branch
* dev
master
$ git checkout master
Switched to branch 'master'
然后,敲命令git tag <name>
就可以打一個(gè)新標(biāo)簽:
$ git tag v1.0
可以用命令git tag
查看所有標(biāo)簽:
$ git tag
v1.0
默認(rèn)標(biāo)簽是打在最新提交的commit上的。有時(shí)候,如果忘了打標(biāo)簽,比如,現(xiàn)在已經(jīng)是周五了,但應(yīng)該在周一打的標(biāo)簽沒(méi)有打,怎么辦?
方法是找到歷史提交的commit id,然后打上就可以了:
$ git log --pretty=oneline --abbrev-commit
aed0d20 (HEAD -> master, tag: v1.0, origin/master) bug fix 01
6ab5982 (issue-101) bug 01
007b7aa merge with no-ff
a66f3d4 (origin/dev, dev) add 004
99fa0a0 ccc
aa309c8 fff
5174635 8zx
06e428d remove love.TXT
284196c git track
e0b6320 understand how stage works
a2092c9 3
747bea0 2
e5b5712 1
021749f mxs
34ec753 zx
af87883 zx
比方說(shuō)要對(duì)mxs
這次提交打標(biāo)簽,它對(duì)應(yīng)的commit id是021749f
,敲入命令:
$ git tag v0.1 021749f
再用命令git tag
查看標(biāo)簽:
$ git tag
v0.9
v1.0
注意,標(biāo)簽不是按時(shí)間順序列出,而是按字母排序的??梢杂?code>git show <tagname>查看標(biāo)簽信息:
$ git show v0.1
commit 021749f03ca0a1bfe5816e92f1d6e3aad757a78d (tag: v0.1)
Author: ITmxs <17752170152@163.com>
Date: Mon Jun 15 09:43:20 2020 +0800
mxs
diff --git a/code.TXT b/code.TXT
index fdd8d4f..f8e2332 100644
--- a/code.TXT
+++ b/code.TXT
@@ -1 +1,2 @@
-ITmxs
\ No newline at end of file
+ITmxs
+<C4>?e<C9>
\ No newline at end of file
可以看到,v0.1
確實(shí)打在mxs
這次提交上。
還可以創(chuàng)建帶有說(shuō)明的標(biāo)簽,用-a
指定標(biāo)簽名,-m
指定說(shuō)明文字:
$ git tag -a v0.1 -m "version 0.1 released" 1094adb
用命令git show <tagname>
可以看到說(shuō)明文字:
$ git show v0.1
tag v0.1
Tagger: Michael Liao <askxuefeng@gmail.com>
Date: Fri May 18 22:48:43 2018 +0800
version 0.1 released
commit 1094adb7b9b3807259d8cb349e7df1d4d6477073 (tag: v0.1)
Author: Michael Liao <askxuefeng@gmail.com>
Date: Fri May 18 21:06:15 2018 +0800
append GPL
diff --git a/readme.txt b/readme.txt
...
注意:標(biāo)簽總是和某個(gè)commit掛鉤。如果這個(gè)commit既出現(xiàn)在master分支,又出現(xiàn)在dev分支,那么在這兩個(gè)分支上都可以看到這個(gè)標(biāo)簽。
如果標(biāo)簽打錯(cuò)了,也可以刪除:
$ git tag -d v0.1
Deleted tag 'v0.1' (was 021749f)
因?yàn)閯?chuàng)建的標(biāo)簽都只存儲(chǔ)在本地,不會(huì)自動(dòng)推送到遠(yuǎn)程。所以,打錯(cuò)的標(biāo)簽可以在本地安全刪除。
如果要推送某個(gè)標(biāo)簽到遠(yuǎn)程,使用命令git push origin <tagname>
:
$ git push origin v1.0
Total 0 (delta 0), reused 0 (delta 0)
To github.com:michaelliao/learngit.git
* [new tag] v1.0 -> v1.0
或者,一次性推送全部尚未推送到遠(yuǎn)程的本地標(biāo)簽:
$ git push origin --tags
Total 0 (delta 0), reused 0 (delta 0)
To github.com:michaelliao/learngit.git
* [new tag] v0.9 -> v0.9
如果標(biāo)簽已經(jīng)推送到遠(yuǎn)程,要?jiǎng)h除遠(yuǎn)程標(biāo)簽就麻煩一點(diǎn),先從本地刪除:
$ git tag -d v1.0
Deleted tag 'v1.0' (was aed0d20)
然后,從遠(yuǎn)程刪除。刪除命令也是push,但是格式如下:
$ git push origin :refs/tags/v1.0
To https://github.com/ITmxs/mygit.git
- [deleted] v1.0
要看看是否真的從遠(yuǎn)程庫(kù)刪除了標(biāo)簽,可以登陸GitHub查看。
聯(lián)系客服