Chuanqiz’s blog

git 工作流程 (转载)

这里对常用的 git 工作流进行梳理和简化

分支命名规则

  • git 仓库命名为 origin
  • 主分支为 master ,存放正式发布版本的代码。该分支上的代码可以随时部署到正式环境。
  • 默认分支和开发分支为 develop ,存放日常工作的最新代码。
  • 发布版本的分支命名为 release/xxx,其中 xxx 是对应的版本号。在这个分支上只进行 bugfix,并且当版本发布完成后,相应的分支上的修改就会合并到 masterdevelop,并将该分支删除。
  • 发布版本的 tag 命名为 vxxx ,其中 xxx 是对应的版本号。
  • 功能分支为 feature/xxx ,其中 xxx 是简明的功能点描述,由小写字母、数字和下划线构成。例如: feature/otafeature/remote_debug。当功能成功发布后,相应的分支删除。
  • bug 修复分支为 bugfix/xxx ,其中 xxx 是简明的 bug 描述,由小写字母、数字和下划线构成,例如:bugfix/data_mismatch 。如果修复的是缺陷管理系统中已有的缺陷,则 xxx 的值为对应缺陷的唯一编号,如 bugfix/442。当缺陷已确认修复后,相应的分支删除。

开发流程

  1. 项目初始化
Command line instructions

Git global setup
git config --global user.name "chuanqi zang"
git config --global user.email "[email protected]"

Create a new repository
git clone [email protected]:sys/openjdk.git
cd openjdk
touch README.md
git add README.md
git commit -m "add README"
git push -u origin master

Existing folder
cd existing_folder
git init
git remote add origin [email protected]:sys/openjdk.git
git add .
git commit -m "Initial commit"
git push -u origin master

Existing Git repository
cd existing_repo
git remote rename origin old-origin
git remote add origin [email protected]:sys/openjdk.git
git push -u origin --all
git push -u origin --tags
  1. 开发者将相应的项目 clone 到本地并定期与远端保持更新
 git clone https://xxx.xxx/xxx.git
 git checkout -b develop origin/develop
  1. 准备进行开发工作之前,开发者基于最新的 masterdevelop 建立相应的分支
 git pull
 git checkout -b feature/xxx develop
  1. 开发者在本地分支上进行修改及 commit
  2. 到达一定程度后(建议每半天到一天,或者修改的代码数量达到一定程度后),将本地分支 pushorigin
  3. 功能开发完成后,从 origin 获取最新的开发进度,进行合并,并 pushorigin。 (这个步骤在团队规模扩大后变更为 PR )
 # 切换到 develop 分支
 git rebase develop
 ​
 # https://www.git-tower.com/learn/git/ebook/cn/command-line/advanced-topics/rebase
 # 如果有冲突则手动合并
 git mergetool
 git rebase --continue
 ​
 # 获取最新进度
 git pull origin develop
 ​
 # 合并分支
 git merge feature/xxx
 ​
 # 推送到远端
 git push
 ​
 # 删除本地分支
 git branch -d feature/xxx
  1. 发布版本
 git checkout -b release/0.0.1 develop
 ​
# 这里可能会有 bugfix
 ​
 # 将 release 合并到 master 。这里一定是没有冲突的。
 git checkout master
 git merge release/0.0.1
 git push
 ​
 # 将 release 合并到 develop
 git checkout develop
 git merge release/0.0.1
 git push
 ​
 # 在 master 上打版本的 tag
 git tag -a v0.0.1 -m "0.0.1 版本" master
 git push --tags
  1. bugfix 分支
 # 建立 bugfix 分支
 git checkout -b bugfix/001 release/0.0.1(或其他相应有缺陷的分支)
 ​
 # 修改和 commit 略过
 ​
 # 合并到有缺陷的分支
 git checkout release/0.0.1
 git merge bugfix/001
 git push

关于 commit message

对 commit message 提出下面的要求:

  • Summary 需要能看出来简单的内容,不能简单写成 bugfix 或者 日常修改 之类。如果有未解决的问题则需要使用 [未完成] 等标注清楚。
  • Descriptions 可以不写,如果写就一定要写清楚。

commit message 建议遵循如下规范:

 type: subject [tag]
 <br>
 body

其中 type 的取值和 subject 的建议写法为:

  • feature 表明新功能,例如: feature: 保存日志
  • bugfix 表明对缺陷的修改,例如: bugfix: #001, #002
  • docs 表明修改文档,例如: docs: 补充安装说明
  • refactor 表明进行代码重构,例如: refactor: 调整了 chart.state 的结构
  • perf 表明进行了优化,例如: perf: 日志内容改为每秒刷新一次
  • build 表明修改了构建工具,例如: build: 升级到 webpack4
  • revert 表明用于撤销之前的某次 commit ,需要注明具体是哪一个,例如: revert: 撤销了 8cef3a 尝试修改死机问题
  • style 表明样式的修改,例如: style: 首页导航栏现在更有动感
  • ci 表明涉及到持续集成工具的修改,例如: ci: 加入 jenkins 的配置
  • test 表明测试用例的修改,例如: test: 增加对 FileUtils 的几个单元测试
  • chore 表明修改了其他的不影响业务的东西

如果一个 commit 对应修改了多个缺陷,则在 body 中具体描述,例如:

 fixed #13175 【管理端】【采购订单】修改采购订单页面,修改供应商后,保存报错
 fixed #446 总是死机的问题

版本更新日志

  • 版本更新日志应当手动维护
  • 版本更新日志应当命名为 CHANGELOG.md
  • 类型包括: Added, Changed, Deprecated, Removed, FixedSecurity

参考文档

1 评论

发表回复

此站点使用Akismet来减少垃圾评论。了解我们如何处理您的评论数据