-
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 スマート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 内部コマンドと外部コマンド
- 10.2 Gitオブジェクト
- 10.3 Gitリファレンス
- 10.4 パックファイル
- 10.5 refspec
- 10.6 転送プロトコル
- 10.7 メンテナンスとデータ復旧
- 10.8 環境変数
- 10.9 まとめ
-
付録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 まとめ
-
付録B. アプリケーションへのGitの埋め込み
- A2.1 コマンドラインGit
- A2.2 Libgit2
- A2.3 JGit
- A2.4 go-git
- A2.5 Dulwich
-
付録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 内部コマンド
1.1 はじめに - バージョン管理について
この章では、Gitの使用方法について説明します。まず、バージョン管理ツールの背景について説明し、次に、Gitをシステムで実行する方法、最後に、作業を開始するための設定方法について説明します。この章の終わりまでに、Gitが存在する理由、Gitを使用する理由、そしてGitを使用するための準備が整っていることを理解する必要があります。
バージョン管理について
「バージョン管理」とは何か、そしてなぜそれが重要なのか?バージョン管理とは、ファイルまたは一連のファイルに対する変更を時間とともに記録することで、後で特定のバージョンを呼び出すことができるシステムです。この書籍の例では、バージョン管理されるファイルとしてソフトウェアのソースコードを使用しますが、実際には、コンピューター上のほぼすべての種類のファイルに対してこれを行うことができます。
グラフィックデザイナーやWebデザイナーで、画像やレイアウトのあらゆるバージョンを保持したい場合(間違いなくそうしたいでしょう)、バージョン管理システム(VCS)を使用することは非常に賢明です。これにより、選択したファイルを以前の状態に戻したり、プロジェクト全体を以前の状態に戻したり、時間の経過に伴う変更を比較したり、問題の原因となっている可能性のあるものを最後に修正した人が誰であるか、問題を導入した人が誰でいつであるかなどを確認できます。VCSを使用すると、一般的に、何かを台無しにしたり、ファイルを紛失したりした場合でも、簡単に復旧できます。さらに、これらすべての機能を非常に小さなオーバーヘッドで利用できます。
ローカルバージョン管理システム
多くの人々が選択するバージョン管理方法は、ファイルを別のディレクトリ(賢い場合はタイムスタンプ付きディレクトリ)にコピーすることです。このアプローチは非常にシンプルであるため非常に一般的ですが、非常にエラーが発生しやすいという欠点もあります。どのディレクトリにいるかを忘れ、誤って間違ったファイルに書き込んだり、意図しないファイルをコピーしたりすることは簡単です。
この問題に対処するために、プログラマーは長い間、改訂管理下にあるファイルへのすべての変更を保持する単純なデータベースを持つローカルVCSを開発してきました。

最も人気のあるVCSツールの1つはRCSと呼ばれるシステムで、現在でも多くのコンピューターに配布されています。RCSは、パッチセット(つまり、ファイル間の違い)を特別な形式でディスクに保持することで機能します。その後、すべてのパッチを追加することで、任意の時点でのファイルの外観を再作成できます。
集中型バージョン管理システム
次に人々が遭遇する大きな問題は、他のシステムの開発者と共同で作業する必要があることです。この問題に対処するために、集中型バージョン管理システム(CVCS)が開発されました。これらのシステム(CVS、Subversion、Perforceなど)には、すべてのバージョン管理されたファイルを含む単一のサーバーと、その中央の場所からファイルをチェックアウトする多数のクライアントがあります。長年にわたり、これはバージョン管理の標準となっています。

この設定は、特にローカルVCSと比較して多くの利点があります。例えば、プロジェクトの全員がある程度、互いの作業内容を把握できます。管理者は、誰が何ができるかを細かく制御でき、すべてのクライアント上のローカルデータベースを扱うよりも、CVCSの管理ははるかに容易です。
しかし、この設定にはいくつかの深刻な欠点もあります。最も明らかなのは、中央サーバーが単一障害点となることです。そのサーバーが1時間停止すると、その間は誰も全く共同作業ができず、作業中の変更をバージョン管理して保存することができません。中央データベースが格納されているハードディスクが破損し、適切なバックアップが保存されていない場合、プロジェクトの全履歴が完全に失われます。クライアントマシン上にたまたま存在するスナップショットを除くすべてです。ローカルVCSもこの同じ問題に悩まされます。プロジェクトの全履歴が単一箇所に存在する時はいつでも、すべてを失う危険性があります。
分散型バージョン管理システム
ここで、分散型バージョン管理システム(DVCS)が登場します。DVCS(Git、Mercurial、Darcsなど)では、クライアントはファイルの最新のスナップショットをチェックアウトするだけでなく、その完全な履歴を含むリポジトリ全体を完全にミラーリングします。したがって、サーバーが停止した場合でも、これらのシステムがそのサーバーを介して連携していた場合、クライアントリポジトリのいずれかをサーバーにコピーして復元することができます。すべてのクローンは、実際にはすべてのデータの完全なバックアップです。

さらに、これらのシステムの多くは、複数のリモートリポジトリをうまく処理できるため、同じプロジェクト内で同時に異なるグループの人々と異なる方法で共同作業を行うことができます。これにより、階層モデルなど、集中型システムでは不可能な、いくつかのワークフローを設定できます。