
ユカイ、ツーカイ、カイハツ環境!(3)
分散バージョン管理Git/Mercurial/Bazaar徹底比較
岡本 隆史
2009/1/14
Subversionとは一味違う「分散バージョン管理」とは?
最近、Linuxをはじめ、Ruby on Rails、MySQL、OpenSolarisなどのオープンソースプロダクトが次々と分散バージョン管理システムを導入し始め、「Git」「Mecruial」「Bazaar」といった、分散バージョン管理システムが注目を浴びています。
本稿では、バージョン管理ツールのデファクトスタンダードであるSubversion(以下、SVN)と分散バージョン管理システムを比較しながら、メジャーな分散バージョン管理システムであるGit、Mercurial、Bazaarについて紹介していきます。
■ 集中型と分散型
最初に、集中管理方式(または、集中型)のバージョン管理システムと分散管理方式(または、分散型)のバージョン管理システムの仕組みの違いを見ていきましょう。
前回の「SubversionとTracでファイル管理の“迷宮”から脱出」では、ソフトウェアのバージョン管理を行うツールとしてSVNを紹介しました。SVNは、サーバ上に中央リポジトリを置き、各開発者はそのサーバからリソースをチェックアウト/コミットすることにより開発を進めていきます。このようなサーバ上でリソースを集中して管理する方式が集中管理方式です。
![]() |
| 図1 集中管理方式のバージョン管理システムの仕組み |
集中管理方式では、リソースの履歴の確認、コミット、ブランチの切り替えなどのタイミングでサーバ上のリポジトリへアクセスする必要があります。
これに対して、分散管理方式では、サーバ上のリポジトリ以外にも各開発者がローカルリポジトリを持ちます。このリポジトリは開発者固有の変更を管理する「プライベートブランチ」となります。
![]() |
| 図2 よく見掛ける設計書のフォルダ |
SVNの場合は、サーバ上のリソースをチェックアウトし、変更したリソースをサーバへ直接コミットしていました。分散管理方式の場合は、次のようなワークフローになります。
■ 分散型のワークフロー
- リポジトリの複製を作成、クローン(clone)
サーバ上のリポジトリの複製を開発者のマシン上にローカルリポジトリとして作成。SVNでは、チェックアウトにより最新のリソースだけ取得していたが、分散管理方式では中央リポジトリの完全な履歴を含んだリポジトリの複製を取得する - コミット(commit)
SVNでは、サーバへ直接コミットするが、分散管理方式ではローカルリポジトリへコミットする。この時点では、サーバのリポジトリは何の影響も受けない - プッシュ/プル(push/pull)
ローカルのリポジトリの変更内容をサーバ上のリポジトリへ反映するには、プッシュもしくはプルを利用する。プッシュとプルはリポジトリ同期の方向が異なる- プッシュ(push)
ローカルのリポジトリの変更内容をサーバ上のリポジトリへ送信(push)。SVNのコミット相当の操作はプッシュに該当する - プル(pull)
サーバ上のリポジトリから各開発者のリポジトリの変更内容を取得(pull)。各開発者のリポジトリは何らかの方法でリポジトリを公開する必要がある
- プッシュ(push)
ローカルリポジトリを中央リポジトリと同期させるとき(すなわち、SVNにおける更新(update)相当の操作)は、プルを利用して中央リポジトリの更新内容をローカルリポジトリへ取り込みます。
ここでは、中央リポジトリを利用する例を示しましたが、実際には各リポジトリの関係は対等で、相互のリポジトリで自由にプッシュ/プルができます。
![]() |
| 図3 分散バージョン管理システムのリポジトリの関係 |
■ 分散でも中央リポジトリを経由して利用!!
分散バージョン管理システムでは、中央リポジトリへ反映されていない他人の変更を自由に自分のローカルリポジトリへ取り込むことができます。例えば、Linuxのカーネルの開発では、個々の開発者がディストリビューション専用のカーネルなどを公開していますが、分散バージョン管理システムを利用しているため、Linux本家の開発のブランチにスムーズに追従できます。
ただし、そのような使い方をした場合、自分のローカルリポジトリに誰のどの変更を取り込んだか把握していないと、リポジトリの状況が分からなくなるなど弊害が出てくる可能性があります。そのため、通常のソフトウェア開発においては、成果物の共有は中央リポジトリを経由して行うのがいいでしょう。
分散型の7つのメリット
さて、仕組みはなんとなく分かりましたが、分散バージョン管理システムを利用すると、何がうれしいのでしょうか。SVNとの違いを見ていきましょう。
■ 【1】一時的作業の履歴管理が容易
分散バージョン管理システムでは、各開発者の作業は、ローカルリポジトリへコミットすることになります。そのため、中央リポジトリに影響を与えることなく各開発者が変更を管理できます。
集中リポジトリ方式では、開発者がリポジトリにコミットすると、変更内容が開発者間で共有されてしまい、不具合が残っているコードをコミットすると、ほかの開発者の作業に影響を与える場合があります。分散バージョン管理システムでは、ローカルのブランチに対して作業を行い、テストまできちんと終了した作業のまとまりを中央リポジトリへ反映できます。
■ 【2】柔軟なワークフロー
各開発者の変更をマスターのリポジトリへ取り込むときに、開発者がマスターのリポジトリへ反映する以外に、マスターリポジトリの管理者が各開発者のリポジトリから変更点をプルにより取り込むことができます。この機能により、管理者が確認した変更点だけをマスターリポジトリへ反映できるようになります。
各開発者が勝手にマスターのリポジトリへコミットするのを避けることができます。例えば、リポジトリ構成を階層化し、各グループのリポジトリ上の変更をリーダーが確認して、上位のリポジトリへプッシュするという使い方ができるのです(図4)。オフショアや外注を利用する場合、発注先のリポジトリの変更を承認して取り込むようにすれば、管理が楽になります。
![]() |
| 図4 分散リポジトリによるリポジトリのグループ化 |
また、外部のソフトハウスへ外注するシステム開発の場合、ソフトハウスごとにグループリポジトリを構築しておき、リリース時に自社のマスターリポジトリへ差分を取り込むという使い方もできます。ほかにも、個人のホビーでプログラミングする場合はサーバがなくても簡単にバージョン管理できるので、手軽に利用できます。
このように分散バージョン管理システムは、大規模なソフトウェア開発から、パーソナルな環境まで、さまざまな開発で利用できます。
次ページでは引き続き、残りのメリットと7つのデメリットも紹介しましょう。
| Index | ||||||||||||
|
||||||||||||
ユカイ、ツーカイ、カイハツ環境! バックナンバー 連載インデックスへ»
- 第1回 Trac Lightningで始めるチケット式開発「電撃」入門
- 第2回 SubversionとTracでファイル管理の“迷宮”から脱出
- 第3回 分散バージョン管理Git/Mercurial/Bazaar徹底比較
- 第4回 Aptanaなら開発環境とクラウドの連携が超お手軽!
- 第5回 App Engine/AptanaなどJavaクラウド4つを徹底比較
- 第6回 Eclipse 3.5 Galileoの「実に面白い」新機能とは
- 第7回 ブラウザを選ばずWebテストを自動化するSelenium
- 第8回 JUnit/FindBugs/PMDなどを総観できるQALab/Limy
- 第9回 Googlerも使っているIntelliJ IDEAのOSS版を試す
- 第10回 Webのバグを燃やしまくるFirebugと、そのアドオン7選
- 第11回 DB設計の神ツール「ERMaster」なら、ここまでできる
| Java Solution全記事一覧 |
ホワイトペーパー(TechTargetジャパン)
- Webの表示速度を遅くする「SSLハンドシェイク」とは (2010/2/9)
安全性を担保しようとWebページにSSLを適用すると、負荷の高い処理が実行される。速度と安全性は両立できるのか? - クラウド活用「雲活」のために押さえるべき39のポイント (2010/2/2)
活用するべきサービスか否か、クラウドの利点・問題点、クラウドプラットフォーム提供企業になるための条件、開発者がするべきことに分けて紹介 - 再利用性の高いクラス作成に重要な“アクセス制御” (2010/1/28)
Javaのアクセス修飾子public、private、protectedや、Eclipseで簡単に作れるアクセサメソッドgetter、setterについて解説 - DB設計の神ツール「ERMaster」なら、ここまでできる (2010/1/21)
直感的なUIに、カスタマイズ可能な、Excel出力のテーブル定義書、辞書機能など多機能なERモデリングの無料Eclipseプラグインです
|
|
スキルアップ/キャリアアップ(JOB@IT)
スポンサーからのお知らせ
- - PR -
- - PR -
お勧め求人情報

