1.Git标签管理

当版本仓库内的数据有个大的改善或者功能更新,我们经常会打一个类似于软件版本号的标签,这样通过标签就可以将版本库中的某个历史版本给记录下来,方便我们随时将特定历史时期的数据取出来用,另外打标签其实只是像某个历史版本做了一个指针,所以一般都是瞬间完成的。

1.1创建本地标签

创建带有说明的标签,-a指定标签名字,-m指定说明文字

  1. [root@git-node1 demo]# git tag -a v1.0.0 -m "version 1.0.0 release"

1.2查看本地标签

1.查看当前本地所有标签

  1. [root@git-node1 demo]# git tag -l v*
  2. v1.0.0
  3. v1.0.1

2.查看当前1.0版本的详细信息

  1. [root@git-node1 demo]# git show v1.0.0
  2. tag v1.0.0
  3. Tagger: xuliangwei <xuliangwei@foxmail.com>
  4. Date: Sun Nov 6 03:12:44 2016 +0800
  5. version 1.0.0 release
  6. commit 95734131860ef7c9078b8a208ff6437d0952380b
  7. Author: xuliangwei <xuliangwei@foxmail.com>
  8. Date: Sun Nov 6 02:15:35 2016 +0800
  9. chnged name index.html->index.php
  10. diff --git a/index.html b/index.html
  11. deleted file mode 100644
  12. index e69de29..0000000
  13. diff --git a/index.php b/index.php
  14. new file mode 100644
  15. index 0000000..e69de29

1.3删除本地标签

我们为同一个提交版本设置了两次标签,删除重复性的标签

  1. [root@git-node1 demo]# git tag -d v1.0.1
  2. 已删除 tag 'v1.0.1'(曾为 3c13e43)
  3. [root@git-node1 demo]# git tag -l v*
  4. v1.0.0

1.4推送本地标签

如上操作都是基于打标签以及删除标签,下面我们来学习下打完标签后如何推送至远端服务器 
也可以使用git push origin –-tags推送所有本地建立的tag包

  1. [root@git-node1 demo]# git push origin v1.0.0
  2. Counting objects: 1, done.
  3. Writing objects: 100% (1/1), 167 bytes | 0 bytes/s, done.
  4. Total 1 (delta 0), reused 0 (delta 0)
  5. To git@git-node1:root/git_demo.git
  6. * [new tag] v1.0.0 -> v1.0.0

1.5获取远程标签

使用git pull获取最新tag包,可以使用git fetch强制获取

  1. [root@git-node1 git_demo]# git pull origin v1.0.0s
  2. remote: Counting objects: 1, done.
  3. remote: Total 1 (delta 0), reused 0 (delta 0)
  4. Unpacking objects: 100% (1/1), done.
  5. 来自 git-node1:root/git_demo
  6. * [新tag] v1.0.0 -> v1.0.0
  7. Already up-to-date.

1.6删除远程标签

通过push delete参数来删除远程标签

  1. [root@git-node1 git_demo]# git push origin --delete tag v1.0.0
  2. To git@git-node1:root/git_demo.git
  3. - [deleted] v1.0.0

也可以先删除本地tag标签,然后推送空标签至于远程进行删除

  1. [root@git-node1 git_demo]# git tag v1.0.1
  2. [root@git-node1 git_demo]# git push origin v1.0.1
  3. Total 0 (delta 0), reused 0 (delta 0)
  4. To git@git-node1:root/git_demo.git
  5. * [new tag] v1.0.1 -> v1.0.1
  6. //删除本地tag
  7. [root@git-node1 git_demo]# git tag -d v1.0.1
  8. 已删除 tag 'v1.0.1'(曾为 9573413)
  9. //推送空tag至远程进行删除
  10. [root@git-node1 git_demo]# git push origin :refs/tags/v1.0.1
  11. To git@git-node1:root/git_demo.git
  12. - [deleted] v1.0.1

1.7Git标签小结

    git版本号规则 
    内部版本 B1.1.0 
    外部版本 V1.1.0 
    补丁版本 P1.1.0

    1. 命令git tag –a <tagname> -m "message" //在当前commit状态新建一个tag
    2. 命令git tag -l <tagname> //列出相对应版本号tag
    3. 命令git push origin <tagname> //推送一个本地标签
    4. 命令git push origin --tags //推送全部未推送过的本地标签
    5. 命令git tag -d <tagname> //删除一个本地标签
    6. 命令git push origin --delete tag <tagname> //删除一个远程标签
    7. 命令git push origin :refs/tags/<tagname> //删除一个远程标签

