Git工作流程(Dev>Staging>Live)基本技术问题

标签 git workflow bitbucket

我对 Git(和 VC 而言)还很陌生,我有点难以理解 Dev>Staging>Live workflow using branches 背后的概念。

我正在尝试应用 this 的一部分 工作流,它使用 dev 分支和 release 分支而不是固定的 staging

在尝试使用 Git 之前,我有使用 SVN 的“相同”工作流程。但是我们没有为每个阶段创建分支,而是为它使用了单独的存储库。现在我正在尝试应用分支,事情变得有点模糊。

我能理解工作流背后的想法,但无法从技术角度理解它。

创建它所遵循的步骤:

创建文件夹

user:/var/www/$ mkdir dev.example.local
user:/var/www/$ mkdir staging.example.local
user:/var/www/$ mkdir example.local

初始化存储库

user:/var/www/example.local$ git init
user:/var/www/example.local$ git remote add origin git@bitbucket.org:user/example.com.git
user:/var/www/example.local$ echo "README" > README
user:/var/www/example.local$ git commit -am "First"
user:/var/www/example.local$ git push origin master

user:/var/www/example.local$ cd ../dev.example.com
user:/var/www/dev.example.local$ git clone git@bitbucket.org:user/example.com.git .
user:/var/www/dev.example.local$ git checkout -b dev
user:/var/www/dev.example.local$ git push origin dev

user:/var/www/dev.example.local$ cd staging.example.com
user:/var/www/staging.example.local$ git clone git@bitbucket.org:user/example.com.git .

开发分支的一些工作

user:/var/www/dev.example.local$ echo "New" > newfile
user:/var/www/dev.example.local$ git add .
user:/var/www/dev.example.local$ git commit -am "Some new file"
user:/var/www/dev.example.local$ git push origin dev

当新版本准备就绪时

user:/var/www/staging.example.local$ git fetch
user:/var/www/staging.example.local$ git checkout -b release-0.1 dev
user:/var/www/staging.example.local$ git push origin release-0.1

user:/var/www/staging.example.local$ cd ../example.com
user:/var/www/example.local$ git fetch
user:/var/www/example.local$ git merge --no-ff origin/release-0.1
user:/var/www/example.local$ git tag -a "0.1"
user:/var/www/example.local$ git push origin master

user:/var/www/example.local$ cd ../dev.example.com
user:/var/www/example.local$ git merge --no-ff master
user:/var/www/example.local$ git push origin dev

我很确定我没有遵循正确的步骤。那么,什么是“正确的方法”:

  • 创建 devstaginglive 文件夹并在每个文件夹中初始化 git 存储库?
  • checkout /merge 新版本?
  • release merge 到live
  • 创建整个环境?

和:

  • 我应该在哪里运行这些 git 命令?在我的本地 repo ?对于每个阶段?

相关信息:

  • 我正在使用 BitBucket
  • 这是用于网站 (Drupal) 开发的
  • 我的master 分支是live 阶段
  • 大约有 3 名开发人员同时工作,每个开发人员在不同的国家/地区

最佳答案

您不需要创建不同的存储库。您应该学习并且您可能会喜欢 git 的是使用分支是多么容易。所以第 1 步:

  • 忘掉你从 SVN 背景中知道的一切

既然我们都准备好了,那就是想法。假设您的 bitbucket 目前只有 master:

  • 克隆存储库:

    $ git clone git@bitbucket.org:user/example.com.git
    $ cd example.com
    
  • 创建您的分支:

    $ git branch dev
    $ git branch staging
    
  • 让其他人知道这些分支:

    $ git push origin dev
    $ git push origin staging
    
  • 开始工作吧!

    $ git checkout dev
    $ touch new_file
    $ git add new_file
    $ git commit
    $ git merge master         # and resolve conflicts
    $ git checkout master
    $ git merge dev
    $ git push origin
    

注意:上面的示例是一个简单的分支-实验- merge ,可能不会反射(reflect)您教程中的确切工作流程。

简而言之,您没有不同的存储库,而是在一个存储库中分支。在这些分支之间,您可以根据需要与任何您喜欢的工作流程 merge 。您可以有额外的分支,这些分支不会被推送到原点,因此它们对其他人是 stash 的。当然,您还应该经常 git fetch/git merge 您想要处理的分支,以确保您从其他协作者那里获得最新的更改。

关于Git工作流程(Dev>Staging>Live)基本技术问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11461680/

相关文章:

ruby-on-rails - Capistrano 和 Rails 部署,无法从 ubuntu 服务器访问 bitbucket 存储库

java - 如何在命令行中使用repo maven(slf4j)编译java项目?

spring - 如何在 Activiti JavaDelegate 中访问 spring bean?

ios - 如何删除 git 应用于文件的 .exec 扩展名?

git - 将 Git 存储库克隆到新的存储库中 - 没有提交历史记录

mercurial - hg push abort : http authorization required. 我正在推送到我的本地 bitbucket 存储库

html - git通过jenkins提交到html文件

workflow - "workflow engine"和 "business process management engine"有什么区别?

Kubernetes可以将工作作为工作流中的步骤链接在一起吗?

git - 为什么这个樱桃选择会导致 merge 冲突