Content-Length: 303587 | pFad | http://www.slideshare.net/DQNEO/git-yapcasia2013

やさしいGitの内部構造 - yapcasia2013 | PPT
SlideShare a Scribd company logo
やさしい
Gitの内部構造
YAPC::Asia2013
@DQNEO
@DQNEO
自己紹介
• PHPプログラマ
• CPAN Author (いちおう)
やさしいGitの内部構造 - yapcasia2013
オープンソース作品
https://github.com/DQNEO/S3ParallelUploader
https://github.com/DQNEO/ethnam
https://github.com/DQNEO/Amazon-S3-FastUploader
Java: S3ParallelUploader
Perl: Amazon::S3::FastUploader
PHP: Ethnam
ブログ
はじめに
※本プレゼンはわかりやすさを優先
したため、一部記述の厳密性を犠牲
にしております。
ご了承ください。m(__)m
本日のゴール
• コミットの中身を知る
• ブランチの正体を知る
• ポインタと連想配列
• オブジェクトグラフを理解する
きっかけ
Git使って
ますか?
• 毎日使ってる
• たまに使う
• 使ったことない
• 他のVCSがメイン
コミットとは
動詞:「コミットする」
名詞:「コミット」
二つの意味
「コミットする」
実際の挙動は
どうなってるの?
Q. “git commit”により作
成されるものは?
1. 差分
2. スナップショット
正解
1. 差分
2. スナップショット
間違えても
気にしないで!
「コミットする」
スナップショットを保存す
ること
=
スナップ
ショット
コミット
オブジェクト
db23d002c336f1ed408c2ef82b7ccb6a33c9f24cハッシュ値
名詞としての「コミット」
=スナップショット
へのポインタ
コミットオブジェクト
=
コミットハッシュ値が指し示すもの
=
Q. 1億行のファイルを
コミットしたときの
コミットオブジェクトの
サイズは?
1. でかい(1MB以上)
2. 小さい(1KB未満)
1億?
100,000,000
やさしいGitの内部構造 - yapcasia2013
やさしいGitの内部構造 - yapcasia2013
git checkout -
Q. 1億行のファイルを
コミットしたときの
コミットオブジェクトの
サイズは?
1. でかい(1MB以上)
2. 小さい(1KB未満)
1. でかい
2. 小さい
正解
コミット1
コミットオブジェクトのサイズは、
コンテンツのサイズによらずほぼ一定
コミット2
コミット
オブジェクト
スナップ
ショット
Gitを理解する鍵
「ポインタ」
※C言語のポインタとは関係ないよ
単に「参照」「指し示す」
くらいの意味
スナップ
ショット
コミット
オブジェクト
db23d002c336f1ed408c2ef82b7ccb6a33c9f24c
コミット
ハッシュ値
指し示す
指し示す
コミットオブジェクトの
中身を見てみよう
コミットオブジェクト
あああ
$ git cat-file -p 6e3c7a7
たったのこれだけ。
メタ情報しかない。
tree b2ba084f61385d9560daa1b43a98014c27620cee
parent 365d440b4c1ab31703ccbb7e2a9980d49cf8ebf6
parent 93f2ceeb0f0608f3754d379dcc473297ad1f0f43
author Tatsuhiko Miyagawa <miyagawa@xxxx.net>
committer Tatsuhiko Miyagawa <miyagawa@xxxx.net>
Merge pull request #430 from kazeburo/master
← コミットハッシュ値を指定
$ git cat-file -p 6e3c7a7
tree: スナップショットへのポインタ
← コミットオブジェクトの中身を表示
parent: 親コミットへのポインタ
コミットオブジェクト
tree b2ba084f61385d9560daa1b43a98014c27620cee
parent 365d440b4c1ab31703ccbb7e2a9980d49cf8ebf6
parent 93f2ceeb0f0608f3754d379dcc473297ad1f0f43
author Tatsuhiko Miyagawa <miyagawa@xxxx.net>
committer Tatsuhiko Miyagawa <miyagawa@xxxx.net>
Merge pull request #430 from kazeburo/master
親 子
A B
コミットオブジェクト
は、
親コミットへのポインタ
を持っている
親 子
A C
孫
B
ポインタを先祖へた
どっていくと
履歴がわかる
Q. 1億行のテキスト
ファイルに、1行追記し
てコミットすると、レポ
ジトリ容量はどのくらい
増える?
1. 1行分増える
2. 1億1行分増える
正解
1. 1行分増える
2. 1億1行分増える
コミット1
のスナップショット
レポジトリ内では、
別個のオブジェクトとして共存
コミット2
のスナップショット
1億行 1億1行
コミット1
のスナップショット
“git log –p”や”git show”で見れる差分
は、
あくまで計算による導出物であるコミット2
のスナップショット
差分
スナップショット
の構造
ルート
README.md
META.json
Tree Object
Blob Object (コンテンツ)
(Plackの例)
lib
scripts
HTTP Message PSGI.pm
plackup
ポインタの連鎖による階層構造
$ git ls-tree HEAD
100644 blob ba2434a0ebdb210e048f2e688652436569e4ffdc .gitignore
100644 blob e6bb679f9e41bc960f72b08b66c6ed46d4c90d4c .mailmap
100644 blob 5533888a0be3813e787cf17c60587fe313c6c23d .travis.yml
100644 blob 362d01e6f7b18e450f0a62187554e64c84f5cb10 Changes
100644 blob 0e07fb7a9173428f3b0f58035a781687bef06542 LICENSE
100644 blob 717d88241a49c58e4d811b555abdc9987a202e3c META.json
100644 blob 5d4062017fb9fe2631691b36a5167ad1d33bb79e Makefile.PL
100644 blob df73cecb9a6771392f8ffb4bbf46ad1057953338 README.md
040000 tree 17d81860c97909ce36c3a7bcd2ea2d89706e4cd1 benchmarks
100644 blob 9dca1adad84d3d4e57e297c2b4f57eaa0a54e3db cpanfile
100644 blob b1835cef488b7ad7cdee62882c4325851ce0404c dist.ini
040000 tree 16c9b6ece58b6028c10f0d983de5781c0cabb964 eg
040000 tree 206a4bef7128a678a020126744b058cbbea6bcac lib
040000 tree 359858f5219cd2e5f5171012e1b8f5f0da684301 script
040000 tree 38100c96e5798b5a513f95b36b85af38a377d5d9 share
040000 tree 8af8046f440af59731f8e93b48d62228ecfb8d83 t
040000 tree d2d27ab4124b7cf8194282c7493001543850bd0f xt
ツリーオブジェクトの中身
タグとは
タグのない世界
Plackの
8c461ae102afbcbbe279bffb171244b710650da1
の件なんだけどさー
えっ?
タグのない世界
だから、Plackのコミット
8c461ae102afbcbbe279bffb171244b710650da1
の話なんだけどさー
えっ?
それなんだっけ?
えっ?
馬鹿なの?
死ぬの?
タグのない世界
コミットハッシュ値と
か
覚えてないんだけど
タグのある世界
( ・ω・)
_ _ つ/ ̄ ̄ ̄/
\/___/ ̄
 ̄