Git系列六之标签管理的更多相关文章

  1. Git之(六)标签管理

    发布一个版本时,我们通常先在版本库中打一个标签(tag),这样,就唯一确定了打标签时刻的版本.将来无论什么时候,取某个标签的版本,就是把那个打标签的时刻的历史版本取出来.所以,标签也是版本库的一个快照 ...

  2. Git学习总结(标签管理)

    在Git中打标签非常简单,首先,切换到需要打标签的分支上: 然后,敲命令git tag <name>就可以打一个新标签: $ git tag v1. 可以用命令git tag查看所有标签: ...

  3. Git系列五之分支管理

    1.Git分支管理 分支即是平行空间,假设你在为某个手机系统研发拍照功能,代码已经完成了80%,但如果将这不完整的代码直接提交到git仓库中,又有可能影响到其他人的工作,此时我们便可以在该软件的项目之 ...

  4. Git系列一之安装管理

    1.Git安装部署 Git是分布式的版本控制系统,我们只要有了一个原始Git版本仓库,就可以让其他主机克隆走这个原始版本仓库,从而使得一个Git版本仓库可以被同时分布到不同的主机之上,并且每台主机的版 ...

  5. Git:六、分支管理(指针操作)

    1.基本操作 1)创建分支 git branch <name> 2)切换分支 git checkout <name> 1)&2)创建并切换分支 git checkout ...

  6. 【Git】六、分支管理&冲突解决

    上一节讲了如何和远端的仓库协同工作,这一节介绍一下分支 ---------------------------- 提要 //创建一个分支dev $ git branch dev //切换到dev分支 ...

  7. kafka系列六、java管理kafka Topic

    package com.example.demo.topic; import kafka.admin.AdminUtils; import kafka.admin.RackAwareMode; imp ...

  8. Git复习(六)之标签管理

    标签管理 发布一个版本时,我们通常先在版本库中打一个标签(tag),这样,就唯一确定了打标签时刻的版本.将来无论什么时候,取某个标签的版本,就是把那个打标签的时刻的历史版本取出来.所以,标签也是版本库 ...

  9. git的使用学习(六)git的标签管理

    发布一个版本时,我们通常先在版本库中打一个标签(tag),这样,就唯一确定了打标签时刻的版本.将来无论什么时候,取某个标签的版本,就是把那个打标签的时刻的历史版本取出来.所以,标签也是版本库的一个快照 ...

随机推荐

  1. ImportError: No module named etree.ElementTree

    ImportError: No module named etree.ElementTree 排查N久,才发现是因为文件名是xml.py的缘故,文件名一定不要用关键词.....

  2. PowerShell 获取系统的硬件信息

    1.获取系统的BIOS的信息: Get-WMIObject -Class Win32_BIOS 2.获取内存信息: Get-WMIObject -Class Win32_PhysicalMemory ...

  3. Java基础知识(二)

    一.基本概念 1. Java程序初始化的顺序是怎么样的 2. Java和C++的区别 3. 反射 先看一个知乎回答 什么是反射 主要用途 获得Class对象 4. 注解 什么是注解 为什么要用注解 基 ...

  4. HRBUST 1213 单词接龙

    暴力搜索. 按照能配对的关系建立有向边,然后暴力搜索. #include<cstdio> #include<cstring> #include<cmath> #in ...

  5. CodeForces 767B The Queue

    模拟. 情况有点多,需要仔细.另外感觉题目的$tf$有点不太对......而且数据水了. $0$ $5$ $2$ $2$ $0$ $5$ 这组数据按照题意的话答案可以是$2$和$4$,但是好多错的答案 ...

  6. TYVJ2002 扑克牌

    卢克生日那天,汉来找卢克玩扑克牌,玩着玩着汉觉得太没意思了,于是决定给卢克一个考验汉把一副扑克牌(54张)随机洗匀,倒扣着放成一摞.然后卢克从上往下一次翻开每张牌,每翻开一张黑桃,红桃,梅花或方块,就 ...

  7. 五种常用的C/C++编译器对64位整型的支持

    变量定义 输出方式 gcc(mingw32) g++(mingw32) gcc(linux i386) g++(linux i386) MicrosoftVisual C++ 6.0 long lon ...

  8. 【BZOJ 1060】 1060: [ZJOI2007]时态同步 (树形DP)

    1060: [ZJOI2007]时态同步 Description 小Q在电子工艺实习课上学习焊接电路板.一块电路板由若干个元件组成,我们不妨称之为节点,并将其用数 字1,2,3….进行标号.电路板的各 ...

  9. 【BZOJ 1036】【ZJOI 2008】树的统计Count

    http://www.lydsy.com/JudgeOnline/problem.php?id=1036 复习了一下好写好调的lct模板啦啦啦--- #include<cstdio> #i ...

  10. [CF600E]Dsu on tree

    题意:树上每个点都有颜色,称一个颜色占领一棵子树,当且仅当没有别的颜色在这棵子树内的数量比它多.求所有子树的占领颜色之和.题解:最显然的是DFS序+主席树或莫队,这里使用Dsu on tree. 每次 ...