
ユカイ、ツーカイ、カイハツ環境!(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」なら、ここまでできる
- 第12回 AWS ToolkitでTomcatクラスタをEC2上に楽々構築
- 第13回 究極の問題解析ツール、逆コンパイラJD-Eclipseとは
| Java Solution全記事一覧 |
ホワイトペーパー(TechTargetジャパン)
- Android NDKでJNIを使用してアプリを高速化するには (2010/3/17)
C/C++やOpenGL ESといったネイティブコードを使うためのNDKとJNIを紹介し、その使い方や注意点を徹底解説します - 調査の難しい「OutOfMemoryError」事例、5選 (2010/3/11)
Java開発者が避けて通れないメモリ不足エラーの基本的な問題切り分け方法と発生につながる事例、対処法を解説 - 究極の問題解析ツール、逆コンパイラJD-Eclipseとは (2010/3/8)
ライブラリ内で例外が発生! そのクラスのソースコードを調べたい!! 自動で逆コンパイルしてくれる無料Eclipseプラグインがあります - いまさら聞けない「Webサービス」の常識 (2010/2/26)
昨今では企業システムでも使われる「Webサービス」の概念やJava標準のJAX-WSを紹介しJBoss WSでサンプルを作成
|
|
スキルアップ/キャリアアップ(JOB@IT)
スポンサーからのお知らせ
- - PR -
| 「いつかは壊れるサーバ」そんな故障に 迅速で安価に手軽に対応する方法とは? New! |
| 「特権ユーザー」の事件を防げ! 万能権限を持つユーザーの管理方法とは? New! |
| 仮想環境の構築とデータ保護の特効薬?! 実績と信頼性の高いパッケージで安心運用 |
| 仮想環境のバックアップもこれまでどおり 「まるごと取ってまるごと戻す」簡単運用 |
| おばかアプリ選手権、第4弾開催中!! ムダにカッコよくてくだらない作品求ム! |
| 社内ファイルサーバを“クラウド”に統合 VPN直結「クラウド型ストレージ」を紹介 |
| その数、なんと400台以上! グループ内 サーバの「統合管理」によるメリットは? |
| 美人!? まあまあ? 気になる いやし系!! PV急増で「美人時計」がとった手段とは? |
| 進化を続ける富士通ストレージETERNUS DX 製品開発者の自信を裏付けるものとは何か |
| 運用管理の課題を“2つの観点”から分析 ユーザー満足度の高い「仮想環境」とは? |
- - PR -
お勧め求人情報

**先週の人気講座ランキング**
〜CCNA編〜
| ◆ | TomcatやJBossなどAPサーバ環境に関する 情報を集約! “業務”用APサーバ大百科 New! |
| ◆ | 一気に解説! 最新のクラスタストレージ 「RAIDを超えたストレージ基準」……など New! |
| ◆ | クラウド的ユーザー体験の変化は脅威か? 仮想化技術を使いこなす運用管理術を紹介 New! |

| ◆ | 上司や部下、部署内メンバーとの情報共有 を“ガラッ”と変えるコラボツールとは? New! |
| ◆ | おばかアプリ選手権、第4弾開催中!! ムダにカッコよくてくだらない作品求ム! |
| ◆ | 社内ファイルサーバを“クラウド”に統合 VPN直結「クラウド型ストレージ」を紹介 |

| ◆ | Twitterのアカウントはなぜ突破された? メールによる新手の攻撃手法とその対策 |
| ◆ | もう仮想化のお試しフェイズは終わりだ! Hyper-V 2.0が基幹システムも仮想化 |
| ◆ | 美人!? まあまあ? 気になる いやし系!! PV急増で「美人時計」がとった手段とは? |

| ◆ | クライアント企業から求められる人材 ⇒IT技術と経営戦略を併せ持つ「戦略家」 |
| ◆ | .NET編集長が実践する「技術情報検索術」 サンプル・コードを簡単に探す“技”は? |
| ◆ | 業務効率と情報セキュリティ対策を両立! 手間なく確実に機密情報を守る方法とは? |

| ◆ | 進化を続ける富士通ストレージETERNUS DX 製品開発者の自信を裏付けるものとは何か |
| ◆ | 運用管理の課題を“2つの観点”から分析 ユーザー満足度の高い「仮想環境」とは? |

| ◆ | 【CTC事例】約30の基幹システムを統合! 膨大なバッジジョブを制御した方法は? |
| ◆ | 仮想化すればコストは削減できるか? 仮想化に必要な「3つの視点」を解説する |
| ◆ | その数、なんと400台以上! グループ内 サーバの「統合管理」によるメリットは? |