Miyagawa氏
git tag 1.0000 8c461ae
Plackの”1.0000”
の件なんだけどさー
あー、はいはい
タグのある世界
git show 1.0000 git show 8c461ae=
等価
タグ 1.0000 コミット 8c461ae=
等価
タグとは
コミットオブジェクト
に付けられた
別名のこと
ブランチとは
枝じゃない!!
Gitに
枝という概念はな
い。
たぶんないはず。
ブランチも
コミットオブジェクトの
別名。
親
A
branchX
親 子
A B
branchX
コミットすると参照先が
勝手に移動
親 子
A C
孫
B
branchX
Like “だるまさんがころんだ”
ブランチの正体
$ cat .git/refs/heads/master
6e3c7a777a7231ff9bbce276e675b16f43287bef
コミットハッシュ値を格納した単なるファイル
コミットオブジェクトへのポインタ
ブランチは
コミットオブジェクトの
別名
git show master git show 8c461ae=
等価
git log master git log 8c461ae=
等価
アレで
たとえる
家康
将軍
家康 秀忠
将軍
家康 秀忠 家光
将軍
ブランチ ! = 徳川家
家康 秀忠 家光
将軍
タグ
東照大権現
ブランチ
• 差分ではなくスナップショット
• コミットオブジェクトは、スナッ
プショットへのポインタ
• タグはコミットオブジェクトへの
ポインタ
• ブランチもコミットへのポインタ
• Gitのデータ構造はポインタの連鎖
= オブジェクトグラフ
まとめ
内部構造を知っていれば色々捗る
つまり
やさしいGitの内部構造 - yapcasia2013
ご清聴
ありがとう
ございました
質問を
どうぞ!

More Related Content

やさしいGitの内部構造 - yapcasia2013









ApplySandwichStrip

pFad - (p)hone/(F)rame/(a)nonymizer/(d)eclutterfier!      Saves Data!


--- a PPN by Garber Painting Akron. With Image Size Reduction included!

Fetched URL: http://www.slideshare.net/DQNEO/git-yapcasia2013

Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy