はじめに
使い始めて約一年、最初よりも操作に慣れてきたSourceTree。
それでも聞いたことのない用語や、使ったことのない機能がまだ多くあるので復習も兼ねてまとめました。
もくじ
- はじめに
- リポジトリ(Repository)
- クローン(Clone)
- コミット(Commit)
- プッシュ(Push)
- ブランチ(Branch)
- チェックアウト(Checkout)
- スタッシュ(Stash)
- マージ(Merge)
- フェッチ(Fetch)
- プル(Pull)
- リベース(Rebase)
- チェリーピック(Cherry-pick)
- まとめ
リポジトリ(Repository)
ファイル、ディレクトリのバージョン管理を保存している場所。貯蔵庫のイメージ。
この中に今まで行ってきた変更や修正を溜めていく。
リポジトリの種類は以下二つ。
リモートリポジトリ(Remote Repository)
サーバ上に存在するファイルやディレクトリの変更履歴を保存するリポジトリ=外部にあるリポジトリ。
公開、共有がスムーズなので複数人での開発に使われたり、個人開発でもネットワーク状にデータを保存したい時、共有したい時に使える。
自分含む複数の人が同時に見ることが可能で、保存されている変更履歴を自分のローカルリポジトリに落とすことができる。
リモートリポジトリ上のファイルを直接編集も可能だが、事故るので行わない。
ローカルリポジトリ(Local Repository)
自分のpc上に作成されるリポジトリ。自分専用の貯蔵庫。
リモートリポジトリに保存されていた変更履歴をここに入れていく。
作業者はローカルリポジトリのファイルを編集し、リモートリポジトリにアップロードして変更履歴を保存していく。
クローン(Clone)
リモートリポジトリを自分のローカル環境(自分のpc上)へコピーすること。
コミット(Commit)
ローカルリポジトリに対してファイルやディレクトリの変更を保存すること。
ゲームのセーブポイントのイメージ。
変更履歴は各コミット単位で保存されている。コミットだけだとリモートリポジトリには反映されない。
プッシュ(Push)
ローカルリポジトリのコミットをリモートリポジトリにアップロードすること。
クローンとは反対。
ブランチ(Branch)
同じリポジトリ内で複数の変更を同時に進めるため、履歴を分けて記録していくもの。
またベースになるmasterブランチに誤った変更を加えてしまうのを防いだり、同じタイミングでの機能の追加、バグの修正を行うことができる。
チェックアウト(Checkout)
今いるブランチから別のブランチに切り替えること。
移動先に何らかの変更がされている時や、自分のブランチにプッシュしていないコミットがある時は使用ができない。
コミットせずにチェックアウトしたい場合、スタッシュをすることでコミット内容を退避できる。
スタッシュ(Stash)
コミットしていない内容を一時的に退避させること。
作業中でない他ブランチに切り替える必要があった際に、作業が中途半端な時やまだコミットのタイミングでない時に使用する。
マージ(Merge)
分岐したブランチを別のブランチに合体させること。
ベースになるmasterブランチではなく、別に作業ブランチで作業し、その作業をmasterブランチにマージしていくような流れが基本。
フェッチ(Fetch)
リモートリポジトリの最新の履歴を取得のみできる。
ブランチにはフェッチの内容が反映されない。今のリモートリポジトリが最新状態かどうかを確認するために使用することが多い。
プル(Pull)
リモートリポジトリの最新履歴を取得し、ローカルリポジトリに最新の履歴を反映する。
ダウンロードのイメージ。フェッチと機能は似ているが自分のローカルリポジトリにリモートの履歴を取り込めることが大きな違い。
プル=フェッチ+マージと言える。
リベース(Rebase)
作業ブランチをベースとなるブランチの最新から作り直すことができる。
作業中にマスターブランチが先に進んでいき、自分の作業ブランチが古いマスターブランチから分岐した状態の時に行うと、新しくマスターブランチの最新から分岐させることができる。
チェリーピック(Cherry-pick)
任意のコミットを作業中のブランチに取り込むことができる。
別ブランチにあるコミット内容を今の作業ブランチで使いたい時に使用する。
まとめ
専門的な用語が多くとっかかりにくいな…と最初に使った時に思ったのを覚えています。
やっぱり自分で操作してみないと覚えられないので、使える機会があったら進んでやっていきたいです!
参照、参考
【Git】No Git, No Life!
【Git】入門記事リンク集【Sourcetree/GitLab/git-flow】
【初心者向け】Gitの各用語をわかりやすく説明します
【イラストで覚える】初心者のためのGitとGitHub用語集
Gitを使いこなしたい!〜仕組みとコマンド24選〜
サル先生のGit入門