Git: git tag 使用小结(给发布版本打标记,切换并修改某个历史版本)
通常在软件发布的时候会打一个tag,用于标注这次发布的相关信息, 这样做的好处是,将来如果这个版本出现了问题,可以通过tag迅速定位到当前版本,进行错误修复。
1. 新建tag
$ git tag v1.6
v1.6 就是这个tag的名称,通常以版本号命名。注意:tag是打在最近的一次Commit记录上的,比如我最近一次提交记录的Commit ID是 7fd77215642fe36e73674f604ef49a0097d3c0d3,那么执行完 git tag v1.6命令后,tag就打在了这个Commit ID上。
还可以通过加上 -a 参数来创建一个带备注的tag, 备注信息由 -m 指定:
$ git tag -a v1.6 -m "publish v1.6 version"
2. 列出已有的tag
$ git tag
v1.
v1.
v1.
v1.
v1.-bugfix
v1.
v1.
还可以加上 -l 命令使用通配符来过滤tag, 这在tag列表比较多的时候很有用:
$ git tag -l "v1.3*"
v1.3
v1.3-bugfix
3. 同步tag到远程服务器
$ git push origin v1.
Total (delta ), reused (delta )
To https://github.com/yongdaimi/AndroidApiTest.git
* [new tag] v1. -> v1.
和提交代码一样,tag默认创建是在本地的,需要进行推送才能到达远程服务器,如果要推送本地所有tag,可以使用:
$ git push origin --tags
4. 查看某个tag的详细信息
$ git show v1.
commit 7fd77215642fe36e73674f604ef49a0097d3c0d3 (HEAD -> master, tag: v1., origin/master, origin/HEAD)
Author: nisha_chen <nisha_chen@realsil.com.cn>
Date: Fri Oct :: + android: update current version to 1.6 diff --git a/app/build.gradle b/app/build.gradle
index 55786a4..b100875
--- a/app/build.gradle
+++ b/app/build.gradle
@@ -, +, @@ android {
applicationId "com.yongdaimi.android.androidapitest"
minSdkVersion
targetSdkVersion
- versionCode
- versionName "1.4"
+ versionCode
+ versionName "1.6"
testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
}
buildTypes {
使用git show 加上 tag名来查看指定tag的详细信息。
5. 为历史版本添加tag
$ git tag v1.1.1 03f98856b1a422b5604fc1337500b756513e785c
利用git log 查看结果:
commit 093dafc3e88d8708fa26ac94919d901024878209 (tag: v1.)
Author: nisha_chen <nisha_chen@realsil.com.cn>
Date: Fri Oct :: + android: update current version to v1. commit 03f98856b1a422b5604fc1337500b756513e785c (tag: v1.1.1)
Author: nisha_chen <nisha_chen@realsil.com.cn>
Date: Fri Oct :: + android: update current version to V1. commit b16b7376506439d5dd649a8352e5ccb78b455000 (tag: v1.)
Author: nisha_chen <nisha_chen@realsil.com.cn>
Date: Thu Oct :: + Bluetooth: Add a interface about scan bluetooth device
也可以使用下列命令实现:
$ git tag -a v1.2 9fceb02 -m "my tag"
9fc3b02 是某次Commit ID的前7位,Git不要求写全所有的Commit ID数字。
6. 删除tag
$ git tag -d v1.6
Deleted tag 'v1.6' (was 03f9885)
这样只是把本地的tag删除掉了,如果要同时删除服务器上的tag,可以使用
$ git push origin :refs/tags/v1.
To https://github.com/yongdaimi/AndroidApiTest.git
- [deleted] v1.
7. 利用tag功能切换并修改某个历史版本
$ git tag
v1.
v1.
v1.
v1.3
v1.
这里修改v1.3版本:
$ git checkout -b feature-bugfix-v1. v1.
Switched to a new branch 'feature-bugfix-v1.3'
语法是:git checkout -b [branchName] [tagName], 在 feature-bugfix-v1.3 这个分支上修改完毕后切回 master分支并合并 bugfix 分支:
$ git checkout master
Switched to branch 'master'
Your branch is up to date with 'origin/master'. $ git merge feature-bugfix-v1.
Merge made by the 'recursive' strategy.
test.txt | +
file changed, insertion(+)
create mode test.txt
Git: git tag 使用小结(给发布版本打标记,切换并修改某个历史版本)的更多相关文章
- tortoiseSVN如何回滚(切换至)某个历史版本?
tortoiseSVN如何回滚(切换至)某个历史版本? 1.右键需要回滚的项目,tortoiseSVN - >show log 2.右键需要回滚的历史版本,选择revert to this re ...
- idea上查看本文件svn修改的历史版本
如上图依次点击,得到下图,比较即可:
- git回退到某个历史版本
1. 使用git log命令查看所有的历史版本,获取某个历史版本的id,假设查到历史版本的id是139dcfaa558e3276b30b6b2e5cbbb9c00bbdca96. 2. git res ...
- git revert 后悔了 还原修改前的版本 + git 常用命令
昨天手残 然后在GitHub for windows 上点了revert 然后就给重置了 更手残的是又给同步了 . 但是 GitHub 会保留之前的版本 . 只要删掉本次修改就可. 解决方案: g ...
- 【git】git回退到某个历史版本(强行推送代码)
1. 使用git log命令查看所有的历史版本,获取某个历史版本的id,假设查到历史版本的id是139dcfaa558e3276b30b6b2e5cbbb9c00bbdca96. 2. 3. 把修改推 ...
- 『现学现忘』Git基础 — 24、Git中查看历史版本记录
目录 1.查看详细的历史版本记录 2.简化显示历史版本记录 3.历史版本记录常用操作 (1)指定查看最近几次提交的内容 (2)以简单图形的方式查看分支版本历史 (3)翻页与退出 4.查看分支相关的版本 ...
- Hadoop概念学习系列之如何去找到历史版本的Hadoop发行包(三十四)
如何去找到历史版本的Hadoop发行包 找到Hadoop历史版本 这里我需要的Hadoop版本是2.0.3.打开hadoop的下载页面 http://www.apache.org/dyn/closer ...
- svn回到某个历史版本的做法
作者:朱金灿 来源:http://blog.csdn.net/clever101 一.在选中的文件上弹出svn的右键菜单,单击"Updateto revision"菜单项,如下图: ...
- Ubuntu修改默认Python版本,你了解多少~
目录 1 查看Python版本 1.1 查看装有哪些版本 1.2 查看默认版本 2 修改Python默认版本 2.1 基于文件修改 2.2 基于软链接修改 1 查看Python版本 1.1 查看装有哪 ...
随机推荐
- openwrt配置strongswan对接hillstone ipsec的笔记
一.主要参考资料: https://openwrt.org/docs/guide-user/services/vpn/ipsec/strongswan/roadwarrior https://open ...
- django配置*app*登录案例*orm简用
1.静态文件的配置和使用 1.静态文件的配置和使用 没有css样式: 添加样式 结果: <html lang="en"> <head> <meta c ...
- JavaScript解析机制之变量提升
1.什么是预解析? 在当前作用域下,JS 运行之前,会把带有 var 和 function 关键字的事先声明,并在内存中安排好.(这个过程也可以理解为变量提升)然后再从上到下执行 JS 语句(预解析只 ...
- 《3+1团队》【Beta】Scrum meeting 1
项目 内容 这个作业属于哪个课程 任课教师博客主页链接 这个作业的要求在哪里 作业链接地址 团队名称 3+1团队 团队博客地址 https://home.cnblogs.com/u/3-1group ...
- LG4718 【模板】Pollard-Rho算法 和 [Cqoi2016]密钥破解
Pollard-Rho算法 总结了各种卡常技巧的代码: #define int long long typedef __int128 LL; IN int fpow(int a,int b,int m ...
- C# 7.0 中的新特性((.NET Framework 4.7 与 Visual Studio 2017 ))
C#7.0 于 2017年3月 随 .NET 4.7 和 VS2017 发布. 一. out 变量(out variables) 以前我们使用out变量必须在使用前进行声明,C# 7.0 给我们提供了 ...
- RCNN,Fast RCNN,Faster RCNN 的前生今世:(2) R- CNN (3,2,1)
3.三次IOU 2.2次model run 1,一次深度神经网络 rcnn主要作用就是用于物体检测,就是首先通过selective search 选择2000个候选区域,这些区域中有我们需要的所对 ...
- VC中文件路径问题
环境:xp+vs2010 1.如果出现这样的路径,input.txt表示在解决方案目录(前提是项目包在解决方案目录下的一个包)下,也就是与你的解决方案XXX.sln平行. ifstream in(&q ...
- 用1 x 2的多米诺骨牌填满M x N矩形的方案数(完美覆盖)
题意 用 $1 \times 2$ 的多米诺骨牌填满 $M \times N$ 的矩形有多少种方案,$M \leq 5,N < 2^{31}$,输出答案模 $p$. 分析 当 $M=3$时,假设 ...
- memorization-根据输入重新计算render的数据
在实际开发过程中,经常遇到根据props和state变化,重新计算“渲染阶段”需要的数据的情况. 如:根据输入的值实时过滤select列表,或者表格数据(查询过滤). 问题特点: 1. 每次渲染都会调 ...