はじめに
今まで学習してきたことを、自分なりにまとめていきます。
Gitとは
分散型バージョン管理システムです。
分散型バージョン管理システムとよばれるのは、以下のような特徴があるからです。
- 古いバージョンに簡単に戻せる
- 新旧のファイルを一元管理できる
- 編集した履歴を複数人で共有できる
- 複数人で修正した部分を一つに統合できる
簡単に説明すると、ファイルのバージョン管理を簡単にするツールのことです。
Gitで管理しているファイルなどは、コンピューター上でファイルの編集履歴を管理することができるので、編集前のファイルを残したまま新しく編集したファイルを保存することができます。
なので、バージョン管理を簡単にすることができるということです。
GitHubとは
GitHubとは、Gitの仕組みを利用して、世界中の人々が自分の作品(プログラムコードやデザインデータなど)を保存、公開できるようにしたWebサービスの名称のことです。
GitHubはその名の通り、GitのHub(ハブ:拠点・中心・集まり)という意味になります。
Gitの基本用語
リポジトリ(repository)
リポジトリとはファイルやディレクトリを保存しておくための貯蔵庫のことです。
- ・リモートリポジトリ
- 特定のサーバー上に設置して、複数人で共有するリポジトリ
- ・ローカルリポジトリ
- ユーザーごとに配置され、手元のPCで編集できるリポジトリ
ブランチ(branch)
ブランチとは、ファイルの編集履歴を分岐させて記録していく機能のことです。
コミット(commit)
コミットとは、ファイルやディレクトリの編集作業をローカルリポジトリに記録するために必要な操作のことです。
ワークツリーとインデックス
ワークツリーとは、ユーザーが編集している作業中のディレクトリのことです。
インデックスとは作業場所であるワークツリーと保存場所であるローカルリポジトリの間にある中間領域のことです。
プッシュ(push)
プッシュとはローカルリポジトリにあるファイルをリモートリポジトリに送信し、保存する機能のことです。
クローン(clone)
クローンとはダウンロードのようなものです。
マージ(merge)
マージとは複数のブランチを一つにまとめて、完成形に近づけることです。
ブランチを統合するようなイメージ。
プル(pull)
プルとは共有されているリモートリポジトリに保存されているファイルの内で、ローカルリポジトリ(あなたのローカル環境)に無いファイルや他のユーザーが更新したファイルのみをダウンロードする機能のことです。
フェッチ(fetch)
フェッチとはリモートリポジトリからファイルの最新情報を取得してくる操作のことです。
プルとは違い、ローカルのファイルを更新することはありません。
プルリクエスト
git push origin <ブランチ名> で、プッシュしたブランチの内容をリモートリポジトリのmasterブランチへ反映させるために、プルリクエストというものをGitHub上で作成します。
「ブランチの作業内容をmasterブランチへ反映させたいのですがいいですか?」とお願いをすることです。
Git開発の流れ
- GitHubにリポジトリを作成する
- 自分のパソコンにフォルダを作成する
- 作成したフォルダをGit管理し、GitHubにアップロードする
- masterブランチからブランチを切る(作成する)
- 切ったブランチ内で作業をする
- 作業が終わったら作業内容をリモートリポジトリにプッシュする
- 切ったブランチの内容をmasterブランチへ結合するプルリクエストを作成する
- プルリクエストをmasterブランチへマージする
- masterブランチの内容をプルする
- その後は4から9をループ
また、1~3は必須の作業ではありません。
すでにリポジトリを他の人が作成している場合は、そのリポジトリを自分の端末へクローンしてから開発をしていきます。
リモートリポジトリの作成
1.リポジトリの新規作成
アカウントにログイン後 New をクリックし、リモートリポジトリを作成してみましょう!
※GitHubで作成するリポジトリはリモートリポジトリと呼ばれています。
2.リポジトリの設定
1.リポジトリの名前を入力
2.このリポジトリを公開するか非公開にするかを決めます
3.Create repositoryをクリックすることでリモートリポジトリの作成が完了します
3.作成したフォルダをGit管理し、GitHubにアップロードする
ターミナルを開き、プッシュしたいディレクトリ(フォルダ)に移動してください
移動できたら下記のコマンドを順に実行していきましょう!
まずはローカルリポジトリを作成します。
$ git init
下記のように表示されたら成功です!
Initialized empty Git repository in ~
次にワークツリーからインデックスへのファイルの登録
$ git add README.md
git add -A .
で、全てのファイルをまとめて追加する方が簡単なのでオススメです!
次に追加・変更したファイルをGitに登録するためのコマンド
$ git commit -m "first commit"
-mはメッセージオプションのことで、“first commit”の中にどのような編集内容なのかを記録することができます。
次にGitリポジトリでのブランチ名の変更を行います
git branch -M main
次にローカルリポジトリとリモートリポジトリの結びつけを行います。
$ git remote add origin https://github.com/ユーザーID/リポジトリ名
こちらはpushするたびに行う必要はなく、結びつけるために1度だけ最初に行います。
最後にリモートリポジトリにファイルをアップロードしていきます。
$ git push -u origin main
これでローカルリポジトリからのGitHubへのファイルアップロードの一連の流れが完了しました!
更新したファイルをアップロード
ローカルリポジトリに新しくブランチを作成し、更新したファイルをアップロードしてみましょう!
ブランチの作成
$ git switch -c 作成したいブランチ名
ワークツリーからインデックスへのファイルの登録
git add -A .
追加・変更したファイルをGit
$ git commit -m “コメント”
変更内容をリモートリポジトリへ反映
git push origin ブランチ名
プルリクエストを作成
まずは、GitHubでリポジトリを開いてください。
そして、メニューバーの Pull requests をクリックしてください。
New pull request をクリック。
下記画像の赤枠内が、プルリクエストしたいブランチになっていることを確認したら、 Create pull request をクリック。
タイトルとコメントを入力できる画面に遷移するので、他開発者やマネージャーなどもこのタイトルとコメントを見ることになるので、なるべくわかりやすく書きましょう!
入力ができたら、 Create pull request をクリックしてプルリクエストの作成は以上となります。
プルリクエストをマージ
実務では、プルリクエストの作成したら、マネージャーなどに実装内容を見てもらい、マージしてもらいますが今回は自分でやっていきます。
まずは、メニューバーの Pull requests をクリックすると、現在のプルリクエストが一覧で確認することができます。
一覧の中から、今回作成したマージしたいプルリクエストをクリックしてください。
その中の Merge pull request をクリックすると、 Confirm merge というボタンが新しく出てくるので、そのボタンをクリックするとリモートブランチのmasterブランチにマージされます。
さいごに
いかがだったでしょうか。
他にもいろいろな記事を書いているのでぜひ読んでいただけたら嬉しいです。