Git系列六之标签管理
1.Git标签管理
当版本仓库内的数据有个大的改善或者功能更新,我们经常会打一个类似于软件版本号的标签,这样通过标签就可以将版本库中的某个历史版本给记录下来,方便我们随时将特定历史时期的数据取出来用,另外打标签其实只是像某个历史版本做了一个指针,所以一般都是瞬间完成的。
1.1创建本地标签
创建带有说明的标签,-a指定标签名字,-m指定说明文字
[root@git-node1 demo]# git tag -a v1.0.0 -m "version 1.0.0 release"
1.2查看本地标签
1.查看当前本地所有标签
[root@git-node1 demo]# git tag -l v*v1.0.0v1.0.1
2.查看当前1.0版本的详细信息
[root@git-node1 demo]# git show v1.0.0tag v1.0.0Tagger: xuliangwei <xuliangwei@foxmail.com>Date: Sun Nov 6 03:12:44 2016 +0800version 1.0.0 releasecommit 95734131860ef7c9078b8a208ff6437d0952380bAuthor: xuliangwei <xuliangwei@foxmail.com>Date: Sun Nov 6 02:15:35 2016 +0800chnged name index.html->index.phpdiff --git a/index.html b/index.htmldeleted file mode 100644index e69de29..0000000diff --git a/index.php b/index.phpnew file mode 100644index 0000000..e69de29
1.3删除本地标签
我们为同一个提交版本设置了两次标签,删除重复性的标签
[root@git-node1 demo]# git tag -d v1.0.1已删除 tag 'v1.0.1'(曾为 3c13e43)[root@git-node1 demo]# git tag -l v*v1.0.0
1.4推送本地标签
如上操作都是基于打标签以及删除标签,下面我们来学习下打完标签后如何推送至远端服务器
也可以使用git push origin –-tags推送所有本地建立的tag包
[root@git-node1 demo]# git push origin v1.0.0Counting objects: 1, done.Writing objects: 100% (1/1), 167 bytes | 0 bytes/s, done.Total 1 (delta 0), reused 0 (delta 0)To git@git-node1:root/git_demo.git* [new tag] v1.0.0 -> v1.0.0
1.5获取远程标签
使用git pull获取最新tag包,可以使用git fetch强制获取
[root@git-node1 git_demo]# git pull origin v1.0.0sremote: Counting objects: 1, done.remote: Total 1 (delta 0), reused 0 (delta 0)Unpacking objects: 100% (1/1), done.来自 git-node1:root/git_demo* [新tag] v1.0.0 -> v1.0.0Already up-to-date.
1.6删除远程标签
通过push delete参数来删除远程标签
[root@git-node1 git_demo]# git push origin --delete tag v1.0.0To git@git-node1:root/git_demo.git- [deleted] v1.0.0
也可以先删除本地tag标签,然后推送空标签至于远程进行删除
[root@git-node1 git_demo]# git tag v1.0.1[root@git-node1 git_demo]# git push origin v1.0.1Total 0 (delta 0), reused 0 (delta 0)To git@git-node1:root/git_demo.git* [new tag] v1.0.1 -> v1.0.1//删除本地tag[root@git-node1 git_demo]# git tag -d v1.0.1已删除 tag 'v1.0.1'(曾为 9573413)//推送空tag至远程进行删除[root@git-node1 git_demo]# git push origin :refs/tags/v1.0.1To git@git-node1:root/git_demo.git- [deleted] v1.0.1
1.7Git标签小结
git版本号规则
内部版本 B1.1.0
外部版本 V1.1.0
补丁版本 P1.1.0
命令git tag –a <tagname> -m "message" //在当前commit状态新建一个tag命令git tag -l <tagname> //列出相对应版本号tag命令git push origin <tagname> //推送一个本地标签命令git push origin --tags //推送全部未推送过的本地标签命令git tag -d <tagname> //删除一个本地标签命令git push origin --delete tag <tagname> //删除一个远程标签命令git push origin :refs/tags/<tagname> //删除一个远程标签
Git系列六之标签管理的更多相关文章
- Git之(六)标签管理
发布一个版本时,我们通常先在版本库中打一个标签(tag),这样,就唯一确定了打标签时刻的版本.将来无论什么时候,取某个标签的版本,就是把那个打标签的时刻的历史版本取出来.所以,标签也是版本库的一个快照 ...
- Git学习总结(标签管理)
在Git中打标签非常简单,首先,切换到需要打标签的分支上: 然后,敲命令git tag <name>就可以打一个新标签: $ git tag v1. 可以用命令git tag查看所有标签: ...
- Git系列五之分支管理
1.Git分支管理 分支即是平行空间,假设你在为某个手机系统研发拍照功能,代码已经完成了80%,但如果将这不完整的代码直接提交到git仓库中,又有可能影响到其他人的工作,此时我们便可以在该软件的项目之 ...
- Git系列一之安装管理
1.Git安装部署 Git是分布式的版本控制系统,我们只要有了一个原始Git版本仓库,就可以让其他主机克隆走这个原始版本仓库,从而使得一个Git版本仓库可以被同时分布到不同的主机之上,并且每台主机的版 ...
- Git:六、分支管理(指针操作)
1.基本操作 1)创建分支 git branch <name> 2)切换分支 git checkout <name> 1)&2)创建并切换分支 git checkout ...
- 【Git】六、分支管理&冲突解决
上一节讲了如何和远端的仓库协同工作,这一节介绍一下分支 ---------------------------- 提要 //创建一个分支dev $ git branch dev //切换到dev分支 ...
- kafka系列六、java管理kafka Topic
package com.example.demo.topic; import kafka.admin.AdminUtils; import kafka.admin.RackAwareMode; imp ...
- Git复习(六)之标签管理
标签管理 发布一个版本时,我们通常先在版本库中打一个标签(tag),这样,就唯一确定了打标签时刻的版本.将来无论什么时候,取某个标签的版本,就是把那个打标签的时刻的历史版本取出来.所以,标签也是版本库 ...
- git的使用学习(六)git的标签管理
发布一个版本时,我们通常先在版本库中打一个标签(tag),这样,就唯一确定了打标签时刻的版本.将来无论什么时候,取某个标签的版本,就是把那个打标签的时刻的历史版本取出来.所以,标签也是版本库的一个快照 ...
随机推荐
- linux命令(1):sed命令
实例一: Config_file文件内容如下: sed去除注释行:sed -i -c -e '/^#/d' config_file [会删除指定文件带有注释行] sed去除空行: sed -i -c ...
- Python+Selenium 自动化实现实例-获取页面元素信息(百度首页)
#coding=utf-8from selenium import webdriverdriver = webdriver.Chrome()driver.get("http://www.ba ...
- 【机器学习】k-近邻算法应用之手写数字识别
上篇文章简要介绍了k-近邻算法的算法原理以及一个简单的例子,今天再向大家介绍一个简单的应用,因为使用的原理大体差不多,就没有没有过多的解释. 为了具有说明性,把手写数字的图像转换为txt文件,如下图所 ...
- Simditor学习--vuejs集成simditor
唠叨 因为项目需要我自己研究了和集成在vue方便以后再使用,详情官方文档在这里.希望大家有好的建议提出让我继续改进. simditor介绍 Simditor 是团队协作工具 Tower 使用的富文本编 ...
- C# CreateProcess的测试
很奇怪的一个现象,在C#中使用Process来启动进程,启动文件名必须是系统指定的扩展名.EXE,而我使用原生的Win32API ::CreateProcess ()并没有这个限制,以后遇到类似的问题 ...
- 编写.gitignore 文件
讲代码 放入 Git 仓库中进行版本控制管理时,有些文件是不需要放入Git 中,比如 Maven 生成的target 目录,IDEA/Eclipse的工程文件, 在项目的根目录 下 添加一个名为.gi ...
- devops basic
- Java Eclipse插件
EasyExplore 快速打开文件所在目录1 http://sourceforge.net/projects/easystruts/ OpenExplorer 快速打开文件所在目录2 https:/ ...
- Trie树【UVA11362】Phone List
Description 给定\(n\)个长度不超过\(10\)的数字串,判断是否有两个字符串\(A\)和\(B\),满足\(A\)是\(B\)的前缀,若有,输出NO,若没有,输出YES. 一道\(Tr ...
- 第5天:Ansible-Playbook
Ansible中的每个模块专注于某一方面的功能.虽然每个模块实现的功能都比较简单,但是,将各个模块结合起来就可以实现比较复杂的功能.在Ansible中,将各个模块组合起来的文件是一个YAML格式的配置 ...