[Tool] Git 使用 与 Git Flow
目录
简介
- Git是目前世界上最先进的分布式版本控制系统(没有之一)。
- Linus花了两周时间自己用C写了一个分布式版本控制系统,这就是Git!一个月之内,Linux系统的源码已经由Git管理了!
- 很遗憾,接触2年+的Git,今天才稍微深入分析。
命令
git config- 配置git
git config --global user.name "Never、C"// 配置用户名git config --global user.email cao@never.cn// 配置邮箱
git init- 创建版本库
git status- 查看 工作区(untracked) 和 暂存区(stage) 状态
git status -s// 精简模式查看
git addgit add . | git add --all// 添加当前所有修改到暂存区
git resetgit reset HEAD .// 将暂存区文件移除,不修改文件本身内容git reset --hard xx// 还原到历史提交记录git reset --merge// 撤销本次合并git reset --hard HEAD^// 回到上个版本,会修改文件内容
git commit- 提交到版本库
git commit -m xx// 带注释提交
git checkout- 从xx处检出文件
git checkout -- .// 将工作区文件还原为暂存区中最近的内容(暂存区无,则与版本库一致)git checkout xx// 切换到分支xxgit checkout -b xx// 创建并切换到分支xx
git log- 查看历史记录
git log --oneline// 单行显示git记录git reflog// 查看'未来'操作
git merge- 合并分支
git merge xx// 从xx分支合并到当前分支
git stash- 储藏
git stash pop// 恢复储藏的修改git stash list// 显示stash列表
git tag- 版本标签
git tag// 查看版本所有标签git tag -m "xx" v1.0// 创建版本为1.0的标签,注释为xx
git revert- 回到历史
git revert xx// 生成新的提交来回到历史记录xx的父级
git push- 推送到远程版本库
git push --tags// 版本库推送到远程库上
git rm- git rm --cached
- git rm --cached -r . // 清空暂存区
- git rm --cached
git rebase- git merge 会生成一个新得合并节点,而rebase不会
git fsck- 检查当前版本库信息是否存在错误
工作流
- 简介
- 软件开发模型有常见的瀑布模型、迭代开发模型、以及最近出现的敏捷开发模型等不同的模型。
- Git Flow重点解决的是由于源代码在开发过程中的各种冲突导致开发活动混乱的问题。
- 分支
- Git Flow模型中定义了主分支和辅助分支两类分支。
- 主分支
- 主分支是所有开发活动的核心分支。所有的开发活动产生的输出物最终都会反映到主分支的代码中。主分支分为master分支和development分支。
- master
- master分支上存放的应该是随时可供在生产环境中部署的代码(Production Ready state)。当开发活动告一段落,产生了一份新的可供部署的代码时,master分支上的代码会被更新。同时,每一次更新,最好添加对应的版本号标签(TAG)。
- develop
- develop分支是保存当前最新开发成果的分支。通常这个分支上的代码也是可进行每日夜间发布的代码(Nightly build)。因此这个分支有时也可以被称作“integration branch”。
- 规范
- 仅在发布新的可供部署的代码时才更新master分支上的代码
- 每当有代码提交到master分支时,我们可以使用Git Hook触发软件自动测试以及生产环境代码的自动更新工作。
- 辅助分支
- 辅助分支主要用于组织软件新功能的并行开发、简化新功能开发代码的跟踪、辅助完成版本发布工作以及对生产代码的缺陷进行紧急修复工作。这些分支与主分支不同,通常只会在有限的时间范围内存在。
- 辅助分支包括:
- 用于开发新功能时所使用的feature分支;
- 用于辅助版本发布的release分支;
- 用于修正生产代码中的缺陷的hotfix分支。
- feature(topic分支)
- 从develop分支发起
- 合并回develop分支 或 被抛弃
- 命名:feature-*
- 该分支可以保存在开发者自己的版本库,不强制要求在主版本库中。
- release
- 从develop分支派生
- 合并回develop 或 master分支
- 命名:release-*
- 用于发布新的产品,允许小的修正,准备发布说明信息。通过在release分支处理,可以让develop分支空闲出来。
- hostfix
- 从master分支派生
- 合并回master 或 develop分支
- 命名:hostfix-*
- 当生产环境遇到异常或严重问题,从master指定的tag派生hotfix分支修复。能够让负责新功能和bug修复人员并行工作。
[Tool] Git 使用 与 Git Flow的更多相关文章
- [Tool] 源代码管理之Git
本节目录 什么是Git 什么是GitHub 安装Git GitHub之Repository GitHub之托管页面 常用Git 命令 什么是Git 由于现在的开发多人协同办公,因此出现源代码管理工具 ...
- Git:Git初体验——Git安装配置
作为即将成为一个程序员的男人,一直在听别人说Git多好多好,之前也随便了解了一些,但是始终没有决心去学会.现在大四了,只有毕设和一门开学六七周只去过一次课的全员必修课外,也没有什么事情做,何不去做这些 ...
- Git 笔记二-Git安装与初始配置
git 笔记二-Git安装与初始配置 Git的安装 由于我日常生活和工作基本上都是在Windows上,因此此处只说windows上的安装.Windows上的安装和其他程序一样,只需要到http://g ...
- 1 起步-Pro Git---VCS比较、git基本原理、git配置
本地版本控制系统 集中化的版本控制系统 诸如 CVS,Subversion 以及 Perforce 等,都有一个单一的集中管理的服务器,保存所有文件的修订版本,而协同工作的人们都通过客户端连到这台服务 ...
- Git版本控制:Git高级教程
http://blog.csdn.net/pipisorry/article/details/50669350 Git有很多命令行参数,使用起来非常方便.可以运行 man git log ,来看一下这 ...
- Git 学习之git 分支(三)
Git 分支 几乎每一种版本控制系统都以某种形式支持分支.使用分支意味着你可以从开发主线上分离开来,然后在不影响主线的同时继续工作.在很多版本控制系统中,这是个昂贵的过程,常常需要创建一个源代码目录的 ...
- Git 学习之git 起步(一)
起步 本章介绍开始使用 Git 前的相关知识.我们会先了解一些版本控制工具的历史背景,然后试着让 Git 在你的系统上跑起来,直到最后配置好,可以正常开始开发工作.读完本章,你就会明白为什么 Git ...
- 项目开发中git常用命令、git工作流、git分支模型
#新建代码库git init # 在当前目录新建一个Git代码库git init [project-name] # 新建一个目录,将其初始化为Git代码库git clone [url] # 下载一个项 ...
- git init和git init -bare区别
1 Git init 和 git init –bare 的区别 用"git init"初始化的版本库用户也可以在该目录下执行所有git方面的操作.但别的用户在将更新push上来的 ...
随机推荐
- Day5 模块及Python常用模块
模块概述 定义:模块,用一砣代码实现了某类功能的代码集合. 为了编写可维护的代码,我们把很多函数分组,分别放到不同的文件里,提供了代码的重用性.在Python中,一个.py文件就称之为一个模块(Mod ...
- hdu4099 Revenge of Fibonacci 字典树
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4099 思想很容易想到 就是预处理出前10w个的fib数,然后建树查询 建树时只用前40位即可,所以在计 ...
- NancyFx 2.0的开源框架的使用-Stateless(二)
继续上一篇Stateless的博文,在上一篇的博文的基础上稍微加点东西 接下来右键解决方案添加新项目,一样建一个空的Web项目 然后在StatelessDemoWeb项目里面添加Views文件夹,Sc ...
- Oracle 12C 新特性之表分区部分索引(Partial Indexes)
12c之前没办法在部分或指定的分区上创建索引,12c 版本中引入了Partial Indexes(部分索引), 无论是global还是local都可以有选择性的对部分分区创建索引.分区上有索引用索引, ...
- Struts2中的JSON问题——后台返回JSON字符串到前台
最近做一个项目遇到一个比较棘手的问题,项目后台采用struts2+Hibernate3+Spring3,前台采用ExtJs4.笔者目前仍是一名大二学生吗,后台框架完全是毫无任何基础,从零学,现学现用. ...
- B计划
简介:从一个初学者的角度来讲,要从六个方面来对计算机来做一个大约的了解: 计算机的组成: 电脑配置: 操作系统: CDEF盘: 正确的开关机(主要是关机): 常用软件: 1. 电脑由哪几部分组成? ...
- python 计算两个日期相差多少个月
近期,由于业务需要计算两个日期之前相差多少个月.我在网上找了很久,结果发现万能的python,居然没有一个模块计算两个日期的月数,像Java.C#之类的高级语言,都会有(date1-date2).mo ...
- H5与客户端联调
进行H5移动端开发时,我们可以使用谷歌浏览器的设备工具栏进行,此方法实时方便快速,但这也是有限的,当我们需要在特定机型特定系统或者在webview中调试时,这种方法就显得很吃力了. 安卓: 一.与安卓 ...
- Azure Messaging-ServiceBus Messaging消息队列技术系列-索引篇
Azure Messaging ServiceBus Messaging相关的技术系列,最近已经整理了不少了,统一做一个索引链接,置顶. 方便查找,并后续陆陆续续再增加. 学习消息队列技术,可以先看第 ...
- VR问题无关方向,VR全景为您领航,全景智慧城市已势不可当
2016年,VR绝对是互联网科技圈的一个高频词. 在这一年里,Magic Leap获得阿里领投的近8亿美元的融资,VR公司的商业价值得到认可.Oculus Rift和HTC Vive的VR产品正式发货 ...