-
1. 入門
- 1.1 バージョン管理について
- 1.2 Gitの歴史
- 1.3 Gitとは何か?
- 1.4 コマンドライン
- 1.5 Gitのインストール
- 1.6 Gitの初回セットアップ
- 1.7 ヘルプの利用
- 1.8 まとめ
-
2. Gitの基本
- 2.1 Gitリポジトリの取得
- 2.2 リポジトリへの変更の記録
- 2.3 コミット履歴の表示
- 2.4 変更の取り消し
- 2.5 リモートでの作業
- 2.6 タグ付け
- 2.7 Gitエイリアス
- 2.8 まとめ
-
3. Gitブランチ
- 3.1 ブランチとは
- 3.2 基本的なブランチとマージ
- 3.3 ブランチ管理
- 3.4 ブランチのワークフロー
- 3.5 リモートブランチ
- 3.6 リベース
- 3.7 まとめ
-
4. サーバー上のGit
- 4.1 プロトコル
- 4.2 サーバーにGitを導入する
- 4.3 SSH公開鍵を生成する
- 4.4 サーバーのセットアップ
- 4.5 Gitデーモン
- 4.6 Smart HTTP
- 4.7 GitWeb
- 4.8 GitLab
- 4.9 サードパーティのホストオプション
- 4.10 まとめ
-
5. 分散型Git
- 5.1 分散型ワークフロー
- 5.2 プロジェクトへの貢献
- 5.3 プロジェクトの管理
- 5.4 まとめ
-
6. GitHub
- 6.1 アカウントのセットアップと設定
- 6.2 プロジェクトへの貢献
- 6.3 プロジェクトの管理
- 6.4 組織の管理
- 6.5 GitHubをスクリプトする
- 6.6 まとめ
-
7. Gitツール
- 7.1 リビジョンの選択
- 7.2 対話的なステージング
- 7.3 スタッシュとクリーン
- 7.4 作業に署名する
- 7.5 検索
- 7.6 履歴の書き換え
- 7.7 Resetコマンドの解明
- 7.8 高度なマージ
- 7.9 Rerere
- 7.10 Gitを使ったデバッグ
- 7.11 サブモジュール
- 7.12 バンドル
- 7.13 置き換え
- 7.14 認証情報の保存
- 7.15 まとめ
-
8. Gitのカスタマイズ
- 8.1 Gitの設定
- 8.2 Git属性
- 8.3 Gitフック
- 8.4 Gitによる強制ポリシーの例
- 8.5 まとめ
-
9. Gitと他のシステム
- 9.1 クライアントとしてのGit
- 9.2 Gitへの移行
- 9.3 まとめ
-
10. Gitの内側
- 10.1 PlumbingとPorcelain
- 10.2 Gitオブジェクト
- 10.3 Gitリファレンス
- 10.4 パックファイル
- 10.5 Refspec
- 10.6 転送プロトコル
- 10.7 メンテナンスとデータ復旧
- 10.8 環境変数
- 10.9 まとめ
-
A1. 付録A: その他の環境でのGit
- A1.1 グラフィカルインターフェース
- A1.2 Visual StudioでのGit
- A1.3 Visual Studio CodeでのGit
- A1.4 IntelliJ / PyCharm / WebStorm / PhpStorm / RubyMineでのGit
- A1.5 Sublime TextでのGit
- A1.6 BashでのGit
- A1.7 ZshでのGit
- A1.8 PowerShellでのGit
- A1.9 まとめ
-
A2. 付録B: アプリケーションにGitを組み込む
- A2.1 コマンドラインGit
- A2.2 Libgit2
- A2.3 JGit
- A2.4 go-git
- A2.5 Dulwich
-
A3. 付録C: Gitコマンド
- A3.1 セットアップと設定
- A3.2 プロジェクトの取得と作成
- A3.3 基本的なスナップショット操作
- A3.4 ブランチとマージ
- A3.5 プロジェクトの共有と更新
- A3.6 検査と比較
- A3.7 デバッグ
- A3.8 パッチ
- A3.9 メール
- A3.10 外部システム
- A3.11 管理
- A3.12 Plumbingコマンド
1.3 はじめに - Gitとは何か?
Gitとは何か?
では、Gitを一言で言うと何でしょうか?このセクションは非常に重要であり、Gitが何であるか、そしてその動作の基本を理解すれば、Gitを効果的に使うことがずっと簡単になるでしょう。Gitを学ぶ際には、CVS、Subversion、Perforceのような他のVCSについて知っているかもしれないことを一旦忘れてみてください。そうすることで、このツールを使用する際に微妙な混乱を避けることができます。Gitのユーザーインターフェースは他のVCSとかなり似ていますが、Gitは情報の保存方法や考え方が大きく異なっており、これらの違いを理解することは、使用中に混乱を避けるのに役立ちます。
スナップショットであり、差分ではない
Gitと他のVCS(Subversionなどを含む)との主な違いは、Gitがデータを考える方法にあります。概念的に、他のほとんどのシステムは情報をファイルベースの変更のリストとして保存します。これらの他のシステム(CVS、Subversion、Perforceなど)は、保存する情報をファイルのセットと、時間の経過とともに各ファイルに加えられた変更として考えます(これは一般的に差分ベースのバージョン管理と呼ばれます)。

