项目开发使用 git工作流插件 -- jgitflow开发实践

使用技术

规范

  1. 默认情况下会有连个分支,develop,master。这两个分支不能更改代码(插件更新的除外)。
  2. 与git服务器交互尽量使用密钥形式,不然 jgitflow 插件会提示输入密码,很烦人。
  3. 应用中可能会与技术的设计理念有冲突,请大家灵活变通。

新功能开发

  1. 使用 mvn jgitflow:feature-start 命令开启一个feature分支,在此分支中进行功能编写。
  2. 将开发模块发不到私服使用(SNAPSHOT 版本),mvn jgitflow:feature-deploy
  3. 开发完成后,使用 mvn jgitflow:feature-finish 完成功能模块,此时插件会将代码合并到develop分支,并删除分支

测试环节

  1. 切换回develop分支(使用 mvn jgitflow:feature-finish 命令时当前分支删除,会自动切换会develop分支)。
  2. 使用 mvn jgitflow:release-start 开启一个预发分支,在此分支进行测试,修复bug。
  3. 开启预发分支后,插件会自动升级develop分支中的maven版本。之后开启新的 feature 分支就是新版本。

发布环节

  1. 测试环节通过后,使用 mvn jgitflow:release-finish 完成当前分支,此时插件会将代码合并到develop分支,和master分支。合并到master分支时会将代码中的 SNAPSHOT 升级为 RELEASE
    版本,并且会提交一个以当前版本号为名的tag。当前分支会被删除。
  2. 自动发布的流水线监听到新tag,以当前master版本代码升级线上版本。

修复 bug

  1. 切换到master分支(切换时确保当前代码都以commit)
  2. 使用 mvn jgitflow:hotfix-start 创建一个修复分支,再次版本修改问题。
  3. 如需在测试环境进行测分两种情况
    1. 当前没有测试环境,可将当前分支当作测试环境,更新测试环境代码。
    2. 当前有测试环境正在测试,想与当前测试环境一起测试。手动切到当前测试环境的 release 分支,将代码合并到这里,⚠️此次合并必会有冲突,因为两个分支的maven版本不同。如没有修改pom文件内容,可直接使用 release
      分支上的 maven 版本。如若有修改pom文件则只修改内容,不修改 release 分支上版本。
  4. 修复完成后,使用 mvn jgitflow:hotfix-finish 完成当前分支,此时插件会将代码合并到develop分支,和master分支。master分支版本升级并创建新tag,develop中版本不变。
  5. 执行发布环节
相关推荐
神の愛15 分钟前
GIT,可以参数这篇,需要加以理解,文字比较冗余,还请见谅
git
jolimark43 分钟前
Windows下如何用GCC编译C语言?轻便方法分享
c语言·windows·git·mingw·gcc编译器
△曉風殘月〆1 小时前
一文带你掌握Visual Studio中集成的git功能
git·visual studio
不爱吃糖的程序媛2 小时前
鸿蒙三方库适配读懂 `thirdparty/AES/.gitignore`:哪些文件不该进 Git?
git·elasticsearch·harmonyos
天若有情67316 小时前
【C++原创开源】formort.h:一行头文件,实现比JS模板字符串更爽的链式拼接+响应式变量
开发语言·javascript·c++·git·github·开源项目·模版字符串
海盗123417 小时前
在群晖NAS上使用Git Server
git
y小花17 小时前
git常用指令
git
华科大胡子17 小时前
开源项目 Git 贡献全流程拆解
git
极地星光17 小时前
工程中:Git 子模块(submodule) vs 直接依赖(源码/库/包管理器)
git
无限进步_18 小时前
【C++&string】大数相乘算法详解:从字符串加法到乘法实现
java·开发语言·c++·git·算法·github·visual studio