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. Nginx事件管理机制-epoll

    epoll的最大好处在于他不会随着被监控描述符的数目的增长而导致效率极致下降. select是遍历扫描来判断每个描述符是否有事件发生,当监控的描述付越多时,时间消耗就越多,并且由于系统的限制selec ...

  2. Django Ajax学习二之csrf跨站请求伪造

    方式1 $.ajaxSetup({ data: {csrfmiddlewaretoken: '{{ csrf_token }}' }, }); 方式2 # html文件from表单中<form& ...

  3. C# Merge into的使用详解

    Merge是一个非常有用的功能,类似于Mysql里的insert into on duplicate key. Oracle在9i引入了merge命令, 通过这个merge你能够在一个SQL语句中对一 ...

  4. HTTP资源合集

    (1)MoZILLA开发者web技术文档之HTTP 未完待续...

  5. 【hdoj_1398】SquareCoins(母函数)

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=1398 此题采用母函数的知识求解,套用母函数模板即可: http://blog.csdn.net/ten_s ...

  6. json转换工具——fastjson的使用

    1.maven依赖<dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson< ...

  7. .NET 二进制序列化器,SOAP序列化器,XML序列化器

    这里就不说JSON序列化了,只介绍三种:二进制序列化器,SOAP序列化器,XML序列化器 直接上代码: /// <summary> /// 二进制序列化器. /// 最节省流量,压缩程度最 ...

  8. cssBase.css你应该有一个

    @charset "utf-8"; /*! * @名称:base.css * @功能:1.重设浏览器默认样式 * 2.设置通用原子类 */ /* 防止用户自定义背景颜色对网页的影响 ...

  9. python笔记二:常用数据类型操作

    1.切片:常用于取list或tuple的部分元素的操作 1)l=[1,2,3,4,5,6] l[:3]表示取前3个值,l[1:5]表示1到5个值, L[-3:]从列表最后往前数即最后3个数.... 2 ...

  10. 一个菜鸟正在用SSH写一个论坛(2)

    额 一不小心又一个多月没有写过随笔了. 这次是在某次启动服务器的时候报错了: 严重: Exception starting filter struts2 Unable to load configur ...