Git初心者がクラスメイトに使い方を講義してみる

  • 48
    いいね
  • 0
    コメント
この記事は最終更新日から1年以上が経過しています。

はじめに

このドキュメントを書いている私が自身がGit初心者であるため、間違っている点があるかと思いますのでご了承お願い致します。

講義内容

  1. Gitってなんぞ
  2. 用語説明
  3. とりあえずローカルで使ってみる
  4. 複数人で使ってみる
  5. ホスティングサービス紹介
  6. 最後に

1. Gitってなんぞ

最近注目のバージョン管理システムです。
バージョン管理システムと言えば「Subversion」や「CVS」が有名ですがどう違うのかをあわせて見て行きましょう。

ソースコードのバージョン管理

バージョン管理システムという名前からわかる通り、
Gitを使うことでソースコードのバージョンを管理することができます。
また、変更の履歴の確認などを簡単に確認することができます。

バージョン管理なら、プロジェクトのフォルダをコピーしておけばできるじゃん!

と思われた方もいるかもしれません。
ですが、この方法では、変更していないファイルもバックアップしてしまい、HDの容量圧迫に繋がってしまします。
GtやSubversion等のバージョン管理システムは、前回からの変更点のみを保存するので無駄なバックアップを減らすことができます。

複数人でのソースコード共有

バージョン管理システムでは、ソースコードを管理できる他にも、
複数人でソースコードを共有できるというメリットもあります。

複数人で作業をしてると、自分の変更をチームメンバーに渡したい事があると思います。
そんな時に、USBメモリーやメッセンジャー等でやり取りをしていると作業に無駄が出てしまいますよね?
Gitを使えばその手間を減らすことができるのです。

分散型バージョン管理システム

Subversion等のシステムは集中型バージョン管理システムを採用していますが、
Gitでは分散型バージョン管理システムを採用しています。

集中型とは、リポジトリと呼ばれる「変更データを保存しておく領域」が1つで、
開発者全員が同じリポジトリを参照して作業をします。

分散型では開発者全員が参照できるリポジトリの他に、開発者一人ひとりが専用リポジトリを持っていて、
必要になったら大本のリポジトリに変更を反映させたり、変更を取得したりできます。

2. 用語説明

リポジトリ( repository )

コードの差分を保存しておく領域

--

ステージ( stage )

次回のコミットで含めるという宣言のこと。


コミット( commit )

ステージされた変更をリポジトリに反映させること。


プッシュ( push )

コミットをリモートリポジトリに反映させること。
プッシュしていないコミットはリモートリポジトリには反映されていないので注意してください。


プル( pull )

リモートリポジトリから変更を取得すること。


マージ( marge )

変更データを現在のデータと合わせること。
変更が競合した場合など手動で行うこともあります。


クローン( clone )

リモートリポジトリから、リポジトリをローカルに取得すること。

3. とりあえずローカルで使ってみる

今回使用するもの

TortoiseGit
mysysgit

1. まずはリポジトリを作ってみる

C:\Users\ユーザ名\Documents\Git\hogeというフォルダで作業をしていきます。
フォルダがない場合は新規作成から作ってください。

リポジトリの作成は簡単です。
フォルダ内で右クリックを押し Git Create repository here… をクリックします。
右クリックメニュー

以下の様なウィンドウが開きますがそのまま OK をクリックします
bare init

Gitリポジトリを作りました的なダイアログが出るので OK をクリック
finish

これでリポジトリの作成が終わりました。

2. ファイルを追加してステージする

次は、テキストファイルを作成してステージしてみます。
私は Hoge.txt というファイルの中に、

Hoge.txt
hogehoge
hogehogehoge

と書き込み保存しました。

それでは、ステージしてみましょう。
フォルダ内の適当な場所を右クリックして、TortoiseGit > Add を選択します

add

すると、ウィンドウが出てくるので Select/deselect all にチェックを入れて OK をクリックします。

add select

ステージ完了のダイアログが出てくるので OK を押して閉じましょう。

add finish

これで Hoge.txt をステージすることができました。

3. ステージしたファイルをコミットする

