タイトルの通り、分かったつもりだったんですよ。
でも、個人でしか使っていなかったしGithubDesktopで使っていたのでよく分かっていなかったのです。
きちんと理解すべく勉強してみました!
間違い等あればご指摘お願い致します。
GitとGitHub
Git
ファイルの変更履歴を記録できるバージョン管理システムです。
いつ、何を変更したかが一目瞭然です。
GItHub
Gitを使ったWebサービスです。
お互いのコードをレビューしたりできるなど、チーム開発を便利にできます。
リポジトリ
リポジトリとは保管庫とか棚と考えれば分かりやすいと思います。
以下の絵のようなイメージですかね。
ローカルリポジトリとリモートリポジトリ
ローカルリポジトリは自分のPC上のリポジトリで、リモートリポジトリはWeb上のリポジトリです。
ここまでは理解できます。
私が理解できなかったのはaddとかpushとかのコマンドでどういう状態になっているかということです。
これはGitの構造を理解することで解決できました。
まずはコマンドから説明し、最後に絵でまとめを説明します。
add
自分の作業ディレクトリからステージング環境へ追加することです。
//今の作業ディレクトリ以下全ての変更を追加する
$ git add .
//指定したファイルだけ追加する
$ git sample.txt
commit
ステージング環境からローカルリポジトリへ追加することです。
$ git commit -m "○○○の変更"
push
ローカルリポジトリからリモートリポジトリへ追加することです。
$ git push origin <リモートリポジトリ名>
最後に絵で流れを説明します。
forkとclone
こちらも先に説明をして最後に絵で説明します。
fork
AさんのGitHub上のリモートリポジトリをBさんのリモートリポジトリにコピーすることです。
コピーすることでAさんのリポジトリには影響を与えず色々試せるということです。
forkは以下のようにGitHub上で行うことができます。
clone
AさんのリモートリポジトリからBさんのローカルリポジトリにダウンロードすることです。
もしくはBさんのリモートリポジトリからBさんのローカルリポジトリにダウンロードすることです。
cloneは以下のようにGitHub上で行うかコマンドで行うことができます。
コマンドの場合は上記のURLをコピーし以下のコマンドを入力します。
$ git clone <URL>
以下がforkとcloneを絵で説明したものです。
branch(ブランチ)
これは図で説明するのが分かりやすいですかね。
1つのリポジトリから派生して作業することで、複数人で作業することができたり、元のリポジトリに影響を与えずにコードの変更ができたりします。
ブランチを作成することをブランチを切る
と言います。
なんかこう、パラレルワールド的な感じですよね。並行世界がある感じ。
ブランチの切り方はプロジェクトによって様々だと思いますが、GitFlowとかを見るとmain(本番環境用)からdevelopブランチ(開発)を切り、そこからさらに細かくブランチを切っていくというのが多いみたいです。
ブランチを切る際のコマンドは以下です。
//以下のコマンドで今いるブランチを確認
$ git branch
例: *develop
*<-このマークが今いるブランチを表す
//以下のコマンドで今いるブランチから新しくブランチを切る
$ git checkout -b sample1
->sample1というdevelopから派生したブランチを切ることができた
pullrequest(プルリクエスト)とmerge(マージ)
例えばBさんがfeatureブランチで作業していて「変更したよ」とpushします。
それをdevelopブランチに合体させてもいいかを「確認して欲しいよー」とリクエストするのがpullrequest(プルリクエスト)で、OKが出て合体することをmerge(マージ)と言います。
以下が説明の図です。
pullとfetchとmerge
pullはfetchとmergeを組み合わせたものなのですが、わかりにくいので図で説明します。
先にどういう時に使うかを説明します。
例えば、AさんとBさんがいてそれぞれ同じリモートリポジトリからcloneしています。
Aさんがローカルで作業をしリモートリポジトリに反映させたものを、Bさんのローカルにも反映させたいという時にpullを使います。
コマンドは以下です。
//pull
$ git pull
//fetch
$ git fetch
//merge
$ git merge
ここで私のつまづいたポイントであるリモート追跡ブランチ
というものが出てきます。
リモートブランチはリモートリポジトリの中にあるもの。
ローカルブランチはローカルリポジトリに中にあるもので、普段pushするところ。
リモート追跡ブランチはローカルリポジトリに中にあり、リモートリポジトリをローカルにコピーしただけの読み取り専用のもの。
言葉だと分かりにくいので図にします。
今回は以上です。
次はrevert(リバート)やrebase(リベース)などまとめようと思います!