我对Git(以及VC)相当陌生,我有点难以理解使用分支进行Dev>Staging>Live工作流的概念。
我正在尝试应用这个工作流程的一部分,该工作流程使用dev分支和relase分支而不是固定的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 .
在 dev 分支上进行了一些工作
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仓库?
- 检出/合并新版本?
- 从release合并到live?
- 创建整个环境?
另外:
- 在哪里运行这些git命令?在我的本地repo上吗?还是在每个阶段都要运行?
相关信息:
- 我正在使用BitBucket
- 这是为网站(Drupal)开发而做的
- 我的master分支是live阶段
- 大约有3位开发人员同时工作,每个人在不同的国家
git archive
),或者拥有存储库的副本。在前一种情况下,您将不得不删除并重写新版本,而在第二种情况下,您将执行git fetch
/git merge
。前一种情况需要更少的空间,因为它不包括存储库的历史记录。 - Shahbaz