次はコミットです。

フォルダ内の適当な場所で右クリックして Git Commit -> "master"… を選択します
commit

なんか出て来ました。
profile

自分の名前を登録しいなかったので、文句を言われてます。
仕方ないので、Yesをおして登録してあげましょう

User InfoのName,Emailを入力(今回は適当でもいい)してOKを押します。

Setting

OKを押すと、コミット画面が出現します。
Messageにどんな変更をしたコミットなのかの説明を書きます。
Set commit dateと、Set authorにはチェックを入れておくといいかも。

commit edit

メッセージの入力が終わったら、OKボタンを押します。
以下の様なダイアログが出現し、 Success というメッセージが出たらコミット完了です。
closeを押すとダイアログが消えます。

commit finish

4. ログを確認する

最後に、きちんとコミットできているか、ログを確認してみましょう。

フォルダ内の適当な場所で右クリックして TortoiseGit > Show log を選択します。

showlog

すると、 以下の様な画面が出てきます。
先ほどのコミットのログがあればコミット成功の証です。

showlog window

こんな感じの作業を繰り返して開発することで、バージョン管理を行う事ができます。

4. 複数人で使ってみる

1人で制作する場合は先程のやり方で良いのですが、複数人で作業を行う場合追加でやらなければいけないことがありますので、順を追って見て行きましょう。

その前に、どうやって複数人で使うのかを見てみましょう。
共通のリポジトリを1つ作成して、そこに個人がPushして変更を反映させ、Pullで変更を取得していきます。

今回は、GitHubというサービスを使用して擬似的に複数人での開発を再現しようと思います。

以下のURLが今回使用するリポジトリのURLです。
GitHub: School

1. GitHubからリポジトリをクローンする

今回はリポジトリを作成するのではなく、既存のリポジトリをローカルにコピーして使います。

先ほどの Git フォルダ内の適当な場所を右クリックして Git Clone… を選択します。
git clone

URL欄に https://github.com/rytmrt/school.git を入力します。
Load Putty Keyは今回は使用しないので、チェックを外しておきます。
必要項目が終わったら、OKを押します。

clone

この画面が出たらクローン終了です。

2. 変更をGitHubに反映する

gt200.txt というファイルを作成し、コミットします。(00は自分の出席番号)
コミットが終了すると以下の様な画面が出てくるので、Pushを選択します。

Push start

この画面が出たら、そのまま OK をクリックしましょう。

push

ユーザー名とパスワードを聞かれるので、
User: tsit-game
Pass: trident53
と入力してください。
(本来は各個人のGitHubアカウントを使用するべきなのですが、
個人のアカウントをすべて登録しているほど時間に余裕が無いため共用のアカウントを作成しました。)

この画面が出るとPush完了です。

push end

3. GitHubから変更を取得する

フォルダの適当な場所で、右クリックして TortoiseGit > Pull… を選択します。

pull

次に、Pullする場所を選択します。今回はCloneしたリポジトリから取得するので、origindのままでOKです。
AutoLoad Putty Key は使用しないので、チェックを外しておきましょう。
準備ができたら OK ボタンをクリックします。

URL Select

以下の画面が出たら、Pull完了です。

pull fin

5. ホスティングサービス紹介

GitHub

超有名なGitホスティングサイト
無料アカウントでは公開リポジトリしか作成できないが、
有料アカウントであれば非公開のリポジトリを作成可能。

オープンソースなプロジェクトを管理するのに最適かも?

BitBucket

もともとはGit用ではなかったが、Gitにも対応したホスティングサイト
無料アカウントでも、非公開リポジトリの作成が可能なのが特徴

5Userまでなら無料らしいので公開したくないものを扱う場合はこっちのほうがいいかも?

その他にもホスティングサイトをはいっぱいあるので、気になる人は調べてください。

6. 最後に

バージョン管理システムを使う上で重要なこと

「ひとつのコミットには、その主題となる変更と無関係な変更を含めない」

-

参考URL

ステージを理解して git をもっと便利に使う
Gitが使えるホスティングサービスまとめ
イラストでわかる!git入門の入門