なんとなく使っているGitブランチ、みんなどうやって管理しているのだろう?
その謎を解明すべく、我々はジャングルの奥地へと向かった。
#1.ブランチとは
Git上で別々の作業を並行して行うための仕組みをブランチという。
# testing-branchという名前のブランチを作る場合
$ git branch testing-branch
# testing-branchブランチで作業する場合
$ git checkout testing-branch
そもそも、ブランチっていつ使うのよ?SVNでいーじゃん!
などと思っていた時代がわたしにもありました。
SVNなどの中央集権リポジトリを利用していると、自分のコミットがどうやっても他人に影響を及ぼしてしまいます。
(コミットしたら、Aさんが修正したソースが壊れましたとかね)
自分のソースをマージして挙動確認したい!でも他の人には迷惑かけたくない!
そんな時にとても便利なのがブランチ。
本番環境で動くソースリポジトリから自分の開発用ブランチを作って、自分が修正した分だけをテストしてマージ、なんてことが簡単にできます。
#2.ブランチ戦略とは
ブランチは誰でもいくつでも作ることができる。
ブランチのブランチ、とかもできちゃう。
無法地帯の予感・・・!!!
というわけで、無法地帯にならないように計画的にブランチを作って運用していくために編み出されたもの、それがブランチ戦略。
Gitを使っているチームの数だけブランチ戦略がある。たぶん。
#3.代表的なブランチ戦略
代表的なブランチ戦略について調べてみる。
- git-flow
- GitHub Flow
- gitworkflows
- 安定trunkパターン
- メインラインモデル
- GitLab Flow
####1. git-flow
下記のブランチを主軸に運用する方法。
- master
- hotfix
- release branches
- develop
- feature branches
下記ルールに従い運用します。
- developはmasterの最新から作成
- featureはdevelopの最新から作成
- releaseはリリース対象featureマージ済developの最新から作成
- 各featureのマージ先はdevelop
- releaseはリリース時のバージョン調整などに使用
- リリースモジュールはmasterから作成
- リリースバージョンが上がるタイミングでreleaseからmasterにマージ
- マージ済featureは削除
- hotfixは致命的バグが発生した場合に使用
####2. GitHub Flow
下記のブランチを主軸に運用する方法。
- master
- work branches
- (integration branches)
下記ルールに従い運用します。
- masterは常にデプロイできる状態とする
- 作業ブランチはmasterから作業内容がわかるような名前のブランチを作成する
- 複数の作業ブランチを統合するための統合ブランチを作成しても良い
- 開発者は作成した各ブランチにコミットする
- 定期的にpushする
- masterへのマージ前に、PullRequestを作成し他の開発者からレビューを受ける
- masterへマージ後、直ちにデプロイするためにデプロイ作業を完全自動化する
- テストを重要視する
####3. gitworkflows
下記のブランチを主軸に運用する方法。
- maint
- master
- next
- pu(proposed updates, 提案中の変更)
下記ルールに従い運用します。
- maintでは前回リリースされた安定バージョンのアップデートを管理
- masterでは次回のリリースに入るべきコミットを管理
- nextは、masterトピックの安定化のための テスト用ブランチとして使用。masterリリース後に
git reset --hard master
する。 - puは、含めるにはまだ時期尚早なコミット用の統合ブランチとして使用。masterリリース後に
git reset --hard master
する。 - マージ作業が多い
- プルリクエストを利用しない(メーリングリストへメールすることで変更を知らせる)
####4. 安定trunkパターン
下記のブランチを主軸に運用する方法。
- stable
- Milestone1
- Milestone2
- (以下略)
下記ルールに従い運用します。
- Milestoneは必ずstableブランチから作成
- stable = trunk = リリースされているもの / いつでもリリース可能なもの
- 複数のリリース向けの開発、結合が可能
- マイルストーンを新設するたびに継続的インテグレーションの設定を行う必要あり
- 複数のバージョンのメンテナンスが出来ない
####5. メインラインモデル
下記のブランチを主軸に運用する方法。
- develop
- version 1.x
- version 2.x
- (以下略)
下記ルールに従い運用します。
- developブランチで作業
- 複数リリースバージョンを管理できる
- 複数バージョンを管理しない場合は、いわゆるdevelop & stableモデルと同じ
####6. Git Lab Flow
下記のブランチを主軸に運用する方法。
- master
- pre-production/staging
- production
- (feature/hotfix)
下記ルールに従い運用します。
- pre-production = GitHub Flowの統合ブランチ = git-flowのrelease
- 作業が終わったらfeatureブランチにコミット
- CIでのテストをパスしたらpre-productionに自動デプロイ
- pre-productionでのテストをパスしたらproductionに自動デプロイ
#4.所感
- GitHub flowとGitLab-flowの使い分けがまだよくわからない。
- CI環境が整っているならマージが多く発生するフローでも問題なさそう
- 小さいチームやプロジェクトならmasterとdevelopのみのGitHub flowが使いやすそう
- チームの規模、リリース頻度、チームのスキルレベル、運用難易度などの観点で再度整理したい
#参考
GitHub実践入門 Pul Requestによる開発の変革
大塚弘記 著/技術評論社/2014.04.25初版/
[A successful Git branching model翻訳]
(http://keijinsonyaban.blogspot.com/2010/10/a-successful-git-branching-model.html)
[書籍「Pro Git」のコンテンツ]
(https://github.com/progit/progit/blob/master/ja/03-git-branching/01-chapter3.markdown)
[git運用フローの選び方]
(https://qiita.com/arai-ta/items/7350d1053d14078a2a97)
[Gitのブランチモデルについて]
(https://qiita.com/okuderap/items/0b57830d2f56d1d51692)
[Using git-flow to automate your git branching workflow]
(https://jeffkreeftmeijer.com/git-flow/)
[(分散)バージョン管理システムの組織化]
(http://troter.jp/pyconjp-2012-dvcs/#slide1)
[Gitlab-flowの説明]
(https://qiita.com/tlta-bkhn/items/f2950aaf00bfb6a8c30d)
[Introduction to GitLab Flow]
(https://docs.gitlab.com/ee/topics/gitlab_flow.html)