はじめましてこんにちは、今年新卒でKRAYに入社しました亀井と申します。
会社のみなさんからは「あさちゅん」と呼ばれております。どうぞよろしくお願いします。
突然ですが、みなさん使ってますか? Git。
KRAYではバリバリ活躍してるGitですが、
「よくわからない……」と頭を抱えてる方も多いですね。
わたしも抱えてます。
正直、KRAYに入社するまでターミナルを使ったことすらなく、
Gitも入社してから使いだしたので初心者もいいところです。
そんなわたしが1日約200回×3ヶ月ターミナルでGitコマンドを打ち続けて
やっとわかってきた、Gitの「これなんで?」を解説します。
主にGit初心者、Gitについて理解を深めたい人向けです。
もくじ
なんでcommitする前にaddしなきゃいけないの?
Gitの操作の基本中の基本、変更したファイルを「addしてcommit」。
「なんでわざわざaddするの??直接commitしたらいいじゃん」
と思いますよね。
わたしも思いました。
「Gitがそういう仕組みになってるから」と言ってしまえばそれまでなんですが……
じゃあなんのためにその仕組みがあって何に役立つっていうのよ!ムキー!
いえいえ、役に立つんですよ、add。
どこに役立つかって?というのをこれから説明していきたいと思います。
その前に説明しておきたいのが、
まず、Gitにはファイルの状態を保存する場所がいくつかあります。
「ワーキングツリー」「インデックス」「ローカルリポジトリ」「リモートリポジトリ」
なんじゃらほい??てかんじですね。
図にするとこんなかんじ。
ここで「ん?」と思うのが「インデックス」。
コミットするためのファイルを登録…って、
こんなものなくても、ワーキングツリーのものを直接
ローカルリポジトリにcommitしたらいいんじゃないのかなあ……?
いえいえ、これが案外必要になってくるのです。
例えば、
コミットメッセージって、ひとつのコミットにひとつだけしかつけられません。
コミットするファイルがひとつだけならいいけど、たくさんのファイルを
一度にコミットしなければいけないときはままあります。
それをaddなしでcommitしようとすると……
git diff
で変更した部分を確認、
「えーと、aaa.htmlと、bbb.htmlと、とddd.htmlと……」
git commit aaa.html bbb.html ccc.html ddd.html -m "change files"
( aaa.html、bbb.html、ccc.html、ddd.htmlが”change files”としてコミットされました)
「そういえばまだ追加するファイルあったっけ……?」
git diff
「あ!eee.htmlとfff.html入れ忘れとる!!!」
なんてことが起こりやすくなってしまうのです。
全部きっちりdiffで確認してから、たくさんのファイルを一度にcommitするのは
なかなか骨が折れる作業です。。
(あとから修正もできますが、めんどくさいですよね)
その点、addという作業を挟むと…
git add aaa.html bbb.html ccc.html ddd.html
「念のためもっかいdiff見るか」
git diff
「おっと、eee.htmlとfff.html入れるの忘れてた、addaddっと」
git add eee.html fff.html
(これでインデックスにaaa.html、bbb.html、ccc.html、ddd.html、eee.html、fff.htmlが登録されました)
よしcommitするファイルが揃った、commit!
git commit -m "change files"
addでインデックスに登録したファイルが”change files”としてコミットされました!
こんなぐあいに、addがあれば、
「インデックス」という「ひとまとめにしてコミットしたいファイルをとりあえず置いておくところ」
に好きな単位で置いておくことができるのです。
そして、
「別に今回はコミットするファイル1つだけだし、やっぱりaddをすっとばしたい」
という場合は
git commit -a aaa.html
というふうに、-a オプションをつけてcommitしましょう。
addとcommitを同時にしてくれます。
ブランチってなんのために分けるの?
「ブランチ、なんか違う作業をしたいときに分けるって聞いたけど……
それってなんかメリットあるの?」
ありますよ〜〜!!!
たとえば、あなたはある日
「イラストを載せるサイトを作りたい!」と思い立ったとしましょう。
(例えなんで実際はどんな内容でもいいです)
どうせならGitで管理しよう!と思い立ち、ローカルリポジトリを作成しました。
git init
これであなたはGit管理をしつつ、サイトを作る作業を始められました。
実は、この時点ですでに「master」というブランチで
作業していることになるのです。
(git status すると、
# On branch master
と、「あなたは今masterブランチにいますよ」
と教えてくれます。)
話は戻り、作業を終えめでたくイラストサイトを開設。
運営を始めてあなたは思いました。
「うーん、イラストを描くたびにhtml作って更新するのはめんどくさいなあ、
よし、ブラウザでイラストをアップロードできる仕組みを作ろう!」
「でも、今のmasterブランチをいじって変になったら戻すのめんどくさいなあ……」
そんなときにブランチを切ると幸せになれます!
(前置きが長くてごめんなさい)
例えば、ここからブランチを切って作業すると、今までのmasterブランチは何の影響も受けずに、
masterブランチのコミットを受け継ぎつつ、uploaderブランチで新しい機能を追加する作業ができるのです。
※この図は、正確には「uploaderブランチを作ってひとつコミットを積んだ状態」です。
このmasterブランチとuploaderブランチは、
ブランチを操作するコマンドを使わない限りお互い干渉することはありません。
ある程度作業したファイルを「別名で保存」してから
片方だけファイルをいじる感覚が近いでしょうか。
そして新しい機能が出来上がって、ちゃんと動くことを確認した時点で
uploaderブランチをmasterブランチにマージすればいいのです。
(マージとは、別のブランチの作業を今いるブランチに取り込む作業です。)
git checkout master #ブランチを移動
git merge uploader #masterブランチにuploaderブランチを取り込む
これで新しい機能を安全にmasterブランチにマージすることができました!
ブランチを切れば新しい機能を追加するのも安心してできますね。
HEADってなんなの?
HEAD。よく聞きますね。
わたしこれがなんなのか理解するのにかなりの時間を要しました。
HEADは「今いるブランチの最新のコミット」の代名詞です。
たとえば、「最後にやったコミットの内容ってどんな内容だったっけ?」
と思ったとき。
たとえばこんなコミットログがあったとします。
※やたら長い数字とアルファベットがランダムに並んだ文字列はコミットのハッシュ値です。
そのコミットのidになります。
ここで「最後にやったコミット(=最新のコミット)ってどうなってたっけ?」
と思ったとき。
git show というコマンドを使うのですが、
HEADという概念が存在しない場合
git show 51ad5fac23ab6dba54a2ca3ac37fcc4dda0e513d
※コミットのハッシュ値を指定する
「最後の1つ前のコミットが見たい」場合も
git show 277d9ba7810f182f8dc0586eb30daf07fca28d05
このようにコミットのハッシュ値を指定します。
いちいち git log などで参照してハッシュ値を控えておかなければならないので、
非常にめんどくさいです。
ここでHEADがあると……!?
git show HEAD
これで最後にコミットした内容が見れます。たった4文字「HEAD」と指定するだけ。
非常に便利。
ちなみに、「最後のひとつ前のコミット」を見たいときは
git show HEAD^
「最後のふたつ前のコミット」を見たいときは
git show HEAD^^
ちなみにこれは
git show HEAD~2
とも書き換えられます。
ファーーーー!!!ってなりますね。
図にするとこうです!!
以降はコミットが増えるたびに ^ 、~ の場合は数字が増えていきます。
(何個も前のコミットの場合は直接ハッシュを指定したほうが簡単ですが……)
(ちなみに、git log -pを使うと
ハッシュ値やHEADの位置指定なしでもコミットの詳細を見ることができます。
git log -pの場合そのブランチのコミットログがすべて出てくるので
とりあえず一覧で詳細も見たいときはgit log -p、コミットひとつだけ見たい場合は
git showと使い分けるといいと思います。)
ちなみに、「今いるブランチの最新コミットだから、HEAD」ではなく
HEADが今いるブランチを決めています。
git checkout ブランチA を使うとHEADがブランチAの最新コミットに移動するので、
今いるブランチが変わるわけです。
HEADすごい。
消したファイルもcommitしなきゃいけないってどうして?
これ、どういうことなのかというと、
Git管理下のファイルは、「消した」こともちゃんと明示しなければならないのです。
Gitは、Git管理下に置かれたファイルを常にくまなく監視していますが、
ファイルを消したからといってそれを自動的に消す処理をしてくれるわけではありません。
特に複数人で作業している場合は、ちゃんと消したことをcommitしてpushしないと
自分のリポジトリでは「消した」前提で諸々の作業が進んでいるのに、
他のメンバーのローカルリポジトリにはその消したファイルが残っていることになってしまい
うまくマージできずチームメンバーに迷惑がかかってしまいます。
(私は一度これをやらかしました……)
私はとくに深い理由もなく
「消したとかだったら別にpushしなくてもいいよね〜」と考えていました。
恥。。。。
しかもGitの場合、ファイルを消したことをコミットする操作にちょっと癖があります。
なんと普通にaddしただけではインデックスに登録できないのです!
それではどうやってGitに「消した」ことを登録するのかというと、
git rm を使います。
たとえば「nya.html」というファイルを消した場合、
git rm nya.html
このコマンドを打ってから git status すると、
deleted: nya.html
という状態でインデックスに登録されていると思います。
ここまできたら、あとはふつうに git commit するだけです!
わたしも最初は「エッaddするんじゃだめなの」と思いましたが、
そういうものらしいです。
【追記】
git add -u で消したファイルもaddできます。
(-u オプションは変更があったファイルのみステージングするオプションです。ちなみに -u オプションでは新しく作ったファイル (untracked file) はaddされません。)
おわりに
わたしもGit初心者なので、
初心者なりに理解したGitの疑問について説明させていただきましたがいかがでしょうか?
まだまだ未熟者なのでこれからも精進していきたいと思います。
宣伝
クレイでは情報共有サービスDocBase を開発しています。
- 最大10人までの同時編集に対応!
- 細かい権限設定でオープンな情報もクローズドな情報もDocBaseに一本化
- SSO、2段階認証、IPアドレス制限に対応。ISMSも取得しており、セキュリティには力を入れています!
チームを作成して30日間は無料ですべての機能が使えるので、ぜひチームを作成して試してみてください。
このエントリーに対するコメント
-
参考になりました!
内容と直接関係ありませんが、目次に各セクションへのリンクがあると読みやすくなるのではと思いました。それと各セクションの末尾に「目次へ戻る」のリンクもあるとなおいいかなと。
他の記事も楽しみにしています!2013年09月16日, 12:19 AM
-
各セクションへのリンクと目次へ戻るリンクを足しました。
ご指摘ありがとうございます!
次の記事もご期待に添えるようにがんばります。2013年09月17日, 11:17 AM
-
> なんと普通にaddしただけではインデックスに登録できないのです!
git add -u で消したファイルもaddされますよー
ちなみに-uだと新しくつくったファイル(untracked file)は
addされないのでご注意を。2013年11月06日, 1:03 PM
-
> ktns さん
ご指摘ありがとうございます!
本文に追記しました。2013年11月07日, 8:13 PM
日本語が含まれない投稿は無視されますのでご注意ください。(スパム対策)
- トラックバック
-
- 2013/9/4のホットエントリー | 話題のニュースまとめ2013/09/04, 7:10 PM
[…] 64category: テクノロジーGit初心者に捧ぐ!Gitの「これなんで?」を解説します。 | KRAY Incはじめましてこんにちは、今年新卒でKRAYに入社しました亀井と申します。 […]
-
- 2013/09/04のWeb情報クロール | Web情報クロール2013/09/04, 8:52 PM
[…] Git初心者に捧ぐ!Gitの「これなんで?」を解説します。 https://kray.jp/blog/git-why-explanation/ […]
-
- ツカエル!ネットの話題 » Blog Archive » 09月05日 05:00版2013/09/05, 5:02 AM
[…] Git初心者に捧ぐ!Gitの「これなんで?」を解説します。 | KRAY Inc […]
-
- リモートリポジトリの置いてあるサーバ上にローカルリポジトリを設置して、作業ツリーをWebに公開する | HugKey.com2013/11/18, 6:29 PM
[…] こちらのページが非常に参考になりました。 Git初心者に捧ぐ!Gitの「これなんで?」を解説します。 カテゴリー: Web | タグ: git, linux | 投稿日: 2013年11月18日 | 投稿者: eggmobile […]
-
- 「GitLab」バージョン管理のススメ その6 | WordPressプラグイン 役立つ情報 - luna plate2014/02/09, 5:33 PM
[…] Git初心者に捧ぐ!Gitの「これなんで?」を解説します。 by KRAY […]
-
- Git入門(GitBucket と SourceTree の準備) | セルティスラボ2014/05/20, 5:07 PM
[…] Git初心者に捧ぐ!Gitの「これなんで?」を解説します […]
-
- Git/GitHub | blog.coluli.net2014/07/17, 11:40 AM
[…] Git初心者に捧ぐ!Gitの「これなんで?」を解説します。 | KRAY Inc 各種用語/用法の技術的な意味について。 […]
-
- 【Git編】テックキャンプエキスパートで教えてくれなかったこと | とむじそブログ2017/10/14, 2:28 AM
[…] Git初心者に捧ぐ!Gitの「これなんで?」を解説します https://kray.jp/blog/git-why-explanation/ […]
-
- Git再学習 | IT技術情報局2018/04/10, 12:51 AM
[…] 参考: Git初心者に捧ぐ!Gitの「これなんで?」を解説します。 https://kray.jp/blog/git-why-explanation/ […]
-
- Gitでつまづきまくったので、スイスイできる方法と情報をまとめた | がいがーの工具箱2018/04/23, 6:06 AM
[…] Git初心者に捧ぐ!Gitの「これなんで?」を解説します。 […]
「いいね!」で応援よろしくお願いします!