$ git branch
* dev
master
$ git checkout master
Switched to branch 'master'
而後,敲命令git tag <name>就能夠打一個新標籤:
$ git tag v1.0
能夠用命令git tag查看全部標籤:
$ git tag
v1.0
默認標籤是打在最新提交的commit上的。有時候,若是忘了打標籤,好比,如今已是週五了,但應該在週一打的標籤沒有打,怎麼辦?
方法是找到歷史提交的commit id,而後打上就能夠了:
$ git log --pretty=oneline --abbrev-commit
12a631b (HEAD -> master, tag: v1.0, origin/master) merged bug fix 101
4c805e2 fix bug 101
e1e9c68 merge with no-ff
f52c633 add merge
cf810e4 conflict fixed
5dc6824 & simple
14096d0 AND simple
b17d20e branch test
d46f35e remove test.txt
b84166e add test.txt
519219b git tracks changes
e43a48b understand how stage works
1094adb append GPL
e475afc add distributed
eaadf4e wrote a readme file
比方說要對add merge此次提交打標籤,它對應的commit id是f52c633,敲入命令:
$ git tag v0.9 f52c633
再用命令git tag查看標籤:
$ git tag
v0.9
v1.0
注意,標籤不是按時間順序列出,而是按字母排序的。能夠用git show <tagname>查看標籤信息:
$ git show v0.9
commit f52c63349bc3c1593499807e5c8e972b82c8f286 (tag: v0.9)
Author: Michael Liao <askxuefeng@gmail.com>
Date: Fri May 18 21:56:54 2018 +0800
add merge
diff --git a/readme.txt b/readme.txt
...
能夠看到,v0.9確實打在add merge此次提交上。
還能夠建立帶有說明的標籤,用-a指定標籤名,-m指定說明文字:
$ git tag -a v0.1 -m "version 0.1 released" 1094adb
用命令git show <tagname>能夠看到說明文字:
$ 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 ...
注意:標籤老是和某個commit掛鉤。若是這個commit既出如今master分支,又出如今dev分支,那麼在這兩個分支上均可以看到這個標籤。
小結
-
命令
git tag <tagname>
用於新建一個標籤,默認爲HEAD
,也能夠指定一個commit id; -
命令
git tag -a <tagname> -m "blablabla..."
能夠指定標籤信息; -
命令
git tag
能夠查看全部標籤。
操做標籤
若是標籤打錯了,也能夠刪除:
$ git tag -d v0.1 Deleted tag 'v0.1' (was f15b0dd)
由於建立的標籤都只存儲在本地,不會自動推送到遠程。因此,打錯的標籤能夠在本地安全刪除。
若是要推送某個標籤到遠程,使用命令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
或者,一次性推送所有還沒有推送到遠程的本地標籤:
$ git push origin --tags Total 0 (delta 0), reused 0 (delta 0) To github.com:michaelliao/learngit.git * [new tag] v0.9 -> v0.9
若是標籤已經推送到遠程,要刪除遠程標籤就麻煩一點,先從本地刪除:
$ git tag -d v0.9 Deleted tag 'v0.9' (was f52c633)
而後,從遠程刪除。刪除命令也是push,可是格式以下:
$ git push origin :refs/tags/v0.9 To github.com:michaelliao/learngit.git - [deleted] v0.9
要看看是否真的從遠程庫刪除了標籤,能夠登錄GitHub查看。
小結
-
命令git push origin <tagname>能夠推送一個本地標籤;
-
命令
git push origin --tags
能夠推送所有未推送過的本地標籤; -
命令git tag -d <tagname>能夠刪除一個本地標籤;
-
命令git push origin :refs/tags/<tagname>