dev分支和master是什么_天天用Git,分支开发你怎么弄的?

c8eed1e3926407e2db02e51da22e0a20.png来源| juejin.im/post/6844903635533594632

Git 是目前最流行的源代码管理工具。为规范开发,保持代码提交记录以及 git 分支结构清晰,方便后续维护,现规范git的相关操作

分支命名

1、master 分支

master 为主分支,也是用于部署生产环境的分支,确保master分支稳定性, master 分支一般由develop以及hotfix分支合并,任何时间都不能直接修改代码

2、develop 分支

develop 为开发分支,始终保持最新完成以及bug修复后的代码,一般开发的新功能时,feature分支都是基于develop分支下创建的。

feature 分支

  • 开发新功能时,以develop为基础创建feature分支。
  • 分支命名: feature/ 开头的为特性分支, 命名规则: feature/user_module、 feature/cart_module

release分支

release 为预上线分支,发布提测阶段,会release分支代码为基准提测。当有一组feature开发完成,首先会合并到develop分支,进入提测时会创建release分支。如果测试过程中若存在bug需要修复,则直接由开发者在release分支修复并提交。当测试完成之后,合并release分支到master和develop分支,此时master为最新代码,用作上线。

hotfix 分支

分支命名: hotfix/ 开头的为修复分支,它的命名规则与feature分支类似。线上出现紧急问题时,需要及时修复,以master分支为基线,创建hotfix分支,修复完成后,需要合并到master分支和develop分支

常见任务

增加新功能

(dev)$: git checkout -b feature/xxx            # 从dev建立特性分支
(feature/xxx)$: blabla                         # 开发
(feature/xxx)$: git add xxx
(feature/xxx)$: git commit -m 'commit comment'
(dev)$: git merge feature/xxx --no-ff          # 把特性分支合并到dev

修复紧急bug

(master)$: git checkout -b hotfix/xxx         # 从master建立hotfix分支
(hotfix/xxx)$: blabla                         # 开发
(hotfix/xxx)$: git add xxx
(hotfix/xxx)$: git commit -m 'commit comment'
(master)$: git merge hotfix/xxx --no-ff       # 把hotfix分支合并到master,并上线到生产环境
(dev)$: git merge hotfix/xxx --no-ff          # 把hotfix分支合并到dev,同步代码

测试环境代码

(release)$: git merge dev --no-ff             # 把dev分支合并到release,然后在测试环境拉取并测试

生产环境上线

(master)$: git merge release --no-ff          # 把release测试好的代码合并到master,运维人员操作
(master)$: git tag -a v0.1 -m '部署包版本名'  #给版本命名,打Tag
e73ba32cd78ea9af429b315bc4ce3783.png

日志规范

在一个团队协作的项目中,开发人员需要经常提交一些代码去修复bug或者实现新的feature。

而项目中的文件和实现什么功能、解决什么问题都会渐渐淡忘,最后需要浪费时间去阅读代码。但是好的日志规范commit messages编写有帮助到我们,它也反映了一个开发人员是否是良好的协作者。

编写良好的Commit messages可以达到3个重要的目的:

  • 加快review的流程
  • 帮助我们编写良好的版本发布日志
  • 让之后的维护者了解代码里出现特定变化和feature被添加的原因

目前,社区有多种 Commit message 的写法规范。来自Angular 规范是目前使用最广的写法,比较合理和系统化。如下图:

03e6859eb79514de49e5ab414d6f6e64.png

Commit messages的基本语法

当前业界应用的比较广泛的是 Angular Git Commit Guidelines

“https://github.com/angular/angular.js/blob/master/DEVELOPERS.md#-git-commit-guidelines

具体格式为:

<type>: 
  • type: 本次 commit 的类型,诸如 bugfix docs style 等
  • scope: 本次 commit 波及的范围
  • subject: 简明扼要的阐述下本次 commit 的主旨,在原文中特意强调了几点:
    • 使用祈使句,是不是很熟悉又陌生的一个词
    • 首字母不要大写
    • 结尾无需添加标点

body: 同样使用祈使句,在主体内容中我们需要把本次 commit 详细的描述一下,比如此次变更的动机,如需换行,则使用 |

footer: 描述下与之关联的 issue 或 break change

Type的类别说明

  • feat: 添加新特性
  • fix: 修复bug
  • docs: 仅仅修改了文档
  • style: 仅仅修改了空格、格式缩进、都好等等,不改变代码逻辑
  • refactor: 代码重构,没有加新功能或者修复bug
  • perf: 增加代码进行性能测试
  • test: 增加测试用例
  • chore: 改变构建流程、或者增加依赖库、工具等

Commit messages格式

