最近Gitに初めて触れたのだが、仕組みや用語の理解に時間がかかった。
そのため、今回記事に書くことで自分自身の理解を深めるとともに、
私と同じようにGitに不慣れな人への助けになればと考え、書かくこととなった。
Gitとは
- ネット上に無料で公開されているオープンソースソフトウェア
- ファイルのバージョンを管理する「分散型バージョン管理システム」
- バージョン管理が楽になるので、ファイルに変更を加えたり、修正がしやすくなる
- GitHabやGitLab等のWeb上に提供されているサービスと連携できる
- リモートリポジトリと手元のローカルリポジトリでファイルを別々に管理
※バージョン管理システムとは
「誰が」「いつ」「何を」変更したのかをファイルごとに記録するシステム
記録をもとに、過去の特定の状態を復元することができる
どのタイミングでバグが発生したのか追跡することもできる
Gitの仕組み
Gitのフロー
- Gitで複数人同時進行の作業をする様子を図で表すと分散したような形になるため、
“分散型” バージョン管理システムと呼ばれる
Gitの特徴
- 基本、CUI(コマンドベース)のため、画面ベースのソフトは別々にPCに入れる
- 基本、ブランチやコミット履歴等を画面で分かりやすく見るには別のウェブ上のサービスが必要
基本用語
リポジトリ
- ファイルやディレクトリを格納するための保管庫
- IT分野において、情報や成果物を蓄積・管理し、開発プロセスを効率化するうえで重要な役割を担う
- ローカルとリモートの2つある
リモートリポジトリ
- 特定のサーバー上に設置された共用リポジトリ
- 全体の作成物をまとめる
ローカルリポジトリ
- 各作業端末に設置された個別リポジトリ
- 個人の作業内容を他の作業者に共有する場合、リモートにデータを送信(push)する
- 他の作業者の作業内容を見るには、リモートのデータを受信(fetch)する
フェッチ(fetch)
- リモートリポジトリのデータをローカルリポジトリに受信すること
- 他の作業者の作業内容を見るときに行う
プッシュ(push)
- ローカルリポジトリのデータをリモートリポジトリに送信すること
- 個人の作業内容を他の作業者に共有するときに行う
インデックス
- リポジトリとワークツリーの中間領域
- 複数個ファイルをまとめてローカルリポジトリに移す(commit)ことができる
- インデックスへの登録は “ステージング” とも呼ばれる
- 各作業者が作業をしているディレクトリのこと
- ワークツリーで編集した内容を各種リポジトリに移すには、インデックスへの登録(add)が必要
- リポジトリからワークツリーへの反映は自動で行われる
アッド(add)・ステージング
- インデックスへ登録すること
コミット(commit)
-
インデックスからローカルリポジトリへの記録作業
-
コミットのたびに、以下のような情報が記録される
- ファイルの変更内容
- ファイルの編集日時
- コミットした人(名前・メールアドレス)
- コミットメッセージ(任意)
-
コミットのたびに上記の情報を持ったファイルが生成され、リポジトリに格納される
-
リポジトリ上でコミットの履歴を確認することができる(コミットログ)
クローン(clone)
- リモートにあるリポジトリをローカルにコピーする
- 一般的には、開発環境構築のためにローカルに作業ディレクトリを作る目的で行われる
- 完全なコピーなので、リモートリポジトリのサーバーが壊れても、ローカルリポジトリに対してリモートのサーバーからクローン(clone)すれば復元することが可能
ブランチ
- 作業者間の平行作業を全て正確に記録するための機能
- ブランチの情報はリポジトリに保存されている
- コミットのフローを分岐させることで実現している
- 複数のブランチを1つにまとめる(merge)ことでシステムを開発していく
マージ(merge)
- 複数のブランチを1つにまとめること
オリジン(origin)・マスター(master)
- オリジナル(元々)のブランチのこと
※基本的にこのブランチはマージのとき以外に操作しない
プル(pull)
- ローカルリポジトリは自動的にリモートの内容を取得しない
そのため、リモートから情報を受信(fetch)し、ローカルリポジトリのブランチの更新(merge)を行うことで更新できる
(Fetch + marge = pull) - ローカルリポジトリのブランチが更新されることで、ワークツリーのファイルが自動更新されることから、リモートリポジトリをもとにワークツリーを更新することをプル(pull)と表現することもある
- 最新データに更新するときに行う
カレントブランチ
- 現在作業中のブランチを指す
Gitの使い方
- 複数人で作業する際は、リモートリポジトリに作業内容を共有、またはリモートリポジトリから引用する
- リモートリポジトリにデータを送るには、ローカルリポジトリを経由しなければならない
- そのために、各端末ごとにフォルダを設置し、作業者はそのフォルダ内にファイルを作成し、作業をする
- 編集内容をフォルダからローカルリポジトリに移すために、中間にあるインデックスへ登録する
- その後、インデックスからローカルリポジトリに記録するが、その編集内容をコメントとして残しておくと、確認した際に分かりやすい
- リモートからローカルリポジトリへデータを受信すると、他の作業者の内容を閲覧、保存ができる
- 作業を始める時と、ローカルからリモートリポジトリへデータを送信する前には、リモートリポジトリからデータを受信し最新状態へ更新をしておく
→その結果、競合を減らし、効率化を図る
Gitと連携する
-
Gitはツールやソフトウェアを活用したり、Web上に提供されているサービスと連携したりすることで、使用できる
-
Gtiを使うためのツールやサービス
-
SourseTree
- GitをGUI(画面ベース)で使用できるソフトウェア
- 同時に入れてくれるため手軽に使える
- これ一つでGitを使え、更にブランチや他者のコミットの履歴を画面ベースで見ることができる
-
GitHub/GitLab
- ネットワーク上に公開されている基本無料のウェブサービス
- ネット上でプログラムソースや情報を共有したり公開することができる
(リモートリポジトリとして利用することが多い) - 他の人が公開したものをネット上で見ることができる
- 開発現場でもよく利用されている(その場合は非公開で管理)
-
GitBash
- GitをCUI(文字ベース)で使用できるツール
- Linuxコマンドを打ち込むことで様々な命令を出すことができる
- 実際の開発現場でもよく使われており、細かな操作やスクリプトの実行にも対応
- Windows環境でも利用できるため、開発の学習にも便利
-
※今回はより深く学習した、GitBashについて説明を行う
Git Bashを使う
インストール
- ダウンロード
下記URL先でダウンロードをクリック
Git Bash - ダウンロードしたファイルの実行
全て“Next”を押して進める
設定
コミット等の際に表示されるユーザー名とメールアドレスを登録する
-
ユーザー名、メールアドレスを設定
「git config --global user.name [ユーザー名]
」:ユーザー名の設定
「git config --global user.email [メールアドレス]
」:メールアドレスの設定 -
設定の確認
「git config --global --list
」:設定した内容を表示
gitbash
$ git config -- global user. name ユーザー名
$ git config -- global user. email メールアドレス
$ git config -- global -- list
user.name=ユーザー名
user. email=メールアドレス
ユーザー名、メールアドレスが表示されたら登録完了
実際の操作・コマンド
何か作業を行ったらコマンドを打ってこまめにに確認する
リポジトリの作成
作業に使用するローカルリポジトリの作成
-
作業フォルダの作成
「cd [アドレス]
」:作成したいアドレスに移動
「mkdir [フォルダ名]
」:フォルダの作成
フォルダ名は任意の名前(今回はGit) -
作成したフォルダへの移動
「cd [フォルダ名]
」:フォルダの移動 -
リポジトリの作成
「git init
」:空のリポジトリを作成
「ls –a
」:フォルダの中身を表示する
gitbash
$ cd /c/
$ mkdir Git
$ cd Git
$ git init
Initialized empty Git repository in C:/Git/.git/
$ 1s -a
/ .. / .git/
作成した名前のファイルができていれば作成完了
インデックスに登録する
まずコミットを行う作業ファイルの作成をする
- ファイルの作成とリポジトリの状態を確認
「touch [ファイル名]
」:ファイルの作成
今回は(test.txt)
「git status
」:リポジトリの状態を確認
※「git status」の表示内容について
・On branch master
ブランチの情報が表示されている
現在のブランチが ”master“ であることが分かる
・No commit yet
一度もコミットしていない場合に表示される
・Untracked files
Gitの管理対象になっていないファイルを表示しする
gitbash
$ touch test.txt
$ git status
On branch master
No commits yet
Untracked files:
(use "git add ... " to include in what will be committed)
test.txt
nothing added to commit but untracked files present (use "git add" to track)
2.インデックスにファイルを登録をする
「git add [ファイル名]
」:指定したファイルをインデックスに登録
※「git add .」 全てのファイルをインデックスに登録できる
※「git reset」 インデックスの登録を取り消すことができる
「git status
」:ファイルの状態を確認
※Change to be committed に緑でインデックスに登録済みのファイルが表示される
※Qiitaの表示上色が付かなかったが(test.txt)が緑色
gitbash
$ git add test.txt
$ git status
On branch master
No commits yet
Changes to be committed:
(use "git rm -- cached ... " to unstage)
new file: test. txt
Change to be committed と表示されたら登録完了
コミットする
インデックスに登録されているファイルをコミットする
- ファイルのコミットを行う
「git commit -m “コメント”
」:コミットする
今回は”テストファイルのコミット”とコメント
gitbash
$ git commit -m"テストファイルのコミット"
[master (root-commit)437129f]テストファイルのコミット
1 file changed, 0 insertions(+), 0 deletions (-)
create mode 100644 test.txt
2.コミット後の確認を行う
「git status
」:状態の確認
※nothing to commit, working tree clean と表示される
全てコミットされ、その後の変更されたファイルが無い状態に表示される
gitbash
$ git status
On branch master
nothing to commit, working tree clean
nothing to commit, working tree clean と表示されたら登録完了
3.コミットの履歴を確認
「git log
」:履歴を確認
※履歴には以下の内容が表示される
・commit:「コミットハッシュ」 (コミットを特定することができる値)
・Author:「コミットしたユーザー」
・Date:「コミットの日時」
・Dateの下に 「コメント」 が表示される
gitbash
$ git log
commit 437129f31c1ff6df15f5da18cc5676b1e9cfe408 (HEAD -> master)
Author: ユーザー名
Date: Wed Apr 13 15:39:09 2022 +0900
テストファイルのコミット
コミット後のファイル変更
コミットしたファイルに編集を加える
- ファイルの編集・変更
「vi [編集ファイル名]
」:ファイルを開く
今回は(test.txt)
「i
」:ファイルを編集
※入力後編集可能になる
Escキー:編集を終了
「:wq
」:編集を保存、戻る
「git status
」:状態を確認
※Changes not staged for commit に赤色で変更のあったファイルを表示する
※Qiitaの表示上色が付かなかったが(test.txt)が赤色
gitbash
$ vi test.txt
$ git status
On branch master
Changes not staged for commit:
(use "git add ... " to update what will be committed)
(use "git restore ... " to discard changes in working directory)
modified: test.txt
no changes added to commit (use "git add" and/or "git commit -a")
2.差分の確認
「git diff
」:コミットした内容から変更されている箇所が表示される
gitbash
$ git diff
diff -- git a/test.txt b/test. txt
index e69de29 .. 0867e73 100644
a/test.txt
+++ b/test.txt
ca -0,0 +1,3 ca
+test
+test
+test
3.変更内容の取り消し
「git checkout -- [ファイル名]
」:ワークツリーでの変更を取り消す
※変更を取り消したため、「git diff」を使用しても何も表示されない
gitbash
$ git checkout -- test.txt
$ git diff
$
何も表示されなければ取り消し完了
ブランチ
ブランチを操作する
- ブランチの作成
「git branch [ブランチ名]
」:ブランチの作成を行う
今回は(test_branch)
「git branch
」 ブランチの状態を確認する
カレントブランチは緑色で「*」が表示される
※Qiitaの表示上色が付かなかったが(master)が緑色
gitbash
$ git branch test_branch
$ git branch
* master
test_branch
2.ブランチの切り替え
「git checkout [ブランチ名]
」:ブランチの切り替えを行う
「git branch
」:ブランチの状態を確認する
※Qiitaの表示上色が付かなかったが(test_branch)が緑色
gitbash
$ git checkout test_branch
Switched to branch 'test_branch'
$ git branch
master
* test_branch
3.ブランチの削除
「git checkout [ブランチ名]
」:ブランチの切り替えを行う
(カレントブランチは削除できないため)
「git branch –D [ブランチ名]
」:指定したブランチの削除を行う
「git branch
」:ブランチの状態を確認する
gitbash
$ git checkout master
Switched to branch 'master'
$ git branch -D test_branch
Deleted branch test_branch (was ef93224).
$ git branch
* master
削除したブランチが消えていたら登録完了
まとめ
・Gitとは、ネット上に無料で公開されているオープンソースソフトウェアで、ファイルのバージョンを管理する「分散型バージョン管理システム」と呼ばれる
・バージョン管理が楽になるので、ファイルに変更を加えたり、修正がしやすくなる
・GitHabやGitLab等のWeb上に提供されているサービスと連携できる
・リモートリポジトリと手元のローカルリポジトリでファイルを別々に管理
・Git Bashでは、何か作業を行ったらコマンドでこまめにに確認するとよい
上記が、私が調査しまとめた結果となる。
今後も学習を続けより理解を深めていこうと考える。
Git Bashのコマンドを使った基本操作
コマンド | 説明 |
---|---|
git config –global –list | 設定の確認 |
cd | フォルダの移動 |
ls –a | フォルダの中身を表示 |
git status | リポジトリの状態を確認 |
git log | コミットの履歴を確認 |
git diff | 差分を表示 |
git branch | ブランチの状態を確認 |
git checkout ブランチ名 | ブランチの切り替え |
作業コマンド
コマンド | 説明 |
---|---|
git config –global user.name [ユーザ名] | ユーザー名を設定 |
git config –global user.email [メールアドレス] | メールアドレスを設定 |
mkdir [フォルダ名] | 作業フォルダの作成 |
git init | リポジトリの作成 |
touch [ファイル名] | コミットするファイルの作成 |
git add [ファイル名] | インデックスにファイルの登録 |
git commit -m “コメント” | ファイルのコミットを行う |
vi [編集ファイル名] | ファイルの編集 |
git checkout — [ファイル名] | 変更内容の取り消し |
git branch [ブランチ名] | ブランチの作成 |
git branch –D [ブランチ名] | ブランチの削除 |
Views: 2