Git学习笔记(8)——标签管理
本文主要记录的Git标签的作用、标签的多种创建方式,以及标签的删除,与推送,和使用GitHub的Fork参与别人的项目。
标签的作用
发布版本时,通常先在版本库中打一个标签,这样,就唯一确定了打标签时刻的版本。无论什么时候,取某个标签的版本,就是把那个打标签的时刻的历史版本取出来。所以,标签也是版本库的一个快照。Git的标签虽然是版本库的快照,但其实它就是指向某个commit的指针(跟分支很像,但是分支可以移动,标签不能移动),所以,创建和删除标签都是瞬间完成的。
创建标签
ubuntu@myUbuntu:~/joe/learngit$ git branch
* dev
master
ubuntu@myUbuntu:~/joe/learngit$
git checkout master
//切换到主分支
切换到分支 'master'
您的分支与上游分支 'origin/master' 一致。
ubuntu@myUbuntu:~/joe/learngit$
git tag vs1.
//在此时创建一个标签,并查看
ubuntu@myUbuntu:~/joe/learngit$ git tag
vs1.
//给以前的commit提交创建标签
ubuntu@myUbuntu:~/joe/learngit$
git log --pretty=oneline --abbrev-commit
//查看历史提交ID
Merge pull request # from joesGit15/dev
9ba78c3 Merge branch 'dev' of github.com:joesGit15/learngit into dev
ba535f3 ubuntu dev
a90acc8 ok
a920dd1 win dev test
52bc95e test01
addb113 merge
95c3257 ubuntu dev
......
......
ubuntu@myUbuntu:~/joe/learngit$
git tag v0. 52bc95e
//给test01设置标签
ubuntu@myUbuntu:~/joe/learngit$ git tag
v0.
vs1.0//便签的顺序不是按照时间顺序排序的,而是按照字母排序的。
ubuntu@myUbuntu:~/joe/learngit$
git show v0.
//显示某个标签而定详细内容
commit 52bc95e5ed322f015e8904b1b26222afde0b670b
Author: joe <little_star13@.com>
Date: Tue May :: + test01 diff --git a/abc.c b/abc.c
index 08db0a8..190e9d0
--- a/abc.c
+++ b/abc.c
@@ -, +, @@
I am dev
-bug is o
I am ubuntUk
bug is ok
I am dev window
//带有姓名和备注内容的标签
ubuntu@myUbuntu:~/joe/learngit$
git tag -a vs0. -m "version 0.6"
a920dd1
ubuntu@myUbuntu:~/joe/learngit$
git show vs0.
tag vs0.6
Tagger: joe <little_star13@.com>
Date: Tue May :: + version 0.6 commit a920dd13e56cb76c49d48b9bfde4d7b963456eeb
Author: joe-PC <little_star14@sina.cn>
Date: Tue May :: + win dev test diff --git a/abc.c b/abc.c
index 099b74b..637aca6
--- a/abc.c
+++ b/abc.c
@@ -, +, @@
I am dev
-bug is ok
I am dev window
//为便签设置签名(必须安装gpg)
ubuntu@myUbuntu:~/joe/learngit$
git tag -s vs1. -m "signed version 1.1"
ba535f3
gpg: 已创建目录‘/home/ubuntu/.gnupg’
gpg: 新的配置文件‘/home/ubuntu/.gnupg/gpg.conf’已建立
gpg: 警告:在‘/home/ubuntu/.gnupg/gpg.conf’里的选项于此次运行期间未被使用
gpg: 钥匙环‘/home/ubuntu/.gnupg/secring.gpg’已建立
gpg: 钥匙环‘/home/ubuntu/.gnupg/pubring.gpg’已建立
gpg: “joe <little_star13@.com>”已跳过:私钥不可用
gpg: signing failed: 私钥不可用
error: gpg 无法为数据签名
error: 无法签署 tag
ubuntu@myUbuntu:~/joe/learngit$ pgp
程序“pgp”尚未安装。 您可以使用以下命令安装:
sudo apt-get install pgpgpg
标签的操作
ubuntu@myUbuntu:~/joe/learngit$
git tag
//显示所有标签
v0.
vs0.
vs1.
ubuntu@myUbuntu:~/joe/learngit$
git tag -d v0.
//本地删除单个标签
已删除 tag 'v0.5'(曾为 52bc95e)
ubuntu@myUbuntu:~/joe/learngit$
git push origin vs0.
//将单个标签推送到远程库
对象计数中: , 完成.
写入对象中: % (/), bytes | bytes/s, 完成.
Total (delta ), reused (delta )
To git@github.com:joesGit15/learngit
* [new tag] vs0. -> vs0.
ubuntu@myUbuntu:~/joe/learngit$
git push origin --tags
//推送所有标签
Total (delta ), reused (delta )
To git@github.com:joesGit15/learngit
* [new tag] vs1. -> vs1.
ubuntu@myUbuntu:~/joe/learngit$ git tag
vs0.
vs1.
//以下2步合起来是删除远程库的标签
ubuntu@myUbuntu:~/joe/learngit$
git tag -d vs0.
//前删除本地的标签
已删除 tag 'vs0.6'(曾为 91832c8)
ubuntu@myUbuntu:~/joe/learngit$
git push origin :refs/tags/vs0.
//推动到远程。
To git@github.com:joesGit15/learngit
- [deleted] vs0.
GitHub的使用
GitHub不仅是免费的远程仓库,个人的开源项目,可以放到GitHub上,而且GitHub还是一个开源协作社区,通过GitHub,既可以让别人参与你的开源项目,也可以参与别人的开源项目。
在GitHub上,利用Git极其强大的克隆和分支功能,人们可以自由参与各种开源项目。比如人气极高的bootstrap项目,这是一个非常强大的CSS框架,在它的项目主页,点“Fork”就在自己的账号下克隆了一个bootstrap仓库,然后,从自己的账号下clone。一定要从自己的账号下clone仓库,这样你才能推送修改。如果从bootstrap的作者的仓库地址git@github.com:twbs/bootstrap.git克隆,因为没有权限,你将不能推送修改。如果你希望bootstrap的官方库能接受你的修改,你就可以在GitHub上发起一个pull request。
Git学习笔记(8)——标签管理的更多相关文章
- git学习笔记12-标签管理-版本
发布一个版本时,我们通常先在版本库中打一个标签(tag),这样,就唯一确定了打标签时刻的版本.将来无论什么时候,取某个标签的版本,就是把那个打标签的时刻的历史版本取出来.所以,标签也是版本库的一个快照 ...
- Git学习总结(标签管理)
在Git中打标签非常简单,首先,切换到需要打标签的分支上: 然后,敲命令git tag <name>就可以打一个新标签: $ git tag v1. 可以用命令git tag查看所有标签: ...
- git 学习笔记 -- 创建标签
在Git中打标签非常简单,首先,切换到需要打标签的分支上: $ git branch * dev master $ git checkout master Switched to branch 'ma ...
- git学习笔记08-分支管理策略-实际上我们应该怎么应用分支
Git用Fast forward模式(快进模式),但这种模式下,删除分支后,会丢掉分支信息. 如果要强制禁用Fast forward模式,Git就会在merge时生成一个新的commit,这样,从分支 ...
- git 学习笔记---操作标签
如果标签打错了,也可以删除: $ git tag -d v0.1 Deleted tag 'v0.1' (was f15b0dd) 因为创建的标签都只存储在本地,不会自动推送到远程.所以,打错的标签可 ...
- Git学习笔记五--分支管理
为什么要引入分支? 分支在实际中有什么用呢?假设你准备开发一个新功能,但是需要两周才能完成,第一周你写了50%的代码,如果立刻提交,由于代码还没写完,不完整的代码库会导致别人不能干活了.如果等代码全部 ...
- GIT学习笔记(3):分支管理
GIT学习笔记(3):分支管理 何谓分支 GIT是如何存储数据的 GIT不是存储文件差异或者变化量,而是一系列文件的快照.在Git提交时,会保存一个提交(commit)对象,该对象包含一个指向暂存内容 ...
- 【转帖】Git学习笔记 记录一下
本文内容参考了廖雪峰老师的博文,并做了适当整理,方便大家查阅. 原帖地址 https://wangfanggang.com/Git/git/ 常用命令 仓库初始化 - git init 1 git i ...
- Pro Git 学习笔记
Pro Git 学习笔记 文档地址:Pro Git原文地址:PRO GIT 学习笔记 git常见命令 1.Git起步 初次运行Git前的配置 用户信息 git config --global user ...
- Git学习笔记 (二)
Git学习笔记(二) 突然发现,学习新知识新技能,都得经常温故使用,这样才能日益精进.最近学习的Git是因为加入了课题组,在学习做一些后台,由于后台开发会牵扯到多人开发,所以学会Git这一代码管理工具 ...
随机推荐
- Android自定义View之CircleView
Android自定义View之CircleView 版权声明:本文为博主原创文章,未经博主允许不得转载. 转载请表明出处:http://www.cnblogs.com/cavalier-/p/5999 ...
- Quartz.Net与MVC结合定时任务
1.首先,我们打开Visual Studio 2015,创建一个ASP.NET MVC的Web应用程序项目. 2.然后通过程序包管理器控制台来安装Quartz.Net组件. Quartz.Net一个最 ...
- C++ 文章列表
C++ 文章列表 Cocos2dx(1) iconv 跨平台的使用方法(Android, IOS) --- 转码(中文乱码)http://www.cnblogs.com/TS-qrt/articles ...
- c# WebBrower 与 HttpRequest配合 抓取数据
今天研究一个功能,发现一个问题. 通过webbrower模拟用户自动登录可以完成,并且可以取到相对应的页面内容. 但是如果页面中通过ajax,动态加载的内容,这种方式是取不到的,于是用到了httpRe ...
- 8.4.4 Picasso
Picasso 收到加载及显示图片的任务,创建 Request 并将它交给 Dispatcher,Dispatcher 分发任务到具体 RequestHandler,任务通过 MemoryCache ...
- Python学习之路--select解析
sellect.poll.epoll三者的区别 select select最早于1983年出现在4.2BSD中,它通过一个select()系统调用来监视多个文件描述符的数组,当select()返回后, ...
- mysql 存储过程 死循环,如何关闭
如果误操作 ,存储过程中出现了死循环怎么办?删除存储过程是不能解决问题的. 解决方法, 1,打开mysql客户端,在查询窗口中执行: show processlist; 2,查询到自己的那个进程 ...
- ASP.NET 导出gridview中的数据到Excel表中,并对指定单元格换行操作
1. 使用NPOI读取及生成excel表. (1)导出Click事件: 获取DataTable; 给文件加文件名: string xlsxName = "xxx_" + DateT ...
- (转载)JAVA敏捷开发环境搭建
整个软件项目分为四个环境 开发本地环境.开发环境.测试环境.IDC环境.和传统C++开发不一样的模式是多了第一个开发本地环境.这是为什么呢,因为目前大部分开发人员还是比较熟悉windows下开发.对于 ...
- 读《我是IT小小鸟》后有感
我是一名大一新生,在下半学期开学时,我迎来新课程——<大学生职业生涯规划与就业指导 >.这是一门既新颖,又有许多就业知识和理论的学科.在课上,老师向我们推荐了一本书,名叫<我是IT小 ...