# 标题行:50个字符以内,描述主要变更内容
#
# 主体内容:更详细的说明文本,建议72个字符以内。需要描述的信息包括:
#
# * 为什么这个变更是必须的? 它可能是用来修复一个bug,增加一个feature,提升性能、可靠性、稳定性等等
# * 他如何解决这个问题? 具体描述解决问题的步骤
# * 是否存在副作用、风险?
#
# 如果需要的化可以添加一个链接到issue地址或者其它文档

往期资源  需要请自取

Java基础核心知识大总结.pdf 下载

68道C语言/C++常见面试题(含答案)下载

Java后端开发学习路线+知识点总结

前端开发学习路线+知识点总结

C/C++开发(后台)学习路线+知识点总结

嵌入式开发学习路线+知识点总结

每天进步一点点

慢一点才能更快

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/344611.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

gradle ant_区分基于Ant目标的Gradle任务

gradle ant在我的博客文章《 从Ant Build演变Gradle构建&#xff1a;导入Ant构建文件》中 &#xff0c;我演示了如何使用Gradle内置的基于AntBuilder的Ant支持在Gradle构建中导入Ant目标。 然后&#xff0c;可以将这些Ant目标作为Gradle任务进行访问&#xff0c;并与Gradle构建…

labview求n阶乘的和_求极限方法总结

函数的极限第一步&#xff1a;判断极限类型1、 型常用方法&#xff1a;①洛必达法则 ②等价无穷小代换 ③泰勒公式2、 型常用方法&#xff1a;①洛必达法则②分子分母同除以分子和分母各项中最高阶的无穷大③基本极限&#xff1a; 当nm时&#xff0c;极限等于 ,当n&#xff1c;…

使用Gradle构建Monorepo项目

根据Wikipedia的说法 &#xff0c; monorepo是一种软件开发策略&#xff0c;其中许多项目存储在同一存储库中。 这种策略可以快速检测到因依赖关系的更改而导致的潜在问题和破坏&#xff0c;并且已被许多使用大型代码库的组织采用&#xff0c;例如Google&#xff0c;Facebook和…

【渝粤教育】广东开放大学 国际私法 形成性考核 (41)

选择题 题目&#xff1a;下列哪些情况适用我国有关法律&#xff1f;&#xff08; &#xff09; 题目&#xff1a;我国法律规定司法协助的内容包括&#xff08; &#xff09;。 题目&#xff1a;采取民事登记婚姻方式是结婚的实质要件。&#xff08; &#xff09; 题目&#xff…

【渝粤教育】广东开放大学 工商企业文化 形成性考核 (55)

选择题 题目&#xff1a;企业制度能否对企业管理起作用&#xff0c;关键在于“自律”和“他律”的相结合&#xff0c;即企业管理制度和&#xff08; &#xff09;的相融合&#xff0c;这才有可能达到企业的均衡发展。 题目&#xff1a;任何的企业管理制度&#xff0c;再好的企业…

uniapp怎么引入css_CSS 三种基础选择器

本节我们来学习 CSS 中的选择器&#xff0c;选择器是 CSS 里面一个很重要的概念&#xff0c;HTML 中的所有标签样式&#xff0c;都是通过不同的 CSS 选择器进行控制的。我们只需要通过选择器&#xff0c;就可以对不同的 HTML 标签进行选择&#xff0c;并指定各种样式声明。在 C…

万网绑定二级域名_Hexo+yilia主题网站绑定个性域名

上篇我们已经成功部署了自己的博客网站&#xff0c;初始化的网站看上去似乎少了些内容(高端大气上档次的设置)。接下来我们就进一步完善我们的博客网站(孟繁胜游)。绑定个性域名当你打开github给你设定的固定域名时&#xff0c;是不是感觉low极了。主要是github给你的域名在你注…

guava缓存数据到本地_扩展Guava缓存以溢出到磁盘

guava缓存数据到本地缓存使您可以轻松地显着加速应用程序。 Java平台的两种出色的缓存实现是Guava缓存和Ehcache 。 尽管Ehcache功能丰富得多&#xff08;例如其Searchable API &#xff0c;将缓存持久化到磁盘或溢出到大内存的可能性&#xff09;&#xff0c;但与Guava相比&am…

【渝粤教育】广东开放大学 性考 形成性考核 (33)

选择题 题目&#xff1a;GATT缓和了国际贸易()有效地促进了国际贸易的发展。 题目&#xff1a;WTO的公平竞争原则要求在WTO框架下,成员方应()采取扭曲市场竞争的措施 题目&#xff1a;技术法规般涉及国家安全、()、环境保护、劳动保护、节能等方面技术法规还涉及到与产品特性、…