**先週の人気講座ランキング**
〜CCNA編〜
| ◆ | 企業の仮想化に足りない“発想”とは? 仮想化運用管理のキモは意外なところに! New! |
| ◆ | 操作もマニュアルも分かりやすい! ユーザー視点で開発されたPC管理ツール New! |
| ◆ | 仮想化すればコストは削減できるか? 仮想化に必要な「3つの視点」を解説する |

| ◆ | セキュリティを知り尽くす上野氏が登壇! @ITメールソリューションLive! in Tokyo |
| ◆ | 運用管理の課題を“2つの観点”から分析 ユーザー満足度の高い「仮想環境」とは? |
| ◆ | 世界に通用するストレージの作り方とは? 製品に込めた思いを富士通の開発者に聞く |

| ◆ | OSSで手間も時間も、障害も減った―― 「マピオンの事例」オープンソース活用法 |
| ◆ | 「ノートPCの持ち出し禁止」で大丈夫? 情報漏えいを防ぐ管理手法とインフラは? |
| ◆ | 1日の処理を1秒に――MySQLの達人が語る 「コスト削減」できるチューニング |

| ◆ | ドキュメント作成を自動化して、SEの作業 効率を大幅アップ! Visio 2007の魅力 |
| ◆ | 急速に広がるHyper-Vでのサーバ仮想化 そのベストプラクティスをデルが解説 |
| ◆ | @IT主催セミナーで語られた、「担当者に 求められるセキュリティ対策」をレポート |

| ◆ | @IT「Windows 7」 特設サイトオープン! 最新情報・移行ノウハウを公開しています |










