Successfully reported this slideshow.
Your SlideShare is downloading. ×

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

Ad
Ad
Ad
Ad
Ad
Ad
Ad
Ad
Ad
Ad
Ad
Upcoming SlideShare
こわくない Git
こわくない Git
Loading in …3
×

Check these out next

1 of 68 Ad

More Related Content

Slideshows for you (20)

Similar to やさしいGitの内部構造 - yapcasia2013 (20)

Advertisement

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

  1. 1. やさしい Gitの内部構造 YAPC::Asia2013 @DQNEO
  2. 2. @DQNEO 自己紹介 • PHPプログラマ • CPAN Author (いちおう)
  3. 3. オープンソース作品 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
  4. 4. ブログ
  5. 5. はじめに ※本プレゼンはわかりやすさを優先 したため、一部記述の厳密性を犠牲 にしております。 ご了承ください。m(__)m
  6. 6. 本日のゴール • コミットの中身を知る • ブランチの正体を知る • ポインタと連想配列 • オブジェクトグラフを理解する
  7. 7. きっかけ
  8. 8. Git使って ますか?
  9. 9. • 毎日使ってる • たまに使う • 使ったことない • 他のVCSがメイン
  10. 10. コミットとは
  11. 11. 動詞:「コミットする」 名詞:「コミット」 二つの意味
  12. 12. 「コミットする」 実際の挙動は どうなってるの?
  13. 13. Q. “git commit”により作 成されるものは? 1. 差分 2. スナップショット
  14. 14. 正解 1. 差分 2. スナップショット
  15. 15. 間違えても 気にしないで!
  16. 16. 「コミットする」 スナップショットを保存す ること =
  17. 17. スナップ ショット コミット オブジェクト db23d002c336f1ed408c2ef82b7ccb6a33c9f24cハッシュ値
  18. 18. 名詞としての「コミット」 =スナップショット へのポインタ コミットオブジェクト = コミットハッシュ値が指し示すもの =
  19. 19. Q. 1億行のファイルを コミットしたときの コミットオブジェクトの サイズは? 1. でかい(1MB以上) 2. 小さい(1KB未満)
  20. 20. 1億?
  21. 21. 100,000,000
  22. 22. git checkout -
  23. 23. Q. 1億行のファイルを コミットしたときの コミットオブジェクトの サイズは? 1. でかい(1MB以上) 2. 小さい(1KB未満)
  24. 24. 1. でかい 2. 小さい 正解
  25. 25. コミット1 コミットオブジェクトのサイズは、 コンテンツのサイズによらずほぼ一定 コミット2 コミット オブジェクト スナップ ショット
  26. 26. Gitを理解する鍵 「ポインタ」 ※C言語のポインタとは関係ないよ 単に「参照」「指し示す」 くらいの意味
  27. 27. スナップ ショット コミット オブジェクト db23d002c336f1ed408c2ef82b7ccb6a33c9f24c コミット ハッシュ値 指し示す 指し示す
  28. 28. コミットオブジェクトの 中身を見てみよう
  29. 29. コミットオブジェクト あああ $ 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 ← コミットハッシュ値を指定
  30. 30. $ 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
  31. 31. 親 子 A B コミットオブジェクト は、 親コミットへのポインタ を持っている
  32. 32. 親 子 A C 孫 B ポインタを先祖へた どっていくと 履歴がわかる
  33. 33. Q. 1億行のテキスト ファイルに、1行追記し てコミットすると、レポ ジトリ容量はどのくらい 増える? 1. 1行分増える 2. 1億1行分増える
  34. 34. 正解 1. 1行分増える 2. 1億1行分増える
  35. 35. コミット1 のスナップショット レポジトリ内では、 別個のオブジェクトとして共存 コミット2 のスナップショット 1億行 1億1行
  36. 36. コミット1 のスナップショット “git log –p”や”git show”で見れる差分 は、 あくまで計算による導出物であるコミット2 のスナップショット 差分
  37. 37. スナップショット の構造
  38. 38. ルート README.md META.json Tree Object Blob Object (コンテンツ) (Plackの例) lib scripts HTTP Message PSGI.pm plackup ポインタの連鎖による階層構造
  39. 39. $ 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 ツリーオブジェクトの中身
  40. 40. タグとは
  41. 41. タグのない世界 Plackの 8c461ae102afbcbbe279bffb171244b710650da1 の件なんだけどさー えっ?
  42. 42. タグのない世界 だから、Plackのコミット 8c461ae102afbcbbe279bffb171244b710650da1 の話なんだけどさー えっ? それなんだっけ?
  43. 43. えっ? 馬鹿なの? 死ぬの? タグのない世界 コミットハッシュ値と か 覚えてないんだけど
  44. 44. タグのある世界 ( ・ω・) _ _ つ/ ̄ ̄ ̄/ \/___/ ̄  ̄ Miyagawa氏 git tag 1.0000 8c461ae Plackの”1.0000” の件なんだけどさー あー、はいはい
  45. 45. タグのある世界 git show 1.0000 git show 8c461ae= 等価 タグ 1.0000 コミット 8c461ae= 等価
  46. 46. タグとは コミットオブジェクト に付けられた 別名のこと
  47. 47. ブランチとは
  48. 48. 枝じゃない!!
  49. 49. Gitに 枝という概念はな い。 たぶんないはず。
  50. 50. ブランチも コミットオブジェクトの 別名。
  51. 51. 親 A branchX
  52. 52. 親 子 A B branchX コミットすると参照先が 勝手に移動
  53. 53. 親 子 A C 孫 B branchX Like “だるまさんがころんだ”
  54. 54. ブランチの正体 $ cat .git/refs/heads/master 6e3c7a777a7231ff9bbce276e675b16f43287bef コミットハッシュ値を格納した単なるファイル コミットオブジェクトへのポインタ
  55. 55. ブランチは コミットオブジェクトの 別名 git show master git show 8c461ae= 等価 git log master git log 8c461ae= 等価
  56. 56. アレで たとえる
  57. 57. 家康 将軍
  58. 58. 家康 秀忠 将軍
  59. 59. 家康 秀忠 家光 将軍 ブランチ ! = 徳川家
  60. 60. 家康 秀忠 家光 将軍 タグ 東照大権現 ブランチ
  61. 61. • 差分ではなくスナップショット • コミットオブジェクトは、スナッ プショットへのポインタ • タグはコミットオブジェクトへの ポインタ • ブランチもコミットへのポインタ • Gitのデータ構造はポインタの連鎖 = オブジェクトグラフ まとめ
  62. 62. 内部構造を知っていれば色々捗る つまり
  63. 63. ご清聴 ありがとう ございました
  64. 64. 質問を どうぞ!

×