Git/GitHub/SourceTreeの使い方
Git/GitHub/SourceTreeの使い方について、学んだことをまとめております。
Git(ギット)
Gitとは
プログラムのソースコードなどの変更履歴を記録・追跡するための分散型バージョン管理システムである。Linuxカーネルのソースコード管理に用いるためにリーナス・トーバルズによって開発され、それ以降ほかの多くのプロジェクトで採用されている。
各ユーザのワーキングディレクトリに、全履歴を含んだリポジトリの完全な複製が作られる。したがって、ネットワークにアクセスできないなどの理由で中心リポジトリにアクセスできない環境でも、履歴の調査や変更の記録といったほとんどの作業を行うことができる。これが「分散型」と呼ばれる理由である。
つまり、 『プログラムの編集や変更履歴を管理できる』 のがGit。
GitHub(ギットハブ)
GitHubとは
Gitの仕組みを利用して、世界中の人々が自分の作品(プログラムコードやデザインデータなど)を保存、公開することができるようにしたウェブサービス。
用語・機能
-
Repository(リポジトリ)
- 『リモートリポジトリ』 と 『ローカルリポジトリ』(以降、リモート、ローカル)の2つに分類される。
- リモートは、Web上に存在するリポジトリのことであり、Github・SourceTreeを用いて、 共有することが可能なリポジトリ である。
- ローカルは、自分のPC内に存在するリポジトリのことであり、例え作成元がリモートであったとしても 変更が自動で反映されることはない 。
-
Commit(コミット)
- 各リポジトリの変更の履歴のことであり、『前回の履歴』(以降、親コミット)からの変更がどうなったかを記録している。
- すべてのコミットがハッシュ(Hash)を持っており、固有の値であるためハッシュからコミットを判別することが可能である。また、初めのコミットを除いたすべてのコミットが親コミットのハッシュも保持していることで、一連のコミットとして扱うことができる。
-
Git Bash(ギット バッシュ)
- LinuxコマンドでGitを扱うターミナル。 コマンドプロンプト とは別物なので注意が必要。
- ターミナルの主要なコマンド一覧
$ ls listの略。カレントディレクトリの中身を表示する。 $ mkdir make directoryの略。ディレクトリ(フォルダ)を作成する。 $ cd /c/git change directoryの略。 指定したディレクトリにカレントディレクトリを移動する。 例では、C¥Gitへ移動。 ※ ~(チルダ)はユーザーディレクトリを表す。 $ git init カレントディレクトリに『.git』ディレクトリを作成する。 カレントディレクトリ以下をGitの監視下とする。 $ touch test.txt カレントディレクトリにtest.txtを作成する。 ※本来は、作成するコマンドではない。
SourceTree(ソースツリー)
SourceTreeとは
GitHubで作成したリポジトリに対応させることで、ローカルとリモートの共有などを補助してくれる。
リモートとの紐づけ
紐づける際は、GitHubからリポジトリのアドレスを用いる。
- Clone(クローン)
- リモートをローカルに紐づけした状態でコピーを行う。
- Add(アド)
-
リモートとローカル紐づける。
※ 更新は行われない。
-
違いに注意して使い分けることが必要。
コミットする
『作業ツリーのファイル』に表示されている変更を、 『indexにステージする』 ことでローカルでコミットできる。この時点では、まだリモートに変化はない。
コミットにコメントを残すこともできるので、変更がわかりやすいコメントを残しておく。
同期
- プッシュ
-
ローカルのコミットをリモートに反映する。
※ただし、リモートが別のプッシュを受けている場合は、リモートのコミットをローカルに反映した後にマージを行ってからプッシュをする必要がある。
-
- フェッチ
-
ローカルとリモートに差分がある場合、リモートのコミットとの差分を参照することができる。
※ ローカルの更新は行われないので注意。
-
- プル
-
ローカルにリモートの差分を反映させる。
※ 自身がローカルで行ったコミットはそのまま残る。 このとき、リモートのコミットと衝突してしまうと、Conflict(コンフリクト)が発生する。コンフリクトは、手動で解消することが必要で、 必ず確認を取り、指示を仰ぐこと。
-
ブランチ/マージ
- ブランチ
-
現在の位置を表す。
-
新たにブランチを作成することで、枝分かれを発生させることができる。
※ origin/masterはリモートを表す。
-
- マージ
-
枝分かれしたブランチを合流させる。
※ 各ブランチでマージを行う必要があるので注意が必要。
AでBとマージしたならば、BでAとマージして、初めてAとBはマージする。
-