最近社内で「今までSubversionしか使ったことない人」を対象に、Git研修をやったので、情報をまとめてみました。
目的
- GitとSubversionでの構成管理方法の違い
- Gitの基本的な操作の理解
1. 構成管理の基本編
そもそも構成管理(この場合はソフトウェア構成管理)とは、ソースコードや文書などの成果物の変更履歴(「誰が」「いつ」「何を変更したか」)を管理し、任意のバージョンの製品を再現可能とすることを目的としています。
1-1. バージョン管理システム
バージョン管理システムとは、この構成管理を人手ではなく、システムを用いて行うことで、過去のある状態への復元を容易にしたり、変更内容の差分を表示できるようにします。
バージョン管理システムには大きく「集中型バージョン管理システム」と「分散型バージョン管理システム」に分けることが出来ます。
1-2. 集中型バージョン管理システム
- 特徴
- 集中型バージョン管理システム(ex. Subversion)では、1つのリポジトリ(変更管理情報を保存する場所)を複数人で共有して利用します。
利用者は、サーバにあるリポジトリから資材を取得(Checkout)し、変更作業が完了したらリポジトリに登録(Commit)します。
- 集中型バージョン管理システム(ex. Subversion)では、1つのリポジトリ(変更管理情報を保存する場所)を複数人で共有して利用します。
- メリット
- 単一リポジトリで仕組みがシンプルなため、管理が容易である
- デメリット
- 単一のリポジトリに対して並行開発を行うと、競合が発生しやすい
- リポジトリへのアクセスが常にNW経由となる
1-3. 分散型バージョン管理システム
- 特徴
- メリット
- ローカル上のリポジトリを更新することにより、NWに繋がらない状況でも利用できる
- 他のリポジトリに影響なく並行開発が可能
- デメリット
- リポジトリが複数存在するため、理解や管理が困難
- 事実上マスターリポジトリが存在しない状況になる
2. Gitの基本編
Gitで構成管理を行う場合、どのような構造イメージなのか、そしてどんなコマンドで実施するのかをまとめます。
2-1. リモートリポジトリとローカルリポジトリ
- リモートリポジトリ
- 専用のサーバに配置して、複数人で共有するためのリポジトリ
- ローカルリポジトリ
- 個々のユーザが利用するために、自分の手元のマシン上に配置するリポジトリ
2-2. Gitの構造
- ワーキングディレクトリ
- Gitの監視下でユーザーが更新や追加作業を行う領域
- ステージングエリア
- リポジトリにコミットするファイルを登録する領域
- ローカルリポジトリmaster
- ステージングエリアからコミットされたファイル群(スナップショット)を格納する領域
- ローカルリポジトリorigin/master
- リモートリポジトリの状態をローカルリポジトリで確認するための領域
- リモートリポジトリ
- リモートリポジトリ上に管理しているファイル群(スナップショット)を格納している領域
2-3. Gitコマンド~個人作業編~
主に個人作業で実施する機会の多いコマンドを以下に記載します。
- git add(ステージングエリアへの移行)
- ワーキングディレクトリで追記変更を行ったファイルやディレクトリをステージングエリアに移行
-
git add <file>..
(スペース区切りで複数ファイルを指定可能)
- git commit(リポジトリへのファイル登録)
- ステージングエリアに登録されたファイルのスナップショットを作成し、リポジトリへ移動する作業。
git commit -m "<コメント>"
- git remote(リモートリポジトリの登録)
- リモートリポジトリ連携の登録を行う(cloneでは動的に「origin」という名前でリモートリポジトリが登録)
-
git remote add <name> <url>
(name:登録名、url:リモートリポジトリのURL)
- git push(リモートリポジトリへの送信)
- リモートリポジトリで自分の手元のローカルリポジトリの変更履歴を共有するために、ローカルリポジトリ内の変更履歴をアップロードする。
Pushを実行すると、リモートリポジトリ内の変更履歴がローカルリポジトリの変更履歴と同じ状態になる。 -
git push <repository> <refspec>...
(repository:プッシュ先アドレス、refspec:プッシュするブランチ)
- リモートリポジトリで自分の手元のローカルリポジトリの変更履歴を共有するために、ローカルリポジトリ内の変更履歴をアップロードする。
2-4. Gitコマンド~チーム開発編~
主にチーム開発で実施する機会の多いコマンドを以下に記載します。
- git fetch
- ローカルリポジトリにあるリモートリポジトリのコピーを最新版に更新
git fetch <remote repository url> or <remote repository name>
- git merge(ブランチのマージ)
- ブランチをメインのブランチに統合する
git merge <branch name>
- git pull
- リモートリポジトリの内容を一度にローカル環境の所属ブランチに反映する
git pull <remote repository> <local repository >
- git clone(リモートリポジトリの複製)
- リモートリポジトリ上で作成したリポジトリの複製をローカルリポジトリに用意する。
-
git clone <repository> <directory>
(repository:リモートリポジトリのURL、directory:複製先のディレクトリ名)
基本的な概念やコマンドは以上です。
rebaseやブランチ戦略、その他便利なコマンドや使い方については別途まとめたいと思います。
参考書籍
わかばちゃんと学ぶ Git使い方入門:漫画感覚でGitを学ぶのにちょうど良い書籍です。