我对 Git(以及 VC)还很陌生,我正在努力理解使用分支的 Dev>Staging>Live 工作流背后的概念。
我正在尝试应用此工作流程的一部分,它使用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
我很确定我没有遵循正确的步骤。那么,什么是“正确的方法”:
- 创建dev,staging,live文件夹并在每个文件夹中初始化 git repo?
- 结帐/合并新版本?
- 从release合并到live?
- 创造整个环境?
和:
- 我应该在哪里运行这些 git 命令?在我的本地仓库上?每个阶段?
相关资料:
- 我正在使用 BitBucket
- 这是用于网站(Drupal)开发
- 我的master分支是live stage
- 大约有 3 名开发人员同时工作,每个人都在不同的国家