- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
最近我在 Git 中发现了工作流的三个概念:
我读过 the nice articles关于它,但我不太了解 GitLab Flow。
简单地说。
GitFlow
我们有一个主分支作为生产分支。我们还有一个开发分支,每个开发人员都在这里 merge 他的功能。有时我们会创建一个发布分支来在生产环境中部署我们的特性。如果我们在发布分支中有错误,请修复它并将更改 pull 入开发分支。如果我们在生产中有一个严重的错误,创建新的修补程序分支,修复错误并将分支与生产(master)和开发分支 merge 。
如果我们很少发布我们的工作结果,这种方法会很有效。 (也许每 2 周一次)。
GitHub 流程
我们有一个 master 分支作为生产分支。我们(作为开发人员)可以创建用于添加新功能或修复错误的分支,并将它们与生产(主)分支 merge 。听起来很简单。这种方法适用于生产分支在一天内部署多次的极限编程。
GitLab 流程
我见过一些新术语,例如预生产、生产、发布(稳定)分支和暂存环境、预生产环境、生产环境。他们之间有什么关系?
我是这样理解的:如果我们需要添加新功能,我们会从 master 分支部署一个预生产分支。完成功能后,我们从预生产分支部署生产分支。预生产分支是中间阶段。然后 master 分支从 production 分支中 pull 所有更改。
如果我们想查看每个单独的功能,这种方法很好;我们只是在分支机构检查我们需要查看的内容。
但是如果我们需要展示我们的工作,我们会尽可能晚地创建一个带有标签的发布分支。如果稍后我们修复 master 分支中的错误,我们需要将它们挑选到最后一个发布分支。最后,我们有带有标签的发布分支,可以帮助我们在版本之间移动。
我的理解正确吗?
pull
和 cherry-pick
有什么区别?
最佳答案
这篇文章提出以来已经一年了,但考虑到 future 的读者以及事情发生了一些变化,我认为值得刷新一下。
GitHub 流程 为 originally depicted by Scott Chacon in 2011假设每个更改一旦在 feature branch
上审查并 merge 到 master
中,就应该立即部署到生产环境中。虽然这在当时有效并且符合唯一的 GitHub Flow 规则,即 master 分支中的任何内容都是可部署的,it was quickly discovered为了保持 master
已知工作生产代码 的真实记录,实际部署到生产应该从 feature 分支
之前发生 将其 merge 到 master
中。从 feature branch
部署非常有意义,因为在任何问题生产的情况下,都可以通过将 master
部署到它来立即恢复。请看a short visual introduction到 GitHub Flow。
GitLab Flow 是 GitHub Flow 的一种扩展,伴随着一组 guidelines and best practices旨在进一步规范流程。除了促进准备部署 master
分支和功能分支(与 GitHub Flow 相同)之外,它还引入了其他三种分支:
Production
branch uat
, pre-production
, production
1-5-稳定
, 1-6-稳定
我相信以上名称和示例是 self 描述的,因此我不会进一步详细说明。
关于git - GitHub Flow 和 GitLab Flow 有什么区别?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39917843/
我正在尝试实现 kotlin stateflow,但不知道它不起作用的原因。 当前输出: 验证34567 预期输出: 验证 34567 验证失败 package stateflowDuplicate
最近我发现了一个我无法理解的流行为。 问题描述 考虑这种情况:你有一个父 flow 并且在它的 collect 中,你将有一个“子”flow 并调用 .collect(),像这样: parentFlo
我想通过 UML2 事件图为以下事件建模: 执行操作 1。此操作产生两个输出参数: Object1和对象 2。 执行操作 2。此操作需要 Object2 作为输入参数。它不需要 Object1 作为输
在 Vaadin 8 中,您可以在 Tab(属于 TabSheet)上设置一个图标: tab#setIcon(...) 在 Vaadin Flow(目前使用 14.1)中,我不知道如何在 Tab(属于
有什么办法可以做到这一点吗?如果存储库仅在 .git/config 中包含 git-flow 指令(如 ),则该存储库是否被视为已初始化 .... [gitflow "branch"] mas
the 2nd collecting below does not collect until I remove the first one. also read from [Manuel Vi
在官方示例中,他们总是有 /* @flow */在页面顶部。现在这对现有项目来说很好,很有帮助,我想选择加入每个文件的流程。从头开始构建一个新项目我只想在任何地方进行流类型检查,而不必输入 /* @f
Vaadin 突然停止构建我的库并出现以下错误。我已经跳了 Vaadin 舞(还有很多其他的东西),但我现在没主意了。我尝试为生产构建库(但对于开发也失败了)。 我正在使用 Vaadin Flow。
我注意到很多人和例子都使用 Flows 作为 List<> 的包装器,例如像这样: @Query("SELECT * from some_model ORDER BY some_field") fun
Vaadin 突然停止构建我的库并出现以下错误。我已经跳了 Vaadin 舞(还有很多其他的东西),但我现在没主意了。我尝试为生产构建库(但对于开发也失败了)。 我正在使用 Vaadin Flow。
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 3 年前。 Improv
git flow init后,如何删除git flow模型? 如何从 .git/config 文件中删除所有相关配置? $ git flow init # force reset $ git flow
我运行了 git init 并在选择第一个分支时犯了一个错误。现在我想重新运行它来更改设置,但它再也不会问第一个问题。 Which branch should be used for bringing
我刚刚开始一份新工作,他们的代码管理一团乱。通常情况下这没什么问题,我可以应付,但在这个地方,情况就糟糕得离谱了。 他们使用 TFS...对此我无能为力。没有机会介绍 git,但我一直在阅读有关 gi
我的应用程序有更新问题。我不太明白 subview 之间的数据流是怎么回事。 这是我目前的结构 ViewModel:ObsebsrvableObject MainView 与 ObservedObje
为什么“flow check-contents”需要使用 < 将文件重定向到其中,而“flow suggest”则不需要?看起来 check-contents 应该假设命令行参数是要检查的文件路径。
最近我在 Git 中发现了工作流的三个概念: GitFlow GitHub 流程 GitLab 流程 我读过 the nice articles关于它,但我不太了解 GitLab Flow。 简单地说
我们刚刚改用 Hg Flow,但我们还没有弄清楚的一件事是如何最好地使用 Jenkins。理想情况下,我们将有一个构建和测试开发的作业,一个构建和测试默认作业和其他作业,这些作业在创建功能或发布分支时
将 Vaadin 12 与 FormLayout 一起使用和标签左侧的输入字段。 我想设置标签列的宽度。如何使用 Java API 实现这一点? 最佳答案 用于设置个人 FormItem标签宽度和/或
我正在使用 React-Flow 来可视化 React 中组件的树状层次结构。每当您在 React-Flow 中创建自定义节点时,您都可以像这样在树中使用它: ,我就可以做到这一点。 .有没有
我是一名优秀的程序员,十分优秀!