git workflow

更新日期: 2019-01-08 阅读: 3.8k 标签: git

Git与SVN的比较

原理上

  • Git直接记录文件快照,SVN每次提交记录哪些文件更新更新了哪些行
  • Git有本地仓库,SVN没有本地仓库
  • Git大多数是本地操作,SVN大多数操作需要联网

操作上

  • Git先提交到本地仓库然后推送到远程仓库,SVN直接推送到远程仓库
  • Git有各种”反悔”指令,SVN没有
  • Git有真正的branch,而SVN只是工作空间的副本

Gitflow工作流

Gitflow为不同的分支分配一个很明确的角色,并定义分支之间如何和什么时候进行交互。

历史分支

develop和master是两个常驻分支,master分支记录了正式发布的历史,而develop分支作为功能的集成分支。因此,master分支的每次提交都应分配一个版本号。

功能分支

新的功能分支应该从develop分支迁出一个feature分支,新功能开发完成之后再合并回develop分支,常用命令:

  1. 开发功能a
git checkout -b feature-a develop
  1. 开发完成后合并回develop分支
git checkout develop
git merge --no-ff feature-a
git push
git branch -d feature-a

发布分支

  1. 当开发完成时,直接从develop分支checkout出release分支
 git checkout -b release-0.1 develop
  1. release分支用于发布,发布完成后将release分支合并到master分支并且打标签,方便后续跟踪每次发布。
git checkout master
git merge --no-ff release-0.1
git push

git tag -a 0.1 -m "release 0.1 publish" master
git push --tags

维护分支/热修复

  1. 从master分支拉出一个hotfix分支维护分支用于bug修复、快速给发布版本打补丁
git checkout -b hotfix master
  1. bug修复完成立即合回master分支和develop分支,完成维护后删除hotfix分支
git checkout master
git merge --no-ff hotfix
git push

git checkout develop
git merge --no-ff hotfix
git push 

git branch -d hotfix
  1. master上打新tag
git tag -a 0.2 -m "release 0.2 publish" master
git push --tags

优点

  • 单个功能独立开发,并行开发互不干扰
  • master和develop分支分别记录发布和功能开发的历史
  • 由于有发布分支,其他暂不发布的功能的开发不受发布的影响,可以继续提交
  • 维护分支能快速打补丁,不影响正在开发的功能

缺点

  • 复杂,分支繁多
  • Git GUI不支持,纯命令行
  • 对开发者要求高(理解工作流,熟悉Git命令)
  • 所有功能分支基于不稳定的develop
  • 需要维护两个长期分支master和develop

GitHub Flow

  • 所有在master上的东西都是可发布的(已发布或马上发布)
  • 开发新功能时,从master拉一个名称清晰的新分支
  • 在本地提交到这个分支的同时把它push到远程仓库
  • 当你需要得到反馈或帮助,或者该分支准备merge时,打开一个pull request
  • 该分支被review且同意合并后,合并到master
  • push到master后,应该立即发布

优点

  • 操作简单
  • 主干的代码有质量保证

缺点

  • 测试线和正式环境的发布没有区分

Git-Develop

Git-Develop模式将develop分支作为固定的持续集成和发布分支

  • 每一个功能都从master拉一个功能分支。
  • 在这个功能分支上开发,功能完成到发布时,提交code review,通过后自动合并到develop。
  • 待所有计划发布的变更分支代码都合并到develop后,rebase master到develop,完成发布。
  • 应用发布成功后打一个tag。
  • develop分支的发布版本合并回master。

优点

  • 操作相对简单
  • 流程稍作改动,即可区分测试线和正式环境
  • 每次开发都基于正式版本最新的代码(master),和当前开发的其他分支不产生依赖关系
  • master始终是已发布状态

Pull Requests

Pull requests不是一种工作流,而是一个能让开发者更方便地进行协作的功能,可以在提议的修改合并到正式项目之前对修改进行讨论。

  • 开发者在本地仓库新建一个功能分支。
  • 功能完成后,开发者push分支修改到远程仓库中。
  • 开发者发起Pull requests。
  • 团队成员收到通知,进行code review,讨论和修改。
  • 项目维护者合并功能到仓库中并关闭Pull Requests。

来自:https://sjis.me/post/git_workflow/


本文内容仅供个人学习、研究或参考使用,不构成任何形式的决策建议、专业指导或法律依据。未经授权,禁止任何单位或个人以商业售卖、虚假宣传、侵权传播等非学习研究目的使用本文内容。如需分享或转载,请保留原文来源信息,不得篡改、删减内容或侵犯相关权益。感谢您的理解与支持!

链接: https://fly63.com/article/detial/1800

相关推荐

git从远程仓库克隆dev分支到本地的实现

这篇文章主要介绍git从远程仓库拉取dev分支到本地的实现【gitLab】:初始化一个本地仓库、与远程仓库建立连接 、查看本地是否具有dev分支、在本地创建分支dev并切换到该分支 、dev分支上的内容都拉取到本地

解决git/github下载速度缓慢的问题总汇

官网下载Git时,速度几乎是超不过20KB,解决方法有很多,这里介绍几个简单粗暴的方法。这里使用windows系统作为演示,其他系统对号入座即可。

git强制覆盖master分支

在开发中,通常会保持两个分支master分支和develop分支,但是如果因为develop上面迭代太多而没有及时维护master,最后想丢弃master而直接将测试确认过的develop强推到master,该怎么操作呢?因此,做如下总结分享,希望对遇到同样问题的人用帮助。

Git报错:remote: HTTP Basic: Access denied的解决方法

账号密码验证不通过,密码或者权限不对,导致 Git 操作失败。输入:git config --system --unset credential.helper,再次进行 Git 操作,输入正确的用户名,密码即可。

通过git命令,上传本地文件到git服务器

把本地代码上传到git的方法:步骤一:首先进入需要上传的项目文件夹,通过命令git init初始化,步骤二:将本地文件添加到版本库中,使用命令 git add . 将文件提交到本地的暂存区,步骤三:使用命令git commit将文件提交到本地仓库...

vscode git 全局忽略文件和文件夹

windows 中先在当前用户根目录下创建一个全局要忽略的文件列表.gitignore_global,window下 只有扩展名的文件不让保存,可以在 git bash中创建文件;二、 然后在命令行下执行下面git 命令

git合并分支

假如我们现在在dev分支上,刚开发完项目,执行了下列命令:想将dev分支合并到master分支,操作如下:首先切换到master分支上,如果是多人开发的话 需要把远程master上的代码pull下来

Git忽略规则文件.gitignore_关于.gitignore配置

.gitignore 文件的作用就是告诉git, push的时候忽略指定的文件夹或者文件,例如:vue-cli脚手架创建的项目,push到github上时,不会上传node依赖文件夹,这是因为vue-cli脚手架创建的时候,自动为我们创建了 .gitignroe文件,并且为我们写好了规则。

Git 如何撤回某一次提交?

在 master 分支做了一次 commit.之前没有出过这样的错误。就算出现也是直接push了然后再 reset 回滚然后再次 push -f。重置位置的同时,只保留Working Tree工作目录的內容

.gitignore的使用手册

避免将不必要的文件添加到版本管理系统中,比如前端的node_modules目录,该目录包含大量文件,如果将其添加到版本管理系统中,会使仓库变的庞大,不利于仓库的管理。

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!