Mac中Git的简单实用(8) --- 标签使用
2015-06-25 23:48
148 查看
今天我来介绍下Git,Git是一款免费、开源的分布式版本控制系统。
我们在上一个学习了Git的远程库的信息、推送分支、pull分支。
这一章,我们要学习标签的使用。
Mac中Git的简单实用(1) — Git基本命令(1)
Mac中Git的简单实用(2) — Git基本命令(2)
Mac中Git的简单实用(3) — Github远程仓库
Mac中Git的简单实用(4) — 分支branch管理
Mac中Git的简单实用(5) — Git分支冲突管理
Mac中Git的简单实用(6) — 分支管理策略
Mac中Git的简单实用(7) — 多人协作使用
然后,敲命令git tag 就可以打一个新标签:
可以用命令git tag查看所有标签:
默认标签是打在最新提交上的。
如果需要在历史版本上面添加标签,方法是找到历史提交的commit id,然后打上就可以了。
通过git log –pretty=oneline –abbrev-commit命令查看:
比方说要对merge with no-ff这次提交打标签,它对应的commit id是03d3111,敲入命令:
注意,标签不是按时间顺序列出,而是按字母排序的。可以用git show 查看标签信息:
还可以创建带有说明的标签,用-a指定标签名,-m指定说明文字;
git tag -a -m “blablabla…”可以指定标签信息:
因为创建的标签都只存储在本地。所以,打错的标签可以在本地安全删除。
如果要推送某个标签到远程,使用命令git push origin :
一次性推送全部尚未推送到远程的本地标签:
如果标签已经推送到远程,要删除远程标签就麻烦一点,先从本地删除;
然后,从远程删除。删除命令也是push,但是格式如下:
我们在上一个学习了Git的远程库的信息、推送分支、pull分支。
这一章,我们要学习标签的使用。
Mac中Git的简单实用(1) — Git基本命令(1)
Mac中Git的简单实用(2) — Git基本命令(2)
Mac中Git的简单实用(3) — Github远程仓库
Mac中Git的简单实用(4) — 分支branch管理
Mac中Git的简单实用(5) — Git分支冲突管理
Mac中Git的简单实用(6) — 分支管理策略
Mac中Git的简单实用(7) — 多人协作使用
1、标签简介
我们通常先在发布应用时候先在版本库中打一个标签,就唯一确定了打标签时刻的版本。 将来无论什么时候,取某个标签的版本,就是把那个打标签的时刻的历史版本取出来。 所以,标签也是版本库的一个快照。 Git的标签虽然是版本库的快照,但其实它就是指向某个commit的指针,所以,创建和删除标签都是瞬间完成的。
2、创建标签
在Git中打标签非常简单,首先,切换到需要打标签的分支上:MBP:git qiuyu$ git branch * dev master MBP:git qiuyu$ git checkout master A test.c 切换到分支 'master' 您的分支与上游分支 'origin/master' 一致。 MBP:git qiuyu$
然后,敲命令git tag 就可以打一个新标签:
MBP:git qiuyu$ git tag v1.0
可以用命令git tag查看所有标签:
MBP:git qiuyu$ git tag v1.0
默认标签是打在最新提交上的。
如果需要在历史版本上面添加标签,方法是找到历史提交的commit id,然后打上就可以了。
通过git log –pretty=oneline –abbrev-commit命令查看:
MBP:git qiuyu$ git log --pretty=oneline --abbrev-commit 4df3131 the forth release b5795fe debug01 cfe4639 debug01 03d3111 merge with no-ff d60705f no fast-forward 33605db the lateset 89519de master b00c593 branch1 d2ba8f0 branch test e5798f6 the third release f49806e the second release 4644630 the first release
比方说要对merge with no-ff这次提交打标签,它对应的commit id是03d3111,敲入命令:
MBP:git qiuyu$ git tag v1.1 03d3111
MBP:git qiuyu$ git tag v1.0 v1.1
注意,标签不是按时间顺序列出,而是按字母排序的。可以用git show 查看标签信息:
MBP:git qiuyu$ git show v1.1 commit 03d3111fa727da8660cedf0cdc721115147ca0c3 Merge: 33605db d60705f Author: qiuyu <qiuyu93422@163.com> Date: Fri Jun 19 19:02:16 2015 +0800 merge with no-ff
还可以创建带有说明的标签,用-a指定标签名,-m指定说明文字;
git tag -a -m “blablabla…”可以指定标签信息:
MBP:git qiuyu$ git tag -a v1.2 -m "version 1.2 release" cfe4639 MBP:git qiuyu$ git show v1.2 tag v1.2 Tagger: qiuyu <qiuyu93422@163.com> Date: Sat Jun 27 17:22:39 2015 +0800 version 1.2 release commit cfe46396593f86edabdadfb55ee2a0b0a47670f5 Author: qiuyu <qiuyu93422@163.com> Date: Fri Jun 19 19:51:21 2015 +0800 debug01
3、操作标签
删除标签操作:MBP:git qiuyu$ git tag -d v1.2 已删除 tag 'v1.2'(曾为 1fdf6da) MBP:git qiuyu$ git tag v1.0 v1.1
因为创建的标签都只存储在本地。所以,打错的标签可以在本地安全删除。
如果要推送某个标签到远程,使用命令git push origin :
MBP:git qiuyu$ git push origin v1.0 Total 0 (delta 0), reused 0 (delta 0) To git@github.com:QyMars/git.git * [new tag] v1.0 -> v1.0
一次性推送全部尚未推送到远程的本地标签:
MBP:git qiuyu$ git push origin --tags Total 0 (delta 0), reused 0 (delta 0) To git@github.com:QyMars/git.git * [new tag] v1.1 -> v1.1
如果标签已经推送到远程,要删除远程标签就麻烦一点,先从本地删除;
然后,从远程删除。删除命令也是push,但是格式如下:
MBP:git qiuyu$ git tag -d v1.1 已删除 tag 'v1.1'(曾为 03d3111) MBP:git qiuyu$ git push origin :refs/tags/v1.1 To git@github.com:QyMars/git.git - [deleted] v1.1
相关文章推荐
- 构建企业日志实时查看系统log.io
- Promises
- 金融大总结
- UDP网络程序设计
- java数据库连接池技术浅析
- Exception handling statements
- 使用duplicate target database ... from active database复制数据库
- 谈谈Ext JS的组件——布局的使用方法续一
- 谈谈Ext JS的组件――布局的使用方法续一
- 转:有感于三个50岁的美国程序员的生活状态与IT职业杂想
- Python fabric远程自动部署简介
- MYSQL EVENT 定时器
- Python fabric远程自动部署简介
- servlet 初步 (四) session
- android获取音频绝对地址
- 谈谈Ext JS的组件——布局的使用方法续一
- 2015062504 - StringUtils源码分析
- 谈谈Ext JS的组件——布局的使用方法续一
- 谈谈Ext JS的组件——布局的使用方法续一
- 简单的扫雷代码,适合初学者