Gitはデータをこのように考えたり保存したりしません。その代わりに、Gitはデータをミニチュアファイルシステムの連続するスナップショットのように考えます。Gitでは、コミットするたびに、つまりプロジェクトの状態を保存するたびに、Gitは基本的にその時点のすべてのファイルの様子を写真に撮り、そのスナップショットへの参照を保存します。効率化のために、ファイルが変更されていない場合、Gitはファイルを再度保存せず、既に保存されている同じファイルへのリンクを保持します。Gitはデータをまるでスナップショットのストリームのように考えます。

これはGitと他のほとんどすべてのVCSとの重要な区別です。これにより、Gitは他のほとんどのシステムが前世代からコピーしてきたバージョン管理のほぼすべての側面を再検討しています。これにより、Gitは単なるVCSというよりも、その上にいくつかの非常に強力なツールが構築されたミニファイルシステムのようなものになっています。データをこのように考えることによって得られる利点のいくつかについては、GitブランチでGitのブランチ機能について説明する際に詳しく見ていきます。
ほとんどすべての操作がローカルである
Gitでのほとんどの操作は、ローカルファイルとリソースのみを必要とします。通常、ネットワーク上の他のコンピューターからの情報は不要です。ほとんどの操作にネットワーク遅延のオーバーヘッドがあるCVCSに慣れている場合、Gitのこの側面は、速度の神々がGitに超常的な力を与えたかのように思わせるでしょう。プロジェクトの完全な履歴がローカルディスクにすべてあるため、ほとんどの操作はほぼ瞬時に行われます。
たとえば、プロジェクトの履歴を閲覧する場合、Gitは履歴を取得して表示するためにサーバーにアクセスする必要はありません。単にローカルデータベースから直接読み込みます。これにより、プロジェクト履歴をほぼ瞬時に確認できます。現在のファイルのバージョンと1ヶ月前のファイルの間の変更点を見たい場合、Gitは1ヶ月前のファイルを検索し、ローカルで差分計算を行うことができます。リモートサーバーにそれを依頼したり、古いバージョンのファイルをリモートサーバーからプルしてローカルで行ったりする必要はありません。
これはまた、オフラインまたはVPNから切断されている場合でも、できないことがほとんどないことを意味します。飛行機や電車に乗っていて少し作業をしたい場合、ネットワーク接続でアップロードできるようになるまで、喜んでコミットできます(ローカルコピーに対して、ということを覚えておいてください)。家に帰ってVPNクライアントがうまく動作しない場合でも、作業を続けることができます。他の多くのシステムでは、そうすることは不可能か、苦痛を伴います。たとえばPerforceでは、サーバーに接続していないとほとんど何もできません。SubversionやCVSではファイルを編集できますが、データベースに変更をコミットすることはできません(データベースがオフラインだからです)。これは大したことではないように思えるかもしれませんが、その違いがいかに大きいかに驚くかもしれません。
Gitの整合性
Git内のすべてのものは、保存される前にチェックサムが計算され、そのチェックサムによって参照されます。これは、Gitが知ることなくファイルやディレクトリの内容を変更することが不可能であることを意味します。この機能はGitの最も低いレベルに組み込まれており、その哲学に不可欠なものです。転送中に情報が失われたり、ファイルが破損したりしても、Gitがそれを検出できないということはありません。
Gitがこのチェックサムのために使用するメカニズムは、SHA-1ハッシュと呼ばれます。これは16進数文字(0–9とa–f)で構成される40文字の文字列で、Git内のファイルまたはディレクトリ構造の内容に基づいて計算されます。SHA-1ハッシュは次のようになります。
24b9da6552252987aa493b52f8696cd6d3b00373
これらのハッシュ値はGitのいたるところで目にするでしょう。なぜなら、Gitがそれらを非常に多用するからです。実際、Gitはデータベースにすべてをファイル名ではなく、その内容のハッシュ値によって保存します。
Gitは基本的にデータを追加するだけ
Gitで操作を行うとき、そのほとんどすべてはGitデータベースにデータを追加するだけです。システムに元に戻せない操作をさせたり、データを消去させたりすることは困難です。他のVCSと同様に、まだコミットしていない変更を失ったり、台無しにしたりすることはありますが、スナップショットをGitにコミットした後でそれを失うことは非常に困難です。特に、定期的にデータベースを別のリポジトリにプッシュしていればなおさらです。
このため、Gitを使うことは喜びです。なぜなら、物事をひどく台無しにする危険なしに実験できるとわかっているからです。Gitがデータをどのように保存し、失われたように見えるデータをどのように回復できるかについて、より深く掘り下げるには、変更の取り消しを参照してください。
3つの状態
さて、今から注意してください。残りの学習プロセスをスムーズに進めたいのであれば、Gitについて覚えておくべき主な点がここにあります。Gitには、ファイルが存在し得る3つの主要な状態があります。それらは、変更済み (modified)、ステージ済み (staged)、そしてコミット済み (committed)です。
-
変更済み (Modified) とは、ファイルを変更したが、まだデータベースにコミットしていない状態を意味します。
-
ステージ済み (Staged) とは、変更されたファイルの現在のバージョンを次のコミットスナップショットに含めるようにマークした状態を意味します。
-
コミット済み (Committed) とは、データがローカルデータベースに安全に保存された状態を意味します。
これにより、Gitプロジェクトの3つの主要なセクションにたどり着きます。それは、ワーキングツリー、ステージングエリア、そしてGitディレクトリです。

