git分支管理和工作流规范:不同场景细化和演示
https://www.iteye.com/blog/qqtalk-2415889
前两篇介绍了 git基本概念 和 具体的规范,本篇针对不同的使用场景做演示。
分支
分支命名
- master 分支名称保持不变
- develop 分支名称保持不变
- feature/<分支名称> 功能分支
- release/<分支名称> 待上线分支
- hotfix/<分支名称> 线上紧急修复分支
拉取远程分支
git checkout -b <分支名称> origin/<分支名称> 拉取并关联远程分支
创建新分支
git checkout -b <分支名称> 创建新分支并切换到新分支
<!-- more -->
提交备注规范
首行,简明扼要地描述更新内容;
空出一行;
之后,详细描述更新内容。
如果对应jira的问题,填写jira路径:issue:http://jira.n.xiaomi.com/test1
举例
修复bug,工单详情页面,工单记录页面,客服头像不显示
<空行占位符>
导致原因:代码逻辑考虑不全
jira: http://jira.n.xiaomi.com/test1
如何整理自己的commit,保持commit清晰
git commit —amend 修改最近一次提交;
git rebase -i 整理提交
- edit,编辑某一次提交的备注;
- squash,把当前commit向前合并,一直合并到pick为止;
- fixup,和squash非常类似,唯一的区别就是,fixup会忽略当前commit的信息;
再次强调:如果commit已经提交到远程git仓库,一定不要再进行整理合并commit。
举例说明
基于develop分支创建一个功能分支,名称为feature/feature1;
git checkout -b feature/feature1
新建一个文件test.txt,提交;
git commit -m ‘add test.txt file’
修改文件test.txt,添加一行内容,提交;
git commit -m ‘update text.txt file, append content: love vae music’
发现上一步添加的内容错误,想修改内容,但不添加新的commit
修改为正确的内容;git commit —amend; 会弹出修改窗口,修改注释,如果不变,直接回车;
连续提交3个commit,但想合并为1个commit;
使用git log,确定要rebase的commit-id;
git rebase -i df87607d5dd24c0a73f23284e6988d6d32c0d3a4 显示编辑窗口
进行编辑,修改如下:
最终结果只会保留commit1:
新人加入,如何加入开发
从远程拉取develop分支:
git checkout -b <分支名称> origin/<分支名称> 拉取并关联远程分支
如果要开发新功能,基于develop分支创建feature分支:
git checkout -b feature/feature1
如果要修复线上紧急bug,基于master分支创建hotfix分支:
git checkout -b hotfix/hotfix1
开发一个feature
基于develop分支创建feature分支;
开发完成后,整理自己的commit,把无意义的commit进行合并;
准备在下一次迭代上线,整理完成后,合并到develop分支;
不准备在下一次迭代上线,整理完成后,push当前分支到远程git仓库,等待准备上线时,再合并到develop分支:
git push origin feature/feature1:feature/feature1
合并到develop分支前,一定要经过本地测试!
确定版本上线计划及上线
整体上,要有明确的上线计划,确定每次上线哪些功能;
只有确认在下一次版本上线的feature才能合并到develop分支;
提交测试,修复测试反馈的bug
提交测试前,确保所有人的代码修改都已提交到develop分支;
基于develop分支,创建release分支:
git checkout -b release/release1
发布release/release1分支到测试环境,测试人员进行测试;
测试过程中发现的bug,直接在release分支进行修复并提交;
测试完成,确认上线,合并代码到master分支和develop分支,用release分支名打Tag,删除release分支:
git tag release.1.1.1
git branch -d release/release1
修复线上bug
基于master分支,创建hotfix分支
git checkout -b hotfix/hotfix1
修复完成后,finish hotfix,合并代码到master和develop分支;
git分支管理和工作流规范:不同场景细化和演示的更多相关文章
- Git 分支管理和冲突解决
Git 分支管理和冲突解决 创建分支 git branch 没有参数,显示本地版本库中所有的本地分支名称. 当前检出分支的前面会有星号. git branch newname 在当前检出分支上新建分支 ...
- git分支管理和stash
1 创建分支$ git branch 分支名 2切换到分支$ git checkout 分支名 3查看提交git log --oneline --decorate --graph --all 4 轻量 ...
- [git] git 分支管理和工作流程
分支管理 列举本地分支.下面的 * 是 HEAD 所指向的分支,标识当前工作目录所用的分支.其他分支隐藏在 git 仓库中,通过 git checkout 命令才能访问和修改. $ git branc ...
- Git应用—03分支管理和冲突解决(转载)
Git 分支管理和冲突解决 https://www.cnblogs.com/mengdd/p/3585038.html 创建分支 git branch 没有参数,显示本地版本库中所有的本地分支名称. ...
- 关于git-Git 分支管理和冲突解决
创建分支 git branch 没有参数,显示本地版本库中所有的本地分支名称. 当前检出分支的前面会有星号. git branch newname 在当前检出分支上新建分支,名叫newname. gi ...
- Git commit message和工作流规范
目的 统一团队Git commit日志标准,便于后续代码review,版本发布以及日志自动化生成等等. 统一团队的Git工作流,包括分支使用.tag规范.issue等 Git commit日志参考案例 ...
- 前端规范之Git工作流规范(Husky + Comminilint + Lint-staged)
代码规范是软件开发领域经久不衰的话题,几乎所有工程师在开发过程中都会遇到或思考过这一问题.而随着前端应用的大型化和复杂化,越来越多的前端团队也开始重视代码规范.同样,前段时间,笔者所在的团队也开展了一 ...
- 好代码是管出来的——Git的分支工作流与Pull Request
上一篇文章介绍了常用的版本控制工具以及git的基本用法,从基本用法来看git与其它的版本控制工具好像区别不大,都是对代码新增.提交进行管理,可以查看提交历史.代码差异等功能.但实际上git有一个重量级 ...
- Git版本控制与工作流详解
这篇文章是针对git版本控制和工作流的总结,如果有些朋友之前还没使用过git,对git的基本概念和命令不是很熟悉,可以从以下基本教程入手: 专为设计师而写的GitHub快速入门教程 git – 简明指 ...
随机推荐
- 尚硅谷Docker---6-10、docker的安装
尚硅谷Docker---6-10.docker的安装 一.总结 一句话总结: docker的安装使用非常简单,安装的话yum安装epel和docker,使用的话就是docker run命令 1.doc ...
- 监听浏览器返回键、后退、上一页事件(popstate)操作返回键
在WebApp或浏览器中,会有点击返回.后退.上一页等按钮实现自己的关闭页面.调整到指定页面.确认离开页面或执行一些其它操作的需求.可以使用 popstate 事件进行监听返回.后退.上一页操作. 一 ...
- leetcode 240搜索二维矩阵
/** 正常的二维搜索估计要超时,本题沿着对角线搜索,然后找到第一个大于目标数字的坐标(x,y)然后搜索(>x,<y)(<x,>y)子区域: 矩阵size() 为m,n:当i& ...
- Django学习之Cookie和Session
一.Cookie 1.Cookie的由来 2.什么是Cookie 3.Cookie的原理 4.查看Cookie 二.Django中操作Cookie 1.获取Cookie 2.设置Cookie 3.删除 ...
- 微博获取原图时重定向到图片的url
微博获取原图时重定向到图片的url,所以获取的是乱码 jsoup默认是执行重定向的. //根据Url获取页面对应的Document public static Document getDoc1(Str ...
- python读取文件时遇到非法字符的处理 UnicodeDecodeError: 'gbk' codec can't decode bytes in position
报错UnicodeDecodeError: 'gbk' codec can't decode bytes in position ipath = 'D:/学习/语料库/SogouC.mini/Samp ...
- java dwg转svg
package com.example.demo.dxf2svg; import com.aspose.cad.InterpolationMode; import com.aspose.cad.Smo ...
- pyinstaller-python->exe
pip install pyinstaller. pyinstaller -F /home/base64_decode.py https://www.imooc.com/article/26772 h ...
- python2.7安装numpy、pandas、matplotlib库
我装的是python2.7 然后pip的版本是18.1,最近使用pip install **安装包的时候总是会提示 You are using pip version 18.1, however ve ...
- Jmeter JDBC请求---把数据库结果参数化传递到其他请求
摘要: 最近一个场景进行压力测试:生成商品id进行上下架和购买,记录写脚本的一个过程 1.在商品上架前需要准备商品ID,商品ID生成需要从数据库读取商品类别,从而生成商品ID,下面是从数据库:读取商品 ...