Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Ethereumを支えるネットワークの話
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
jkcomment
July 24, 2018
Technology
5.3k
11
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Ethereumを支えるネットワークの話
blockchain.tokyo #10登壇資料
jkcomment
July 24, 2018
More Decks by jkcomment
See All by jkcomment
なぜBlockchainはRustを選ぶのか #roppongirs / why-blockchain-chooses-rust
jkcomment
2
2.3k
DAppsを支えるバックエンド開発の話
jkcomment
2
940
Other Decks in Technology
See All in Technology
Oracle AI Database@Google Cloud:サービス概要のご紹介
oracle4engineer
PRO
6
1.6k
[AWS Summit Japan 2026]迷っているあなたへ_小さな一歩が、やがて自分を助けてくれる
sh_fk2
1
380
不要なレビューをAIにまかせて AIコーディングの環境改善を加速した
shoota
1
250
5分でわかるDuckDB Quack
chanyou0311
2
230
水を運ぶ人としてのリーダーシップ
izumii19
4
900
AIが自律的に回る開発ループを設計してチーム開発に組み込む
nekorush14
0
120
攻撃者視点で考えるDetection Engineering
cryptopeg
3
2.1k
サイバーエージェントにおけるAI推進戦略と変革への取り組み
shotatsuge
0
460
ぼっちではじめた登壇が「51名」「241件」の発信に化けた
subroh0508
1
300
フィジカル版Github Onshapeの紹介
shiba_8ro
0
320
新しいUbuntu/GNOMEが使いたいからXからWaylandへ移行頑張ってるの巻 2026-06-20
nobutomurata
0
160
レガシーな広告配信システムでのAI駆動開発/運用の挑戦
i16fujimoto
0
110
Featured
See All Featured
Art, The Web, and Tiny UX
lynnandtonic
304
22k
Easily Structure & Communicate Ideas using Wireframe
afnizarnur
194
17k
Efficient Content Optimization with Google Search Console & Apps Script
katarinadahlin
PRO
1
630
Reality Check: Gamification 10 Years Later
codingconduct
0
2.2k
Typedesign – Prime Four
hannesfritz
42
3.1k
Designing Experiences People Love
moore
143
24k
The Mindset for Success: Future Career Progression
greggifford
PRO
0
370
JavaScript: Past, Present, and Future - NDC Porto 2020
reverentgeek
52
6k
RailsConf & Balkan Ruby 2019: The Past, Present, and Future of Rails at GitHub
eileencodes
141
35k
ピンチをチャンスに:未来をつくるプロダクトロードマップ #pmconf2020
aki_iinuma
128
56k
The Language of Interfaces
destraynor
162
27k
How to make the Groovebox
asonas
2
2.2k
Transcript
Ethereumを支える ネットワークの話 BLOCKCHAIN.TOKYO #10 2018.7.24 DMM.comラボ スマートコントラクト事業部 金志京
自己紹介 2016年9月 株式会社DMM.comラボ(現 合同会社DMM.com)入社 2017年まではWebRTCの人でした。が、2018年からはBlockchainの人です。 趣味: 育児、ロードバイク、最近はスニーカー 金 志京(きむ じぎょん)
Twitter: @jkcomment
本日のアジェンダ • ちょっとだけP2Pの話 • Ethereumのネットワークの話 • まとめ
入る前に • 外部勉強会は初登壇です • go-ethereumの実装&wikiベース(ほぼ) • ソースコードと各プロトコルの 細かいスペックは出ません(ほぼ)
本日のゴール 1. ノードを生成して 2. どのように他のノードを探索して 3. どのように他のノードと接続して 4. どのようにデータのやり取り(同期とか)をするか ...をわかっていただければ
ちょっとだけP2Pの話 Ethereumのネットワークの話 まとめ Section01 Section02 Section03
P2Pとは Peer to Peer(ピア・トゥ・ピア または ピア・ツー・ピア)とは、 複数の端末間で通信を行う際のアーキテクチャのひとつで、 対等の者(Peer、ピア)同士が通信をすることを特徴とする通信方式、通信 モデル、あるいは通信技術の一分野を指す。 wikipediaより
P2Pの種類 - ① Hybrid • Peerの位置情報およびデータ保存情報を Indexサーバに保存し、個別のPeerの接続を 管理する方式 • メ:
Indexサーバがノード探索を担当するため 設計と管理が安易 • デ: Indexサーバが攻撃されると、 新規Nodeは参加できなくなる
P2Pの種類 - ② Pure • ノード探索も、情報の保持もノード自分で 行う方式 • メ: 耐障害性高さ
• デ: 実装が難しい、セキュリティ制御も難 しい
ちょっとだけP2Pの話 Ethereumのネットワークの話 まとめ Section01 Section02 Section03
EthereumのProtocol
EthereumのProtocol
EthereumのProtocol
ÐΞVp2p • Transport Layer(Network Layer & Presentation Layer) • Kademlia-like
DHT • 全てのデータはRLPでエンコードする(RLPx) • データのやり取りはTCP、ネットワークの維持(探索・確認)はUDP • 使用ポートは30303
ノード探索(Node Discovery)
ノード探索(Node Discovery) • Kademliaベースのノード探索アルゴリズム • Node ID = secp256k1 Public
key • Node間(n₁, n₂)の距離 = keccak256(n₁) XOR keccak256(n₂)
ノード探索(Node Discovery)
ノード探索(Node Discovery)
接続(RLPx Protocol)
接続(RLPx Protocol) 2種類のHandshakeを行う • Encrypted handshake • Protocol handshake
接続(RLPx Protocol) Encrypted handshake • Node A ◦ 認証メッセージの初期化(主に署名に関する処理) ▪
メッセージの内容: • 公開鍵、署名、Nonceなど ◦ 認証メッセージをRLPでエンコード ◦ Node Bの公開鍵で暗号化し、EIP8フォーマットのpacket に変換 ◦ コネクションに書き込む(Write)
接続(RLPx Protocol) Encrypted handshake • Node B ◦ 受信したパケットを自分の秘密鍵で復号化し、 内容を検証
◦ Response用認証メッセージ生成 ▪ メッセージ内容 • 公開鍵、署名、Nonceなど ◦ 認証メッセージをRLPでエンコード ◦ Node Aの公開鍵で暗号化し、EIP8フォーマットのpacket に変換 ◦ コネクションに書き込む(Write)
接続(RLPx Protocol) Protocol handshake • Helloメッセージを送り合う • Helloメッセージのやり取りが終わるまで packetの送・受信はできない •
Helloメッセージを送って、5秒以内に返信がな いとTimeOut処理が走る
Ethereum Wire Protocol
Ethereum Wire Protocol • Application Layer • Ethereum(eth)、Whisper(shh)、Swarm(bzz) etc. •
シンプルな識別コード
識別コード メッセージ 説明 0x00 Status Ethereum状態情報を伝送 0x01 NewBlockHashes 新しいブロックヘッダを伝送 0x02
Transactions トランザクションを伝送 0x03 GetBlockHeaders ブロックヘッダ要求 0x04 BlockHeaders ブロックヘッダ応答 0x05 GetBlockBodies ブロックボディ要求 0x06 BlockBodies ブロックボディ応答 0x07 NewBlock 新しいブロックボディを伝送 0x08 BlockHashesFromNumber ブロックハッシュと番号を要求 0x0d GetNodeData ノードデータ要求 0x0e NodeData ノードデータ応答 0x0f GetReceipts レシート要求 0x10 Receipts レシート応答 Ethereum Wire Protocolメッセージ一覧
ノード間同期処理 1. Node Aは、自分の状態情報を送信 (Total Difficulty, Block hash) 2. Node
Bは、自分の状態情報を返信 3. TDとBlock hashを比較 4. Get Block Headers 5. Block Headers 6. 情報をダウンロード
ちょっとだけP2Pの話 Ethereumのネットワークの話 まとめ Section01 Section02 Section03
まとめ
まとめ • EthereumにはÐΞVp2pプロトコルと Ethereum Wire Protocolがある。 • ÐΞVp2pプロトコルでノード探索を行い、 P2Pオーバーレイネットワークを形成する。 •
Ethereum Wire Protocolで実際のブロックチェーンの データのやりとりを行う。(送・受信手段はRLPx)
• DMMでは様々な人材を募集しています ◦ https://dmm-corp.com/recruit/top • 遊びに来てね 最後に
ご清聴ありがとうございました