ワーキングツリーは、プロジェクトの特定のバージョンの単一のチェックアウトです。これらのファイルはGitディレクトリ内の圧縮されたデータベースから取り出され、使用または変更のためにディスク上に配置されます。
ステージングエリアは、通常Gitディレクトリ内に含まれるファイルで、次のコミットに含まれる情報が格納されます。Gitの専門用語での技術的な名前は「インデックス」ですが、「ステージングエリア」という表現も同様によく使われます。
Gitディレクトリは、Gitがプロジェクトのメタデータとオブジェクトデータベースを保存する場所です。これはGitの最も重要な部分であり、別のコンピューターからリポジトリをクローンする際にコピーされるものです。
基本的なGitのワークフローは次のようになります。
-
ワーキングツリー内のファイルを変更します。
-
次のコミットに含めたい変更のみを選択的にステージングし、それらの変更のみをステージングエリアに追加します。
-
コミットを実行すると、ステージングエリアにあるファイルの状態がGitディレクトリに永久的にスナップショットとして保存されます。
特定のバージョンのファイルがGitディレクトリにある場合、それはコミット済み (committed) とみなされます。ファイルが変更され、ステージングエリアに追加された場合、それはステージ済み (staged) です。そして、チェックアウトされてから変更されたものの、まだステージングされていない場合、それは変更済み (modified) です。Gitの基本では、これらの状態について詳しく学び、それらを活用する方法や、ステージングを完全にスキップする方法についても学びます。