Upgrade to Pro — share decks privately, control downloads, hide ads and more …

ブロックチェーン概論 / Introduction to Blockchain

ブロックチェーン概論 / Introduction to Blockchain

慶應義塾大学大学院メディアデザイン研究科「サービスデザインプロジェクトB」2024秋 第1回にて使用したスライドです。

Kenji Saito

October 05, 2024
Tweet

More Decks by Kenji Saito

Other Decks in Technology

Transcript

  1. Generated by Stable Diffusion XL v1.0 B 2024 1 (

    ) B 2024 — 1 — 2024-10-07 – p.1/68
  2. https://speakerdeck.com/ks91 ( ) ( ) Discord Discord ( / /

    ) Zoom URL ( ) B 2024 — 1 — 2024-10-07 – p.2/68
  3. ( ) ( ) CSO (Chief Science Officer) 1993 (

    ) 2006 ( ) SFC 24 P2P (Peer-to-Peer) 2011 ( ) 2018 2019 VR 2021.9 & VR 2022.3 2023 AI VR&RPG 2023.5 “Don’t Be So Serious” 2023 2024 AI( ) 2024 “ALOHA FROM HAWAII” 2024 2024 AI( ) → ( ) B 2024 — 1 — 2024-10-07 – p.3/68
  4. SAY NO TO BULLSHIT JOBS David Graeber, Bullshit Jobs: A

    Theory, Penguin, 2018. ( , , , — , , 2020) Bullshit Jobs ( ) Shit Jobs ( ) ( ) . . . B 2024 — 1 — 2024-10-07 – p.6/68
  5. Alexa, ত࿨࣌୅ ੈلޙ൒ ࣾձγεςϜ ࣾձ؀ڥ ػց ٕज़ ਓؒ ࣗಈγεςϜ ྩ࿨࣌୅

    ੈلલ൒ ిؾ͚ͭͯ ͸͍ ͸͍ ిؾ͚ͭͯ ͜ͷ৚݅ͷͱ͖ ٕज़Ͱ͋Γࣾձ؀ڥˠࣗવ؀ڥ ਓ ⇒ ( ) ⇒ ( ) B 2024 — 1 — 2024-10-07 – p.7/68
  6. “Digital Transformation for Public Good” ( ) ( ) —

    AI ( ) — ( ) ( ) ← “FinTech — Financial Innovation and the Internet” ( ) (2023 2024 ) B (2020 ∼) ( ) → ( ) https://speakerdeck.com/ks91 B 2024 — 1 — 2024-10-07 – p.8/68
  7. NEO — (2009) : SF NEO : New Economic Order

    ( ) http://grsj.jp/neo.pdf (CC-BY-SA 3.0) science fiction prototyping (1) (2) VR A +VR3D (2021) B 2024 — 1 — 2024-10-07 – p.9/68
  8. ( ) (2017) : SF + + SF (2048 )

    2048 B 2024 — 1 — 2024-10-07 – p.10/68
  9. ( ) (1) 2020 9 60 (2020) : ( )

    . . . = ( ) ( ) GitHub Copilot (AI ) ChatGPT B 2024 — 1 — 2024-10-07 – p.11/68
  10. ( ) (2) (2020) : ( ) ( = ×

    ) . . . B 2024 — 1 — 2024-10-07 – p.12/68
  11. (1/2) — World Wide Web COVID-19 2020 1990 World Wide

    Web (← ) End-to-End ( ) ( ) ( ) End-to-End ( ) 2008 B 2024 — 1 — 2024-10-07 – p.15/68
  12. (2/2) — ( web3 ) B 2024 — 1 —

    2024-10-07 – p.16/68
  13. ← Python Flask (Python ) Ethereum Brownie (Python Ethereum )

    BBc-2 ( ) B 2024 — 1 — 2024-10-07 – p.17/68
  14. ( 2 ) ( ) Discord miro Discord miro (

    ) ( : ) . . . : ( ) : DApp ( ) B 2024 — 1 — 2024-10-07 – p.18/68
  15. ( ) 25% 25% 20% 30% ( ) B 2024

    — 1 — 2024-10-07 – p.19/68
  16. ( ) 1 10 7 • 2 10 14 3

    10 21 1 4 11 28 2 5 11 4 1 6 11 11 2 7 11 18 8 11 25 ( ) Discord B 2024 — 1 — 2024-10-07 – p.20/68
  17. ( ) ੪౻ 0DVMVT2VFTU खݩͷΩʔϘʔυ ࣮ߦ )%.* #MVFUPPUI #MVFUPPUI खݩͷτϥοΫϘʔϧ

    .BD1SP ໨ͷલͷσΟεϓϨΠ എޙͷ..BD#PPL"JS "QQMF 3FNPUF%FTLUPQ 0DVMVT 3FNPUF%FTLUPQ )PSJ[PO8PSLSPPNT VT2VFTU MacBook Air B 2024 — 1 — 2024-10-07 – p.23/68
  18. ެ։୆ா ެ։Ͱͳ͚Ε͹ͳΒͳ͍ ʜ ຊਓ ɾૹۚه࿥ ɾίʔυ ɾσʔλͷมԽ ɾ࣮ߦϩά ݕӾͰ͖Δୈࡾऀ ͜Εɺ

    ه࿥͍ͨ͠Μ͚ͩͲ ͋ͳͨ͸ ॻ͍ͨΒμϝ ͜ͷ಺༰͸ ॻ͍ͨΒμϝ ॻ͍ͪΌͬͨͷʁ ͜͏ॻ͖׵͑·͠ΐ͏ ॻ͍ͯͳ͍ͷʁ ͜͏ॻ͔Εͨ͜ͱʹ ͠·͠ΐ͏ ॻ͍ͪΌͬͨͷʁ ফ͠·͠ΐ͏ %P4 ߈ܸͱ͔Ͱ ๦֐ͯ͠ࢭΊ·͠ΐ͏ B 2024 — 1 — 2024-10-07 – p.25/68
  19. Bitcoin . . . : (i.e. ) ( ) :

    : : ⇒ ( ) ← B 2024 — 1 — 2024-10-07 – p.26/68
  20. ৽ن ϒϩοΫ ܈ ௥Ճ ίετϨδελʔ෇͖ ୆ா ਖ਼౷ͳཤྺ ఏҊ͞ΕΔ৽͍͠ཤྺ ίετ େ

    ੎ ͕ ࢀ Ճ ݁Ռ B มߋແ͠ C ௥ه D ॻ͖׵͑ ɾ৽͍͠ཤྺ͕͜Ε·Ͱͷཤྺʹ஝ੵ͞Εͨ ɹίετΛ૿େͤ͞ΔΑ͏ͳ΋ͷͰͳ͍ͷ ɹͳΒ͹มߋ͸ੜ͡ͳ͍ɻ ɾίετ͸݁ՌతʹɺωΠςΟϒ҉߸ࢿ࢈ ݐͯͰଌΒΕΔɻ ɾ୆ாͷҡ࣋ʹࢀՃ͢Ε͹ɺ֬཰తʹେ͖ͳ ใुΛωΠςΟϒ҉߸ࢿ࢈ͰಘΒΕΔɻ ɾใुΛಘΔͨΊʹ͸ίετෛ୲ͰϚδϣϦςΟ ଆʹ͍ͳ͚Ε͹ͳΒͳ͍ɻ B 2024 — 1 — 2024-10-07 – p.27/68
  21. 4 ( ) ( ) ( ; ) ( )

    B 2024 — 1 — 2024-10-07 – p.28/68
  22. ( ) ೖྗ σδλϧͳΒԿͰ΋Α͍σʔλͷू߹ ແݶ ग़ྗ CJU ͳͲݻఆ௕ͷ਺ͷू߹ ༗ݶ ग़ྗ஋͸ʮμΠδΣετʯͱ΋ݺ͹ΕΔ

    খ ͞ ͍ ॱ ʹ ฒ Μ Ͱ ͍ Δ ͱ ͠ ͯ খ ͞ ͍ ॱ ʹ ฒ Μ Ͱ ͍ Δ ͱ ͠ ͯ 4)"ͳͲͷؔ਺ 4)"4FDVSF)BTI"MHPSJUIN Ұ༷ʹ෼෍ ϋογϡؔ਺ͷੑ࣭ ภͬͯ෼෍ Ϛοϐϯάʹ๏ଇੑ͕ແ͍Α͏ʹݟ͑ɺ ˠͷํ޲ʹ͸҆ՁʹܭࢉͰ͖Δ͕ɺ ٯͷํ޲ʹ͸ܭࢉͰ͖ͳ͍ Ұํ޲ੑ ҉߸ֶతϋογϡؔ਺ͷੑ࣭ ແݶΛ༗ݶʹϚοϐϯά͢ΔͷͰɺҟͳΔೖྗ͕ ಉ͡ग़ྗ݁ՌʹͳΔ৔߹΋͘͝رʹ͋Δ িಥ িಥ ͤ͞Δํ๏ ͕ݟ͔ͭͬͨ҉߸ֶతϋογϡ ؔ਺͸΋͸΍҆શͱ͸ݟͳ͞Εͳ͍ B 2024 — 1 — 2024-10-07 – p.29/68
  23. ( ) ൿີ伴 伴ϖΞ ͋Β͔͡Ί ੜ੒ ൿີʹӅ࣋ͭ͠ ͋Β͔͡Ί౉͓͍ͯͯ͠΋Α͍ ॺ໊Λ࡞ͬͨͷ͸ެ։伴ʹ ରԠ͢Δൿີ伴Λ࢖͑Δ୭

    ͔ ͢ͳΘͪॺ໊ऀ ͩ͠ɺ ݩͷσʔλ͸ॺ໊ޙ͸CJU ΋มΘͬ ͍ͯͳ͍ ͜ͷ࢓૊Έ͕ਖ਼͘͠ಈ࡞͢ΔͨΊʹ͸ɺ ड͚औͬͨެ։伴͕ຊ౰ʹॺ໊ऀͷ΋ͷ Ͱ͋Δͱ͍͏ԿΒ͔ͷূ໌͕ඞཁ ʲॺ໊ΞϧΰϦζϜʳ ೖྗݩͷσʔλɺ ൿີ伴 ग़ྗॺ໊ ʲॺ໊ݕূΞϧΰϦζϜʳ ೖྗݩͷσʔλɺ ॺ໊ɺ ެ։伴 ग़ྗ0,·ͨ͸/( ެ։伴 ॺ໊ऀ ॺ໊ ΞϧΰϦζϜ ॺ໊ݕূ ΞϧΰϦζϜ 0, ·ͨ͸ /( Πϯλʔωοτ ݕূऀ ެ ެ։ ։伴 伴 ެ։ ެ։伴 ެ ެ։ ։伴 伴 ݩͷ σʔλ ݩͷ σʔλ ॺ໊ ॺ໊ B 2024 — 1 — 2024-10-07 – p.30/68
  24. ϒϩοΫ O ࣌ؒ ϒϩοΫϔομʔ ͍ΖΜͳ৘ใ͕ೖ͍ͬͯΔ ϒϩοΫ O ͷ μΠδΣετ औҾ

    σʔλ ެ։伴 ˍॺ໊ औҾ σʔλ ެ։伴 ˍॺ໊ औҾ σʔλ ެ։伴 ˍॺ໊ ʜʜ ϒϩοΫ O  ϒϩοΫϔομʔ ͍ΖΜͳ৘ใ͕ೖ͍ͬͯΔ ϒϩοΫ O ͷ μΠδΣετ औҾ σʔλ ެ։伴 ˍॺ໊ औҾ σʔλ ެ։伴 ˍॺ໊ औҾ σʔλ ެ։伴 ˍॺ໊ ʜʜ ϒϩοΫͷμΠδΣετ͸ ͦͷϒϩοΫΛҰҙʹࣔ͢ ࣝผࢠͱͯ͠΋༻͍ΒΕΔ औҾσʔλͷ࡟আ౳ͰϒϩοΫͷ ಺༰͕มΘΕ͹ɺͦͷμΠδΣετ ΋มΘΔͷͰɺໃ६͕ੜ͡Δ औҾσʔλʹ͸ૹ৴ऀͷσδλϧ ॺ໊͕෇͍͍ͯΔͷͰվ͟Μ͸ ࠔ೉͕ͩɺऔҾσʔλΛؙ͝ͱ ࡟আ͢Δ͜ͱ͸Ͱ͖Δ ࣍ͷϒϩοΫʹμΠδΣετ͕ ֨ೲ͞Ε͍ͯΔ͜ͱͰɺखલͷ ϒϩοΫͷ಺༰͸ϩοΫ͞Εͯ ͍Δͱ΋ݴ͑Δ͕ʜ ܨ͕͍ͬͯΔϒϩοΫͷϔομʔ ͷதͷμΠδΣετΛ࣍ʑͱॻ͖ ׵͍͚͑ͯ͹ໃ६ͳ͘վ͟ΜͰ͖ ΔͷͰɺϒϩοΫΛ࡞Δ͜ͱࣗମ ʹେ͖ͳίετΛඞཁʹͯ͠कΔ Proof of Work ( ) : ( ) Proof of Stake ( ) : B 2024 — 1 — 2024-10-07 – p.31/68
  25. ( : ) ( : ) ← NFT 4 ⇒

    B 2024 — 1 — 2024-10-07 – p.32/68
  26. (Confidentiality) 4 ( 4 ) ↑ ( = ) (Integrity)

    (Availability) B 2024 — 1 — 2024-10-07 – p.33/68
  27. 2009 ↑ 15 ( 5 ) B 2024 — 1

    — 2024-10-07 – p.34/68
  28. ( ) ( ) ( ) B 2024 — 1

    — 2024-10-07 – p.36/68
  29. ( ) ( ) ( ) B 2024 — 1

    — 2024-10-07 – p.38/68
  30. / ( ) ( ) ( ) ( ) B

    2024 — 1 — 2024-10-07 – p.40/68
  31. ( ) ( ) ( ) B 2024 — 1

    — 2024-10-07 – p.41/68
  32. ( ) ( ) ( ) : https://doi.org/10.1016/j.icte.2021.08.012 ( )

    ( ) ( ) : https://ieeexplore.ieee.org/document/9686409 B 2024 — 1 — 2024-10-07 – p.48/68
  33. ( ) ( ) : https://ieeexplore.ieee.org/document/9686409 3D ( ) :

    HACCP ( ) B 2024 — 1 — 2024-10-07 – p.49/68
  34. 2. Ethereum macOS (Sonoma 14.7) + Homebrew Linux (Ubuntu 24.04)

    (x86/AMD64 and ARM) Windows 11 + Windows Subsystem for Linux (Ubuntu ) Ethereum solidity brownie Lima on macOS B 2024 — 1 — 2024-10-07 – p.50/68
  35. macOS : Homebrew (Apple macOS ) UNIX macOS Lima Homebrew

    brew Apple brew ( ) brew Rosetta brew brew https://github.com/homebrew/install Path : https://zenn.dev/tet0h/articles/a92651d52bd82460aefb $ which brew /opt/homebrew/bin/brew B 2024 — 1 — 2024-10-07 – p.51/68
  36. macOS : Rosetta 2 Apple x86/AMD64 ( ) $ softwareupdate

    --install-rosetta lima Rosetta 2 lima B 2024 — 1 — 2024-10-07 – p.52/68
  37. macOS : Lima macOS Linux ( ) https://github.com/lima-vm/lima QEMU (

    ) Rosetta 2 Apple x86/AMD64 brew $ brew install lima Ubuntu 24.04 (x86/AMD64) “kmd.yaml” $ limactl start kmd.yaml B 2024 — 1 — 2024-10-07 – p.53/68
  38. macOS : Lima Linux (Ubuntu) x86_64 $ limactl list Linux

    (exit ) $ limactl shell kmd Linux limactl list STATUS Stopped limactl start kmd “.lima” diffdisk 100GB B 2024 — 1 — 2024-10-07 – p.54/68
  39. Solidity Ethereum ( ) http://solidity.readthedocs.io/en/latest/installing-solidity.html Linux (on Windows) “sudo apt”,

    macOS “brew” Linux ARM git clone dependencies solc 0.8.27 (10/5 ) $ solc --version brownie py-solc-x solc (dependencies) ( solc py-solc-x ) B 2024 — 1 — 2024-10-07 – p.55/68
  40. Python3 macOS $ brew install python3 Python 3.8 Homebrew $

    brew uninstall --ignore-dependencies [email protected] $ brew install [email protected] /usr/local/opt/[email protected]/bin/python3 Linux ( python3.12.3 OK) $ sudo apt update $ sudo apt install python3-dev python3-venv python3-tk 16.10 python3(.8) apt (PPA ) python3 python3-dev python3-venv python3-tk B 2024 — 1 — 2024-10-07 – p.57/68
  41. macOS : . . . macOS wget brew dyld: Library

    not loaded: /usr/local/opt/gettext/lib/libintl.8.dylib $ brew uninstall --force gettext $ brew install gettext B 2024 — 1 — 2024-10-07 – p.58/68
  42. Python (venv) macOS (Linux python3 ) OK Python $ python3

    -m venv bbc2env $ source bbc2env/bin/activate (bbc2env) $ pip install -U pip bbc2env ( BBc-2 ) ( ) (bbc2env) $ deactivate B 2024 — 1 — 2024-10-07 – p.59/68
  43. $ brownie init ( ERC-20 ) $ brownie bake token

    $ cd token B 2024 — 1 — 2024-10-07 – p.61/68
  44. contracts (macOS Linux (x86/AMD64) ) $ brownie compile Linux (ARM)

    (AMD64 ) $ python # >>> import solcx >>> solcx.compile_solc(’0.6.12’) # >>> quit() /tmp ∼/.solcx/solc-v0.6.12 ( ) $ pytest tests B 2024 — 1 — 2024-10-07 – p.62/68
  45. Brownie $ brownie console Python >>> len(accounts) 10 >>> accounts[0].balance()

    100000000000000000000 >>> quit() B 2024 — 1 — 2024-10-07 – p.63/68
  46. infura.io Brownie https://infura.io SIGN UP PROJECT ID infura Ethereum API

    infura . . . infura.io PROJECT ID WEB3_INFURA_PROJECT_ID PROJECT ID (∼/.bash_profile ) $ export WEB3_INFURA_PROJECT_ID= PROJECT ID B 2024 — 1 — 2024-10-07 – p.65/68
  47. Sepolia ETH brownie console Sepolia >>> network.disconnect() >>> network.connect(’sepolia’) >>>

    len(accounts) 0 >>> accounts.add() <LocalAccount object ’ 16 ’> >>> accounts[0].private_key 16 >>> quit() Sepolia Testnet ETH Faucet ETH https://sepoliafaucet.com ( ) ( ) https://metamask.io/ B 2024 — 1 — 2024-10-07 – p.66/68
  48. Sepolia ETH brownie console Sepolia ETH >>> network.disconnect() >>> network.connect(’sepolia’)

    >>> len(accounts) 0 >>> accounts.add( 16 ) <LocalAccount object ’ 16 ’> >>> accounts[0].balace() ETH >>> quit() ETH >>> accounts[0].transfer(accounts[1], "0.01 ether") B 2024 — 1 — 2024-10-07 – p.67/68