jmeterhttp代理服务器_Jmeter使用HTTP代理服务器录制

1、添加线程组2、线程组下&#xff0c;添加录制控制器3、添加HTTP代理服务器&#xff0c;右键单击测试计划添加→非测试元件→HTTP代理服务器。1)HTTP代理服务器配置&#xff0c;目标控制器选择测试计划>线程组>录制控制器&#xff1b;端口号随便输入一个&#xff0c;与浏…

【渝粤教育】广东开放大学 文化田野调查 形成性考核 (22)

选择题 题目&#xff1a; 文化遗产主要是指的非物质文化遗产。 答案&#xff1a;看左侧 题目&#xff1a; 县级以上人民政府根据非物质文化遗产保护、保存工作需要&#xff0c;组织非物质文化遗产调查。非物质文化遗产调查由县级以上研究部门负责进行。 答案&#xff1a;看左侧…

GraalVM上的Picocli:极快的命令行应用程序

GraalVM GraalVM允许您提前将程序编译为本地可执行文件。 与Java VM相比&#xff0c;生成的程序具有更快的启动时间和更低的运行时内存开销。 这对于通常是短暂的命令行实用程序尤其有用。 GraalVM对Java反射的支持有限&#xff0c;它需要提前了解反射访问的程序元素。 反射访…

【渝粤教育】广东开放大学 标准化理论与方法 形成性考核 (50)

选择题 题目&#xff1a; 我国的标准层级分为&#xff08;&#xff09;级。 答案&#xff1a;看左侧 题目&#xff1a; 国家标准中"要求”属于必备要素&#xff0c;也是规范性技术要素。 答案&#xff1a;看左侧 题目&#xff1a; &#xff0c;标准可分为国际标准、区域标…

【渝粤教育】广东开放大学 社会保障学 形成性考核 (34)

选择题 题目&#xff1a;乡政府现要对申请低保的村民张三进行资格调查&#xff0c;按照法律规定&#xff0c;不属于调查范围的是&#xff08; &#xff09; 题目&#xff1a;我国现行《失业保险条例》所指失业人员为 &#xff08; &#xff09; 题目&#xff1a;《失业保险条例…

es数据频繁的更新_es之文档更新过程中并发冲突问题

1&#xff1a;乐观锁控制ES是分布式的&#xff0c;也是异步并发的&#xff0c;我们的复制请求是并行发送的&#xff1b;这就意味着请求到达目的地的顺序是不可控制的&#xff0c;是乱序的&#xff1b;如果是乱序的方式&#xff0c;很有可能出现这样的一个问题&#xff0c;新ver…

【渝粤教育】广东开放大学 网络编程技术 形成性考核 (57)

选择题 题目&#xff1a;在JavaScript中&#xff0c;运行以下代码&#xff1a; var flagtrue; document .write(typeof(flag)); 值是( )。 题目&#xff1a;下面的代码( )能在页面中弹出提示框&#xff0c;并且输入框中默认无任何内容 题目&#xff1a;在JavaScript中&#xff…

【渝粤教育】广东开放大学 金融学 形成性考核 (37)

选择题 题目&#xff1a;金融体系中居于联接宏微观的纽带和运作核心地位的是&#xff08; &#xff09; 题目&#xff1a;对居民盈余与赤字的管理选择&#xff0c;说法正确的是&#xff08; &#xff09; 题目&#xff1a;从形式上看&#xff0c;收入可分为&#xff08; &a…

面试题目_总结面试中 promise 相关题目的套路

Promise 作为当下主流的异步解决方案&#xff0c;在工作中和面试中常常出现&#xff0c;尤其是在面试中&#xff0c;会弄个场景让你手写代码&#xff0c;这里给大家介绍五道比较有代表性的题目&#xff0c;以便熟悉一些套路。promise 简单介绍先简单介绍下 PromisePromise 对象…

javafx 自定义控件_JavaFX自定义控件– Nest Thermostat第1部分

javafx 自定义控件几周前&#xff0c;由于Hendrik Ebbers的出色文章 &#xff0c;我决定花一些时间观看有关JavaFX的JavaOne讨论。 我不得不说我已经学到了很多东西&#xff0c;只是看这些视频&#xff08;即使我还没有完成&#xff09;&#xff01; Gerrit的“使用力&#xf…

【渝粤教育】电大中专Office办公软件 (4)作业 题库

1.以下软件不属于系统软件的是&#xff08; &#xff09;。 A.Visual Studio 2019 B.MySQL 5.7 C.Windows 10 D.Office 2016 错误 正确答案&#xff1a;左边查询 学生答案&#xff1a;未作答 2.学习好Office办公软件这门课程&#xff0c;应该&#xff08; &#xff09;。 A.重视…