在發布版本時,我們通常先在版本庫打一個標簽(tag),這樣,就唯一確定了打標簽時刻的版本.將來無論什么時候,取某個標簽的版本,就是把那個打標簽的時刻的歷史版本取出來,所以標簽也是版本庫的一個快照.
Git的標簽雖然是版本庫的快照,但其實它就是指向某個commit的指針(跟分支很像對不對?但分支可以移動,標簽不能移動),所以,創建和刪除標簽都是瞬間完成的.
Git有了commit,為什么還要引入tag呢?
因為commit號是3b5819e...
一串亂七八糟的數字不好找.而tag可以根據需要任意命名,讓人非常容易記住,它跟某個commit
綁定在一起.
創建標簽
在Git中打標簽,首先,需要切換到需要打標簽的分支上:
$ 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
b95bbf0 conflict fixed
c2e47c0 & simple
89cdc59 AND simple
fae4e76 忽略不要的文件
e151f7e add README.md
3fafa4a remove test.txt
c291807 add test.txt
6d99443 boss
8b33073 git tracks changes
3557835 Revert "add aaa"
9b4fd89 add aaa
94bf088 append microService
8cf77e4 add code for theme
92b6075 add spring-boot sample
5ad5c1f add a readme file
比方說要對& simple
這次提交打標簽,它對應的commit id是c2e47c0
,敲入命令:
$git tag v0.8 c2e47c0
再用命令git tag
查看:
$ git tag
v0.8
v1.0
這里需要注意,標簽不是按時間順序列出的,而是按字母排序的,可以用git show <tagname>
查看標簽信息:
$ git show v0.8
commit c2e47c06db550e03b2c19ee5247b03d949a10541
Author: alan7c <chong_luo@kingdee.com>
Date: Fri Mar 17 17:42:44 2017 +0800
& simple
diff --git a/README.md b/README.md
index 342d90d..0a28620 100644
--- a/README.md
+++ b/README.md
@@ -1 +1,2 @@
# spring-boot-mongo
還可以創建帶有說明的標簽,用-a
指定標簽名,-m
指定說明的文字:
$ git tag -a v0.9 -m "version 0.9 master" b95bbf0
用命令git show <gitname>
可以看到說明文字:
$ git show v0.9
tag v0.9
Tagger: alan7c <chong_luo@kingdee.com>
Date: Mon Mar 27 16:29:13 2017 +0800
version 0.9 master
commit b95bbf0ac897b2d88fa4bcf0308913f624d566c7
Merge: c2e47c0 89cdc59
Author: alan7c <chong_luo@kingdee.com>
Date: Fri Mar 17 17:48:28 2017 +0800
conflict fixed
小結
- 命令
git tag <name>
用于創建一個標簽,默認為HEAD
,也可以指定一個commit id; -
git tag -a <tagname> -m "balabalalbala.." commit id
可以指定標簽信息; - 命令
git tag
可以查看所有標簽.
操作標簽
如果標簽打錯了,也可以刪除標簽:
$ git tag -d v0.8
Deleted tag 'v0.8' (was c2e47c0)
因為創建的標簽都是只存儲在本地,不會自動推送到遠程,所以打錯的標簽也可以在本地安全刪除.
如果要推送某個標簽到遠程,使用命令git push origin <tagname>
:
$ git push origin v1.0
Total 0 (delta 0), reused 0 (delta 0)
To git@github.alanluochong/spring-boot-test.git
* [new tag] v1.0 -> v1.0
或者一次性推送全部尚未推送到遠程的本地標簽:
$ git push origin --tags
Counting objects: 1, done.
Writing objects: 100% (1/1), 554 bytes, done.
Total 1 (delta 0), reused 0 (delta 0)
To git@github.com:michaelliao/learngit.git
* [new tag] v0.2 -> v0.2
* [new tag] v0.9 -> v0.9
如果標簽已經推送到遠程,要刪除遠程標簽就麻煩一點,但是格式如下:
$ git push origin :refs/tags/v0.9
To git@github.com:alanluochong/spring-mongo-test.git
- [deleted] v0.9
小結
- 命令
git push origin <tagname>
可以推送一個本地標簽到遠程; - 命令
git push origin --tags
可以推送全部未推送過的本地標簽; - 命令
git tag -d <tagname>
可以刪除一個本地標簽; - 命令
git push origin :refs/tags/<tagname>
可以刪除一個遠程標簽;