git 操作规范
分支描述
长期存在
- online
- 主分支,负责记录上线版本的迭代,该分支代码与线上代码是完全一致的。
- dev
- 开发分支,该分支记录相对稳定的版本,所有的feature分支都从该分支创建。
- 多套开发环境是,命名规范:dev1、dev2
- test
- 测试分支,用于代码上线准备,该分支从dev分支创建,创建之后由测试同学发布到测试环境进行测试,测试过程中发现bug需要开发人员在dev分支上进行bug修复,测试通过以后再合并到test分支,由测试发布到测试环境。在上线之前,需要合并该test分支到online分支。
- 多套测试环境是,命名规范:test1、test2
- online
上线后删除
- feature
- 功能分支,用于开发新的功能,不同的功能创建不同的功能分支,功能分支开发完成并自测通过之后,需要合并到dev分支,之后删除该分支。
- 命名规范:feature/*,比如:feature/tie。(建议英文,拼音也可以)
- hotfix
- 紧急bug修复分支,该分支只有在紧急情况下使用,从online分支创建,用于紧急修复线上bug,修复完成后,需要合并该分支到online分支以便上线,同时需要再合并到dev分支。
- 命名规范:hotfix/*,比如:hotfix/fenan(建议英文,拼音也可以)
- bugfix(不常用)
- bug修复分支,用于修复不紧急的bug,普通bug均需要创建bugfix分支开发,开发完成自测没问题后合并到dev分支后,删除该分支。
- 命名规范:bugfix/*,比如:hotfix/mobile (建议英文,拼音也可以)
- feature
分支合并流程介绍
开发
- 根据功能排期,从dev分支创建feature(功能)分支(组长统一创建、管理),比如:tie、bujian。
- 联调测试,把feature(功能)分支通过rebase合并到dev分支。
提测
- 提测时把dev分支通过rebase合并到test分支。
上线
- 上线把test分支通过rebase合并到online分支。
上线以后
- 删除所有feature、hotfix、bugfix分支。
- 删除dev分支,并且从online分支创建dev分支。
操作规范
git checkout online //切换到online分支
git branch -D dev //删除本地dev分支
git push origin :dev //删除远程dev分支
git checkout -b dev //创建本地dev分支
git push origin dev:dev //创建远程dev分支
- 删除test分支,并且从dev分支创建test分支。
操作规范
git checkout dev //切换到dev分支
git branch -D test //删除本地dev分支
git push origin :test //删除远程test分支
git checkout -b test //创建本地dev分支
git push origin test:test //创建远程test分支
紧急生产bug
- 新建hotfix/*分支,验收通过以后,把hotfix/*分支rebase到dev和online分支,之后删除hotfix分支。
一般生产bug(不常用)
新建bugfix/*分支,验收通过以后,把bugfix/*分支rebase到dev分支,之后删除bugfix分支。
二、分支操作常用命令
本地操作
git add -A #添加文件
git reset . #取消添加文件
git status # 查看状态
git commit [-a] -m "更新说明" #提交更新,-a为包含内容修改和增删,-m为说明信息,也可以使用 -am。
git reset HEAD^ #取消掉本次的提交
dev分支开发
git add -A
git commit -m "更新说明"
git fetch origin dev
git rebase origin/dev #fetch和rebase可以用这条命令替换 git pull --rebase origin dev
# 如果有冲突,修改冲突
git add .
git rebase --continue #继续合并,如果有异常递归操作
git rebase --abort #终止合并
git rebase --skip #跳过本次commit合并
git push origin dev:dev #提交代码
分支管理
# 当前分支为:dev
git branch -a #查看分支信息
git branch test #创建test本地分支,test分支和当前本地dev代码一样
git push origin test:test #把本地分支推送远程仓库,并且创建远程test分支
git branch -d test #删除本地分支
git push origin :test #删除远程仓库test分支
git checkout -b test origin/test # 创建本地test,获取远程仓库test分支最新代码
test分支合并dev分支
git checkout test #先切换到test分支
git pull --rebase origin dev
git pull --rebase origin test
git push origin test:test
tag管理
git tag -a v1.0.0 -m 'version1.0.0' #创建tag
git push origin --tags #提交tag
git tag -d v1.0.0 #删除本地tag
git push origin :refs/tags/v1.0.0 #删除远程仓库tag
获取test分支最新代码
git fetch --all
git reset --hard origin/test # 本地未push代码都删除
git 操作规范的更多相关文章
- [No0000176]Git常用命令速查表(收藏大全)
名词 master: 默认开发分支 origin: 默认远程版本库 Index / Stage:暂存区 Workspace:工作区 Repository:仓库区(或本地仓库) Remote:远程仓库 ...
- 学习笔记之Git / Gitflow / TortoiseGit
Git - Wikipedia https://en.wikipedia.org/wiki/Git Git (/ɡɪt/) is a version control system for tracki ...
- Mysql高性能优化规范建议
数据库命令规范 所有数据库对象名称必须使用小写字母并用下划线分割 所有数据库对象名称禁止使用mysql保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来) 数据库对象的命名要能做到见名识意 ...
- Scrum冲刺_Day02
一.团队展示: 1.项目:light_note备忘录 2.队名:删库跑路队 3.团队成员 队员(不分先后) 项目角色 黄敦鸿 后端工程师.测试 黄华 后端工程师.测试 黄骏鹏 后端工程师.测试 黄源钦 ...
- Git Flow 分支管理简述
概述 Git 是什么 Git 是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目. Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的 ...
- 【原理、命令】Git基本原理、与Svn的区别、命令
一.Git是什么? Git是目前世界上最先进的分布式版本控制系统.工作原理 / 流程:Workspace:工作区Index / Stage:暂存区Repository:仓库区(或本地仓库)Remote ...
- Git的原理简介和常用命令
Git和SVN是我们最常用的版本控制系(Version Control System, VCS),当然,除了这二者之外还有许多其他的VCS,例如早期的CVS等.顾名思义,版本控制系统主要就是控制.协调 ...
- Git学习总结(5)——搭建Git简易高效服务器
1. mysysgit+gitblit安装流程 1.1资源 需先下载好的资源(公司用的1.6,1.7+请自行匹配对应的mysysgit+gitblit): jdk1.6 Git-1.8.4-pr ...
- git基本原理
git基本原理 一.总结 一句话总结:把原理那张图图背下来 1.git中的四大区,除了远程仓库和本地仓库,剩下两个是什么? 解答:工作区和暂存区. 2.git中的四大区(例如远程仓库和本地仓库),他们 ...
随机推荐
- taro初识一
很早之前就听说京东的凹凸实验室发布的开源的一对多的开源框架---Taro,一对多指的是一套代码编译成多端代码使用,极大的节省了开发的效率和成本 废话不多说 第一步,和vue一样下载相应的是cli脚手架 ...
- 从Win32程序中的主函数中获取命令行参数
在标准C或者Win32控制台程序的main函数中,它们都有两个参数:"argc" 和 "argv",如下所示: int main(int argc, char ...
- MyBatis基础入门《二十》动态SQL(foreach)
MyBatis基础入门<二十>动态SQL(foreach) 1. 迭代一个集合,通常用于in条件 2. 属性 > item > index > collection : ...
- 蓝桥杯 基础训练 2n皇后
数月前做的2N皇后基本看书敲代码的,然后发现当时的代码不对,正好做到算法提高的8皇后·改,顺便把以前的代码顺带改了下,题目如下: 问题描述 给定一个n*n的棋盘,棋盘中有一些位置不能放皇后.现在要向棋 ...
- scrapy item pipeline
item pipeline process_item(self, item, spider) #这个是所有pipeline都必须要有的方法在这个方法下再继续编辑具体怎么处理 另可以添加别的方法 ope ...
- 问题 1462: [蓝桥杯][基础练习VIP]Huffuman树
题目描述 Huffman树在编码中有着广泛的应用.在这里,我们只关心Huffman树的构造过程. 给出一列数{pi}={p0, p1, …, pn-1},用这列数构造Huffman树的过程如下: ...
- 因微信SSJD分享接口升级,分享变化
4月25日发版发现的微信分享问题,已确认是腾讯微信开发团队更新的分享的策略,而我们未能收到通知依然沿用老代码造成的.目前已经解决,解决方案如下: 微信分享的shareUrl域名必须与当前环境的安全域名 ...
- 像素与DPI之间的关系
先说像素.像素是电子图像组成的基本单位,将图像放大数倍,会发现图像是由一个个“小色块”紧密排列组成的,每一个“小色块”就是一个像素点. 也就是说,每个图像都是由n多个像素点组成. 再说分辨率.所谓分辨 ...
- HDU 5552 Bus Routes(NTT+分治)
题意 给定 \(n\) 个点,任意连边,每条边有 \(m\) 种颜色可选,求带环连通图的方案数. \(1\leq n\leq 10000\) \(1\leq m < 2^{31}\) 思路 直接 ...
- Learning-Python【34】:进程之生产者消费者模型
一.什么是生产者消费者模型 生产者指的是生产数据的任务,消费者指的是处理数据的任务,在并发编程中,如果生产者处理速度很快,而消费者处理速度很慢,那么生产者就必须等待消费者处理完,才能继续生产数据.同样 ...