JP7208164B2 - ブロックチェーン・ネットワークにおいてラージ・ブロックを管理するためのコンピュータ実装システム及び方法 - Google Patents

ブロックチェーン・ネットワークにおいてラージ・ブロックを管理するためのコンピュータ実装システム及び方法 Download PDF

Info

Publication number
JP7208164B2
JP7208164B2 JP2019564132A JP2019564132A JP7208164B2 JP 7208164 B2 JP7208164 B2 JP 7208164B2 JP 2019564132 A JP2019564132 A JP 2019564132A JP 2019564132 A JP2019564132 A JP 2019564132A JP 7208164 B2 JP7208164 B2 JP 7208164B2
Authority
JP
Japan
Prior art keywords
nodes
transactions
node
blockchain
computer
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
JP2019564132A
Other languages
English (en)
Other versions
JP2020522786A (ja
Inventor
デステファニス,ジュゼッペ
マデオ,シモーネ
モティリンスキ,パトリック
ヴィンセント,ステファヌ
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
nChain Holdings Ltd
Original Assignee
nChain Holdings Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Priority claimed from GBGB1709098.6A external-priority patent/GB201709098D0/en
Priority claimed from GBGB1709099.4A external-priority patent/GB201709099D0/en
Application filed by nChain Holdings Ltd filed Critical nChain Holdings Ltd
Publication of JP2020522786A publication Critical patent/JP2020522786A/ja
Priority to JP2023000329A priority Critical patent/JP2023036931A/ja
Application granted granted Critical
Publication of JP7208164B2 publication Critical patent/JP7208164B2/ja
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/24Querying
    • G06F16/245Query processing
    • G06F16/2458Special types of queries, e.g. statistical queries, fuzzy queries or distributed queries
    • G06F16/2465Query processing support for facilitating data mining operations in structured databases
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/10File systems; File servers
    • G06F16/18File system types
    • G06F16/182Distributed file systems
    • G06F16/1834Distributed file systems implemented based on peer-to-peer networks, e.g. gnutella
    • G06F16/1837Management specially adapted to peer-to-peer storage networks
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/60Protecting data
    • G06F21/64Protecting data integrity, e.g. using checksums, certificates or signatures
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/104Peer-to-peer [P2P] networks
    • H04L67/1074Peer-to-peer [P2P] networks for supporting data block transmission mechanisms
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/104Peer-to-peer [P2P] networks
    • H04L67/1087Peer-to-peer [P2P] networks using cross-functional networking aspects
    • H04L67/1091Interfacing with client-server systems or between P2P systems
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/104Peer-to-peer [P2P] networks
    • H04L67/1087Peer-to-peer [P2P] networks using cross-functional networking aspects
    • H04L67/1093Some peer nodes performing special functions
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/06Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols the encryption apparatus using shift registers or memories for block-wise or stream coding, e.g. DES systems or RC4; Hash functions; Pseudorandom sequence generators
    • H04L9/0643Hash functions, e.g. MD5, SHA, HMAC or f9 MAC
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/32Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials
    • H04L9/3236Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials using cryptographic hash functions
    • H04L9/3239Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials using cryptographic hash functions involving non-keyed hash functions, e.g. modification detection codes [MDCs], MD5, SHA or RIPEMD
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q20/00Payment architectures, schemes or protocols
    • G06Q20/30Payment architectures, schemes or protocols characterised by the use of specific devices or networks
    • G06Q20/36Payment architectures, schemes or protocols characterised by the use of specific devices or networks using electronic wallets or electronic money safes
    • G06Q20/367Payment architectures, schemes or protocols characterised by the use of specific devices or networks using electronic wallets or electronic money safes involving electronic purses or money safes
    • G06Q20/3672Payment architectures, schemes or protocols characterised by the use of specific devices or networks using electronic wallets or electronic money safes involving electronic purses or money safes initialising or reloading thereof
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L2209/00Additional information or applications relating to cryptographic mechanisms or cryptographic arrangements for secret or secure communication H04L9/00
    • H04L2209/30Compression, e.g. Merkle-Damgard construction
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L2209/00Additional information or applications relating to cryptographic mechanisms or cryptographic arrangements for secret or secure communication H04L9/00
    • H04L2209/56Financial cryptography, e.g. electronic payment or e-cash
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/50Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols using hash chains, e.g. blockchains or hash trees

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Security & Cryptography (AREA)
  • Theoretical Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Databases & Information Systems (AREA)
  • Software Systems (AREA)
  • Computing Systems (AREA)
  • Data Mining & Analysis (AREA)
  • Bioethics (AREA)
  • Computer Hardware Design (AREA)
  • General Health & Medical Sciences (AREA)
  • Health & Medical Sciences (AREA)
  • Power Engineering (AREA)
  • Fuzzy Systems (AREA)
  • Mathematical Physics (AREA)
  • Probability & Statistics with Applications (AREA)
  • Computational Linguistics (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
  • Financial Or Insurance-Related Operations Such As Payment And Settlement (AREA)

Description

本明細書は概してブロックチェーン・ネットワークのノードにおける実装に適したコンピュータ実装方法及びシステムに関する。多数のトランザクション及び大きなトランザクション・ブロックを扱うための修正されたブロックチェーン・ノード構造、ネットワーク・アーキテクチャ、及びプロトコルが説明される。本発明はビットコイン・ブロックチェーンに使用することに特に適しているがこれに限定されない。
本書では電子的なコンピュータ・ベースの分散型の全ての形態の台帳を含むように用語「ブロックチェーン」を使用する。これらは、ブロックチェーン及びトランザクション・チェーン技術、許可された及び許可されていない台帳、共有台帳、並びにそれらの変形を含むが、これらに限定されない。ブロックチェーン技術の最も広く知られている応用はビットコイン台帳であるが、他のブロックチェーン実装が提案され開発されている。本明細書では、便宜上及び説明の目的でビットコインが参照されるかもしれないが、本発明は、ビットコイン・ブロックチェーンで使用することに限定されず、代替的なブロックチェーンの実装及びプロトコルが、本発明の範囲内に属することに留意すべきである。
ブロックチェーンはコンセンサス・ベースの電子台帳であり、これはトランザクション及びその他の情報により構成されるブロックにより構成される、コンピュータ・ベースの非セントラル化された分散システムとして実装される。ビットコインの場合、各トランザクションは、ブロックチェーン・システムの参加者間のディジタル資産のコントロールの移動をエンコードするデータ構造であり、少なくとも1つの入力及び少なくとも1つの出力を含む。各ブロックは、共にチェーン化されるようになる先行するブロックのハッシュを含み、開始以来ブロックチェーンに書き込まれている全てのトランザクションについての永続的で変更不可能な記録を作成する。トランザクションは、トランザクションの入力及び出力に組み込まれるスクリプトと呼ばれる小さなプログラムを含み、スクリプトは、トランザクションの出力がどのように誰によってアクセスされ得るかを指定する。ビットコイン・プラットフォームでは、これらのスクリプトはスタック・ベースのスクリプト言語を使用して書かれる。
トランザクションがブロックチェーンに書き込まれるためには、それが「検証済み(validated)」でなければならない。幾つかのネットワーク・ノードは、マイナーとして振る舞い、各トランザクションが有効であることを保証するために作業を行い、無効なトランザクションはネットワークから拒否される。例えば、ノードにインストールされたソフトウェア・クライアントは、未使用残高(unspent transaction output:UTXO)を参照するトランザクションに対してこの検証作業を実行する。検証は、そのロック及びアンロック・スクリプトを実行することによって実行されてもよい。ロック及びアンロック・スクリプトの実行がTRUEに評価され、特定の他の条件が満たされる場合、トランザクションは有効であり、トランザクションはブロックチェーンに書き込まれることができる。従ってトランザクションがブロックチェーンに書き込まれるためには、i)トランザクションを受け取るノードによって検証され、トランザクションが有効である場合には、そのノードがそれをネットワーク内の他のノードへ中継すること;及びii)マイナーによって構築された新しいブロックに追加されること;及びiii)採掘されること、即ち、過去のトランザクションの公の台帳に追加されることを要する。トランザクションを実質的に不可逆的にする程度に十分な数のブロックがブロックチェーンに追加されると、トランザクションは合意されたと考えられる。
ブロックチェーン技術は、暗号通貨の実装を利用することに最も広く知られているが、ディジタル起業家は、新しいシステムを実現するために、ビットコインが基礎としている暗号セキュリ・ティシステムと、ブロックチェーンに格納され得るデータとの双方を使用することを探求し始めている。ブロックチェーンが、暗号通貨での支払いに純粋に限定されない自動化されたタスク及びプロセスに使用され得るならば、非常に有利であろう。このようなソリューションは、ブロックチェーンの利点(例えば、イベントの恒久的な改ざん防止記録、分散処理など)を、それらの用途でいっそう多様化しつつ利用し得るであろう。
1つの研究分野は「スマート契約(smart contracts)」の実装のためにブロックチェーンを利用することである。これらは、機械読み取り可能な契約又は合意の条件の履行を自動化するように設計されたコンピュータ・プログラムである。自然言語で書かれる伝統的な契約とは異なり、スマート契約は、結果を生成するために入力を処理することが可能であり、次いでそれらの結果に依存してアクションを実行させることが可能なルールを含む機械実行可能プログラムである。
ブロックチェーン関連の他の関心領域は、ブロックチェーンを介して現実世界のエンティティを表現及び転送するための「トークン」(又は「カラー・コイン」)を使用することである。潜在的にセンシティブな又は秘密のアイテムは、認識可能な意味又は値を持たないトークンによって表現されることが可能である。従って、トークンは、現実世界のアイテムがブロックチェーンから参照されることを可能にする識別子として機能する。
US2015/0287026は、ホット・ウォレット・サービス・システムを開示している。ホット・ウォレット・サービス・システムは、1つ以上のユーザ・デバイスから金融トランザクションを受信し、マルチ署名認証システムを実装する複数の認証サーバーを使用して金融トランザクションを認証し、ディジタル署名を集約し、認証された金融トランザクションを仮想通貨ネットワークに伝搬させる。金融トランザクションが仮想通貨ネットワークにより伝播されると、金融トランザクションは、通常の方法で仮想通貨ネットワークのマイナー・エンティティによって、公の共有台帳に組み込まれることが可能である。
CN106548349は、ブロックチェーン・ネットワーク内の全てのノードが全てのトランザクションのトランザクション情報を検証する必要がある場合、このプロセスはかなりのワークロードを生成し、ノードに多大な圧力をかけてしまう問題に関連している。CN106548349に記載されているソリューションは、全てのノードがトランザクション情報を検証しなければならないことを要求するのではなく、トランザクション情報を検証するために、第1のノードから複数の選択された第2ノードへトランザクション情報を伝搬することである。第2ノードはランダムで不規則な方法で選択され、悪意のある詐欺(fraud)の可能性を防止し、全てのノードがトランザクション情報を検証する必要もない。
WO2017/162904は、トランザクション遅延が削減され、リソースの二重送金が、リソース管理システムで新ブロックが確立される前にトランザクションを検証することにより軽減される、ブロックチェーン・ベースのリソース管理システムに関連している。少なくとも1つの検証ノードは、トランザクションを検証し、検証受諾メッセージをマーチャントに提供し、アイテムを顧客にリリースするために提供される。従って、ブロックチェーンの次のブロックが確立されるのを待たずに、売却を確実に完了させることができる。また、検証ノードは、検証ノードのセットに検証リクエストを配布し、検証ノードのセットからレスポンスを受信できることも開示されている。次いで、検証ノードは、検証ノードのセットからのレスポンスの何れもがトランザクションに対する拒否ではない場合であってその場合に限り、検証受諾メッセージをマーチャントに送信してよい。ブロックチェーン内でブロックを確立する時が到来した場合に、ブロックを確立するノードは、直近に確立されたブロック以降に行われた一連のトランザクションをコンパイルすることができ、次のブロックはこの一連のトランザクションを含むことが更に開示されている。
US2016/0259937、WO2017/004527、及びWO2017/011601は、現在のビットコイン・ブロックチェーン・ネットワークがどのように構成され機能するかを説明している。特に、個々のトランザクションは、ネットワークを介して伝播され、マイニングによりブロックチェーンに組み込まれ、ここで、マイニング・ノードは、トランザクションのセットを選択し、トランザクションをプロトタイプ・ブロックにグループ化し、従来の「プルーフ・オブ・ワーク」方式でノンスの値を決定する。マイナーが有効なノンスを発見すると、そのブロックは他のノードによって検証され、ブロックチェーンに組み込まれる。
US2015/0310424は、マルチ・モーダル暗号鍵アドレス・マッピングによってユーザ・ディレクトリ・データを生成するシステムを開示している。暗号通貨ネットワークは暗号ノードを備え、暗号通貨のユーザのトランザクションのセットを公に検証する。ノードは、トランザクションを中継し、検証台帳を維持し、及び/又は暗号通貨をマイニングすることによって、暗号通貨ネットワークに参加することができる。
本書執筆時点で、ビットコイン・ブロックチェーン・ネットワークは、約2000トランザクションを含むブロック・サイズに基づいており、ブロックは約10分ごとにマイニングされている(10分のブロック時間は、最初の確認時間とチェーン・スプリットに費やされる時間との間の妥協として設定されている)。これは約3.5トランザクション/秒というトランザクション処理速度を提供する。対照的に、VISAシステムは、約10000トランザクション/秒というトランザクション処理速度で動作し、50000トランザクション/秒以上に到達し得る。
競争力のある決済システムを構築するためには、ブロックチェーン・ネットワークの現在の制約を何らかの方法で回避する必要があることは明らかである。10分のブロック時間は十分に制定されているので、ブロック・サイズ、従ってブロックチェーン自体の変更を考慮することが必須である。本明細書では、例えば約5万トランザクション/秒を処理し得るスケーラブルなソリューションが説明される。重要なことに、非セントラルかされた分散されシステム・アーキテクチャを維持しながら、高いトランザクション速度をサポートし得るソリューションが提供される。
ビットコイン・ネットワークの現在のアーキテクチャから、大量の同時トランザクションが処理され得るものへの移行は、ネットワーク全体にインフラストラクチャ負担圧力をかける。多数のトランザクションをより効率的に、より高速に検証し中継することが可能なノードのシステムが提案されている。トランザクションの量に起因して、分散アプローチが、メモリプール(mempool)(まだ処理されておらずブロックチェーンに保存されていない未処理トランザクション)の設計において提案される。大量に増加したトランザクションは、ブロック・サイズに圧力をかけ、ブロック・サイズが所定の制限を超えると、ストレージ・インフラストラクチャの問題が生じることになる。本明細書では、大きなギガバイト・サイズのブロックを処理及び格納する問題に対するソリューションが説明される。
本明細書は修正されたブロックチェーン・ネットワーク・アーキテクチャを記載しており、修正されたアーキテクチャは複数の専用トランザクション検証ノードを含み、そのノードは、トランザクションを検証し、ブロックチェーン・ネットワーク内の他のトランザクション検証ノードと共に、検証されたトランザクションを分散された非セントラル化されたストレージを維持するように構成される。トランザクション検証ノードは、更に、検証済みトランザクションのリストをマイナーのために準備し、検証済みトランザクションのリストをマイナーに提供する代わりに、ディジタル資産のためのコミットメント・トランザクションを作成するように構成される。従って、専用トランザクション検証ノードは、トランザクションを検証し、検証済みトランザクションのリストを構築し、及びこれらのリストを有償でマイナーに提供するという観点から、マイナーにサービスを提供する。トランザクションがマイニングされると、マイニングされたトランザクションはトランザクション検証ノードに戻され、トランザクション検証ノードは、マイニングされたトランザクションの大きなブロックを構築し、専用ストレージ・ノードに大きなブロックを格納する。
本発明の一態様はポスト・マイニング機能(post-mining functionality)に関連する。ブロックチェーン・ネットワークのノードのためのコンピュータ実装方法が提供され、コンピュータ実装方法は:
複数の検証されたトランザクションに対応するブロックチェーン・ネットワークからマイニングされたデータを受信するステップ;
マイニングされたデータに基づいてブロックを組み立てるステップ;及び
組み立てられたブロックを、ブロックチェーンに格納するためにストレージ・エンティティへ送信するステップを含む。
このような方法は、マイナーが大きなブロックを構築して格納し、そのようなブロックをブロックチェーン・ネットワークで送信することを必要とせずに、ノードが、ストレージ・エンティティに格納される大きなブロックを構築することを可能にする。更に、このアーキテクチャは、まだ成長し続ける大きなブロックチェーンを格納する専用の大規模な格納エンティティの使用を可能にする。
コンピュータ実装方法は更に:
ブロックチェーン・ネットワークからトランザクションを受信するステップ;
ブロックチェーン・ネットワークから受信したトランザクションを検証するステップ;
ブロックチェーン・ネットワーク内の他のノードとともに、検証されたトランザクションの分散された非セントラル化されたストレージを維持するステップ;及び
検証されたトランザクションに対応するデータであって検証されたトランザクションのリストを含むデータを、マイニングのためにブロックチェーン・ネットワークへ分配するステップを含む。各々のリストは、ブロックへのマイニングのために検証されたトランザクションの完全なリストを提供することができる。
このような方法は、ブロックチェーン・ネットワーク内の他のノードとの検証済みトランザクションの分散された非セントラル化されたストレージを維持しつつ、検証機能を実行するマイナーの要件を効果的に除去する。更に、この方法は、トランザクション検証ノードが、検証されたトランザクションに対応するデータを準備し、マイニングのためにブロックチェーン・ネットワークに分配することにより、マイナーにサービスを提供することを可能にする。例えば、本方法は、検証されたトランザクションのリストが、準備され分配されることを可能にする。
ブロックチェーン・ネットワーク内の他のトランザクション検証ノードとの検証済みトランザクションの分散された非セントラル化されたストレージを維持するステップは、分散され非セントラル化された方法で検証済みトランザクションの最新リストを維持するために、ブロックチェーン・ネットワークのトランザクション検証ノードを同期化するステップを含んでもよい。例えば、検証ノードは、可逆ブルーム・フィルタ・ルックアップ・テーブル(invertible bloom filter lookup tables)を交換することによって同期させられることが可能である。検証されたトランザクションはまた、検証されたトランザクションの分散された非セントラル化されたストレージを維持するために、ブロックチェーン・ネットワーク内のトランザクション検証ノードにわたって共通のオーダリング・システムが使用されるように、定義された順序でソートされることも可能である。例えば、正規のオーダリング・システムは、検証済みトランザクションの分散された非セントラル化されたストレージを維持するために使用されることが可能である。これは、ネットワークを横断するトランザクション・データが一貫した方法で維持されることを保証する一方、非セントラル化された分散されたストレージを保持する特に効率的な方法であることが発見された。
検証されたトランザクションに対応するデータを、マイニングのためにブロックチェーン・ネットワークに分配するステップは、検証されたトランザクションのリストに対応するデータ(可逆ブルーム・ルックアップ・テーブル及び検証されたトランザクションのリストに対応する任意の付随データであって、検証されたトランザクションがブロックに含まれているもの)を準備するステップを含むことが可能である。更に、検証されたトランザクションに対応するデータを、マイニングのためにブロックチェーン・ネットワークに配布するステップは、検証されたトランザクションのリストに対応するデータをマイナーに提供するのと引き換えに、ディジタル資産のコミットメント・トランザクションを作成するステップを含むことが可能である。例えば、ハッシュ(マークル)ツリー、パトリシア・ツリー、又は他のタイプのラディックス・ツリー(radix tree)が、包含されるコミットメント・トランザクションとともに計算されることが可能である。
検証トランザクションに対応するデータが配布され、関連する暗号パズル、例えばハッシュ・パズルを解くことによってマイニングされた後、マイニングされたデータは、マイナーによってブロックチェーン上で直接的に格納されるのではなく、トランザクション検証ノードへ返送される。次に、このマイニングされたデータが、(大きな)ブロックに組み立てられ、大量のデータの格納のために特別に構成されたストレージ・エンティティに及び/又は分散されたストレージ・システムの何れかに格納されることが可能である。上述したように、これは、大きなブロックを構築及び格納し、そのようなブロックをブロックチェーン・ネットワークで送信することをマイナーに要求せずに、ストレージ・エンティティに格納される大きなブロックを、検証ノードが構築することを可能にする。更に、アーキテクチャは、常に成長し続ける大きなブロックチェーンを格納する専用の大規模ストレージ・エンティティの使用を可能にする。
ブロックチェーン・ネットワークから受信されるマイニングされたデータは、検証されたトランザクションに対応するブロック・ヘッダを含むことが可能である。マイニングされたデータはまた、採掘されたデータに基づいてブロックをアセンブル及び/又は記憶することに対するディジタル資産のトランザクションを含むことができる。更に、この方法は、ディジタル資産を受信する前に、最小ブロック数に関連付けられた期間tの間待機する条件を含むことが可能である。これは、プロバイダが、検証済みトランザクションのリストを(例えば、可逆ブルーム・ルックアップ・テーブルの形式で)マイニングのために提供すること、及び/又はマイニングされたブロックをブロックチェーン上で格納することに対して報いられるように、検証ノードを提供するためのインセンティブ・スキームを提供する。ディジタル資産を受け取る前に最低期間を必要とすることは、或る範囲のノードへスケルトン・ブロック(支払いを含む)を伝播させるようにマイナーにインセンティブを与え、ノードは他のノードへスケルトン・ブロックを伝播するようにインセンティブを受ける。
マイニングされたデータに基づいてブロックを組み立てるステップは、例えば、各ブロックが少なくとも2、4、6、8、10、50、100、500、1000、又は10000メガバイトのサイズを有する大きなブロックを組み立てるステップを含み得る。経時的に上限は増えるが、1ペタバイトという公称上限値が指定されてもよい。各ブロックは、例えば、少なくとも5000、10000、50000、100000、500000又は1000000トランザクションを含み得る。上限は時間の経時的に増えるが、1ブロック当たり1012トランザクションという公称上限値が指定されてもよい。上述したように、本明細書に記載された方法、ノード、及びブロックチェーン・ネットワーク・アーキテクチャは、多数のトランザクションを構築及び記憶することをマイナーに要求せずに、ラージ・ブロックが構築され及びストレージ・エンティティに記憶されることを可能にする。これは、システムが大幅に引き上げられたトランザクション速度を処理できるようにする。
本明細書に記載される方法では、ブロックは、マイナーによって提供される乱数を含むブロック・ヘッダを含むように修正され得る。即ち、トランザクション検証ノードは、ブロックチェーン・ネットワークから解決されたトランザクションを受信する場合に、マイナーによって提供された乱数を含むブロック・ヘッダを含むブロックを処理するように構成されることが可能である。これは、ブロック・ヘッダに対する変更を構成し、それによって、マイナーはブロック・ヘッダに挿入される番号を選択したり、又はランダムに生成したりすることが可能である。これは、たとえ同じトランザクション・リストが多数のマイナーによって選ばれたとしても、マイナー達が同一のブロックを採掘しようと競わないことを保証する助けとなる。
データの上述のラージ・ブロックを記憶する記憶装置は、ブロックチェーン・ネットワーク上の複数のトランザクション検証ノード間で共用されることが可能であり、複数のトランザクション検証ノードは、ブロックチェーン・ネットワーク上でスーパー・ノードを形成し、共用される記憶装置は、共通のストレージ・ノード、分散されたストレージ、又はそれら2つの組み合わせの何れかである。このアーキテクチャは、ブロックチェーン・ネットワーク上のスーパー・ノードの形成を導出し、ブロックチェーンを記憶し、ブロックチェーン・ネットワークにサービスを提供する専用記憶装置の提供を可能にする。
上記に鑑み、ブロックチェーン・ネットワークのスーパー・ノードもまた提供され、スーパー・ノードは:
上述されたような複数の検証ノード;及び
ブロックチェーンを格納する共有されるストレージ・エンティティ;
を備え、共有されるストレージ・エンティティは、共通のストレージ・ノード、分散されたストレージ、又はそれら両者の組み合わせの何れかであり、及び
複数の検証ノードにより組み立てられたブロックは、共有されるストレージ・エンティティへ送信され格納され、それにより共有されるストレージ・エンティティはブロックチェーンを維持する。
このアーキテクチャは、本明細書に記載される方法及び構成の目的であるトランザクション・レートの所望の増加を達成するために必要とされる大きなブロック・サイズを処理することにいっそう適している。例えば、共有されるストレージ・エンティティは、少なくとも100ギガバイトのストレージ容量、より好ましくは少なくとも1、10、100、又は1000テラバイトのストレージ容量を有するように構成され得る。上限は経時的に増加するが、10テラバイト、場合によっては10ヨタバイトという公称上限値が指定され得る。
全体的なネットワーク・アーキテクチャに関し、複数のこのようなスーパー・ノードを含むブロックチェーン・ネットワークが提供され得る。スーパー・ノードは、ブロックチェーン・ネットワークで接続されることが可能であり(ただし、重複しない)、各スーパー・ノードの共有されるストレージ・エンティティは、ブロックチェーンのコピーを格納するように設定される。スーパー・ノードは、スーパー・ノードとして機能するプールを形成するノードのグループを効果的に含む。ブロックチェーンの分散された性質を維持するためには、有利なことに、一定数の(例えば、少なくとも10、50、100、又は1000であり、選択的に100,000,000未満の)そのようなスーパー・ノードが存在すべきである。
本発明の実施形態は、様々な形態で提供され得る。例えば、実行されると本明細書に記載されている方法を実行するようにプロセッサを構築するコンピュータ実行可能命令を含むコンピュータ読み取り可能な記憶媒体が提供され得る。電子デバイスはまた:インターフェース;インターフェースに結合される1つ以上のプロセッサ;及び1つ以上のプロセッサに結合されるメモリを有するように提供されることが可能であり、メモリは、実行されると、本願で説明されている方法を1つ以上のプロセッサに実行させるコンピュータ実行可能命令を保存している。更に、ブロックチェーン・ネットワークの検証トランザクション・ノードが提供されることが可能であり、検証トランザクション・ノードは、本明細書で説明される方法を実行するように構成される。
本明細書で説明される発明は、以下説明されるように、背景技術のセクションで議論される先行技術とは異なる。
US2015/0287026は、いったん仮想通貨ネットワークを介して金融トランザクションが伝播されると、その金融トランザクションは、標準的な方法で仮想通貨ネットワークのマイナー・エンティティによって、公の共有台帳に組み込まれ得ることを開示している。従って、US2015/0287026は、特殊なストレージ・ノードを使用してブロックチェーン上で保存するために、マイナーに代わって、採掘されたトランザクションの大きなブロックを収集及び構築するノードを開示していない。更に、US2015/0287026は、採掘されたデータが、採掘されたデータに基づいてブロックを組み立て、及び/又は組み立てられたブロックを記憶することの対価として、ディジタル資産のトランザクションを含むことを開示していない。
同様に、CN106548349、WO2017/162904、US2016/0259937、WO2017/004527、WO2017/011601、及びUS2015/0310424は、特殊なストレージ・ノードを使用してブロックチェーン上で保存するために、マイナーに代わって、採掘れたトランザクションの大きなブロックを収集及び構築するノードを開示していない。更に、これらの文献は、採掘されたデータに基づいてブロックを組み立て、及び/又は組み立てられたブロックを保存することと引き換えに、採掘されたデータがディジタル資産のトランザクションを含むことを開示していない。むしろ、文献は、現在のブロックチェーン・ネットワーク・アーキテクチャを使用する標準的なマイニング手順を開示しており、マイニング・ノードが一組のトランザクションを選択し、そのトランザクションをプロトタイプ・ブロックにグループ化し、従来の「プルーフ・オブ・ワーク」方式でノンスの値を決定し、そしていったんマイナーが有効なノンスを発見すると、そのブロックは他のノードによって検証され、ブロックチェーンに組み込まれる。
上記に鑑みて、本発明はブロックチェーン・ネットワーク内で大きなギガバイト・サイズのブロックをより効率的に処理及び格納するためのユニークなアーキテクチャ及び方法を提供するものと確信する。
本発明のこれら及び他の態様は、本明細書に記載される実施形態から明らかであり、それを参照して解明される。本発明の実施形態は、単なる例示として、添付図面を参照して説明される。
図1はブロックの全体構造を示す。 図2は、ユーザがトランザクションをサブミットした時点からブロックチェーン上で終了するまでのステップを示す動作図によるビットコイン・ネットワークの修正されたアーキテクチャを示す。 図3は、確認のためにメモリプールで待機しているトランザクションの合計サイズの一例を示すグラフを示す。 図4は、内的にセントラル化されたストレージ施設にリンクされた複数のノードを示す。 図5は、各ノードが、分散されたメモリプール及び分散されたストレージ施設双方の一部分である構成を示す。 図6は、新しいノード構造がビットコイン・ネットワークにどのように適合するかを示し、検証ノードがストレージ・プールのメンバーであり、プールが一緒に非セントラル化され分散されたビットコイン・ネットワークを構成するネットワーク構成を示す。 図7は新しいノードの機能を示す。 図8は、現在のプロトコルに対する修正を為す新しいマークル・ツリー構造を示す。 図9はブルーム・フィルタを作成するワークフローを示す。 図10は、トランザクションが、可逆ブルーム・フィルタ(IBF)及び可逆ブルーム・ルックアップ・テーブル(IBLT)でどのようにエンコードされるから示すワークフローを示す。
本明細書では、大きなギガバイト・サイズのブロックを処理して格納する問題に対するソリューションが説明される。
ブロックチェーン・ネットワーク・ノード及び検証ノードのタイプ
ブロックチェーン・ネットワークは、招待無しに及び他のメンバーからの同意も無しに、誰でも参加してよいピア・ツー・ピア・オープン・メンバーシップ・ネットワークとして説明されてよい。ブロックチェーン・ネットワークが動作するブロックチェーン・プロトコルのインスタンスを実行する分散された電子デバイスは、ブロックチェーン・ネットワークに参加することができる。このような分散電子デバイスは、ノードと称されることが可能である。ブロックチェーン・プロトコルは、例えば、ビットコイン・プロトコル又は他の暗号通貨であってもよい。
ブロックチェーン・プロトコルを実行し、ブロックチェーン・ネットワークのノードを形成する電子デバイスは、例えば、デスクトップ・コンピュータ、ラップトップ・コンピュータ、タブレット・コンピュータ、サーバー、コンピュータ・ファームなどのコンピュータ、スマートフォンなどのモバイル・デバイス、スマート・ウォッチなどのウェアラブル・コンピュータ、又は他の電子デバイスなどの様々なタイプのものであってもよい。
ブロックチェーン・ネットワークのノードは、有線及び無線通信技術を含み得る適切な通信技術を使用して互いに結合される。多くの場合、ブロックチェーン・ネットワークは、少なくとも部分的にインターネットを介して実装され、ノードの幾つかは、地理的に分散した場所に配置され得る。
現在、ノードは複数のブロックにグループ化されるブロックチェーン上の全てのトランザクションのグローバルな台帳を維持し、各ブロックはチェーン内で先行するブロックのハッシュを含む。グローバル台帳は、分散した台帳であり、各ノードは、グローバル台帳の完全なコピー又は一部のコピーを保存することができる。グローバル台帳に影響を与えるノードによるトランザクションは、他のノードによって検証され、グローバル台帳の有効性が維持される。ビットコイン・プロトコルを使用するもののようなブロックチェーン・ネットワークの実装及び動作の詳細は、当業者に理解されるであろう。
各トランザクションは、典型的には、1つ以上のインプット及び1つ以上のアウトプットを有する。インプット及びアウトプットに埋め込まれたスクリプトは、トランザクションのアウトプットがどのように誰によってアクセスされ得るかを指定する。トランザクションのアウトプットは、トランザクションの結果として値が転送される先のアドレスであってもよい。この値は、未使用残高(UTXO)として、そのアウトプット・アドレスに関連付けられる。その後、後続のトランザクションは、その値を消費又は分散するために、インプットとしてそのアドレスを参照することができる。
ノードは、それらの機能に応じて、異なるタイプ又はカテゴリのものであり得る。ノードに関連する4つの基本的な機能:ウォレット、マイニング、フル・ブロックチェーン・メンテナンス、及びネットワーク・ルーティングが存在することが示唆されている。これの機能についてのバリエーションが存在し得る。ノードは1つより多い機能を有していてもよい。例えば、「フル・ノード」は4つ全ての機能を提示する。ライトウェイト・ノードは、例えば、ディジタル・ウォレットに実装されてもよく、またウォレット及びネットワーク・ルーティング機能のみを発揮してもよい。ディジタル・ウォレットは、ブロックチェーン全体を格納するのではなく、ブロックを照会する場合にインデックスとして役立つブロック・ヘッダを追跡することができる。ノードは、TCP/IP(伝送制御プロトコル)等のコネクション指向プロトコルを用いて互いに通信する。
ノードの追加のタイプ又はカテゴリが提供されてもよい:マーチャント・ノード(a merchant node)(本明細書では、しばしば「M-Node」と呼ばれる)。M-Nodeは、トランザクションの高速伝搬に焦点を当てるように設計されている。それらは、完全なブロックチェーンを記憶しても記憶しなくてもよく、マイニング機能を実行しない。その意味で、それらはライトウェイト・ノード又はウォレットに類似しているが;トランザクションの高速伝播を可能にする追加の機能を含んでいる。M-Nodeの運用上の焦点は、未確認トランザクションの迅速な検証と伝播、特に他のM-Nodeへの伝播であり、当該他のM-Nodeから、未確認トランザクションはブロックチェーン・ネットワークの他のノードへ迅速にプッシュされる。この機能を容易にするために、M-Nodeには、管理プロトコルの下でノードに対して許可される可能性のある、進入する及び特に進出する多数のコネクションが許可される。
M-Nodeは、マーチャント・ネットワーク(又は「M-net」)と総称されてもよい。「マーチャント」という用語は「専門的な(specialised)」という意味として解釈されてもよい。M-Nodeはブロックチェーン・ネットワークに統合されてもよい。各々のM-Nodeは、ブロックチェーン・ネットワークにおける特殊なノードであり、M-Nodeの機能を実行できることを保証する特定のハードウェア及びパフォーマンス能力を満たす。即ち、M-netはブロックチェーン・ネットワーク内のサブ・ネットワークと考えられ、ブロックチェーン・ネットワークを通じて分散され得る。M-Nodeは、一つ以上の専用の機能又はサービスを実行するように配置され及び構成されてもよい。
M-netが確実に動作し、所定のセキュリティ・レベルでサービスを提供できるようにするためには、M-nodeはM-net全体の良好な概観を維持する必要があり、従って効率的なルーティング・プロトコルが整っている必要がある。M-nodeが開始トランザクションを受信するたびに、他のノードに加えて、幾つかの他のM-nodeへそれをブロードキャストする必要がある。M-netの状況では、これは複数巡回セールスマン問題(MTSP)の解を見つけることになる。この問題に取り組む解決策は多数存在し、そのうちの1つがM-netで使用されてもよい。M-nodeの各々は何らかの最新の形式でルーティングの最適化を実行する。
幾つかの実装では、M-netは非セントラル化されたIPマルチキャスト・タイプのネットワークとして実装される。即ち、ブロックチェーン・ネットワークへの到来するトランザクションの高速な拡散を可能にするために、マルチキャストが使用されてもよく、トランザクションがM-netを通じて迅速にブロードキャストされることを保証し、次いで全てのM-ノードが、ブロックチェーン・ネットワーク内の他のノードへトランザクションを転送することに焦点を合わせることを可能にする。
マルチキャスト・ネットワーク・アーキテクチャは、情報を受け取ることに関心のある各ノードに対するデータの重複なしに、宛先ノードのグループへのデータの同時分配の可能性を許容する。ノードがマルチキャスト送信を受信することを希望する場合、マルチキャスト・グループに参加し(登録段階)、その後、マルチキャスト・グループ上で送信された全てのデータを受信することができるであろう。IPマルチキャストは、何台の受信機が存在するかについての事前知識を必要とセズに、より大きな受信者集団に拡大することが可能であり、ネットワーク・インフラストラクチャは、1回だけパケットを送信することをソースに要求することによって、効率的に使用される。マルチキャスト・ネットワークの性質のために、(TCPのような)コネクション指向プロトコルの使用は、多数の他のノードとの同時通信に起因して実用的ではない。従って、コネクションレス・プロトコルが使用される。
ビットコイン等の幾つかのブロックチェーン・ネットワークは、ノード・ツー・ノード通信にTCPを使用する。TCPを使用して送信されるデータ・パケットは、順序付けのために使用される関連シーケンス番号を有する。これに加えて、TCPプロトコルは、コネクションを確立する時と終了する時の両方で、3方向ハンドシェイク手順を含む。TCP上で送信されるパケットは、関連するオーバーヘッドと共に到来し、それらは関連するシーケンス番号を有し、3方向ハンドシェイク・プロトコルがある。コネクションを確立するには、128~136バイトが送信され、コネクションを閉じるには160バイトのコストがかかる。従って、パケット伝送におけるハンドシェイクは、高々296バイトのコストがかかる。更に、ノードが新しいトランザクションを受信すると、他のノードに、トランザクションのハッシュを含むインベントリ(INV)メッセージを通知する。INVメッセージを受信するノードは、そのトランザクションのハッシュが以前に発見されているか否かを検査する:発見されていない場合、ノードはGETDATAメッセージを送信することによってトランザクションを要求する。ノードAからノードBへトランザクションを送信するために必要な時間は、
T1=verification+TCP(inv+getdata+tx)
であり、TCP()は、TCPハンドシェイク手順によって導入されるオーバーヘッドを時間の観点から示す。
M-nodeは、ビットコインのように、既存のプロトコルによって強制される他ノードとの通信のためにTCPを使用するように設定されてもよい。しかしながら、それらは、M-nodeからM-nodeへの通信、あるいは、より適切には、マルチキャスト状況においてM-nodeから複数のM-nodeへの通信のために、ユーザ・データグラム・プロトコル(UDP)等のコネクションレス・プロトコルを使用してもよい。TCPとは異なり、UDPはハンドシェイク・プロトコルを含まないので、M-nodeはより速やかにトランザクションを伝播することができる。これは、実際のトランザクションを送信することなく繰り返されるINVメッセージを送信することによって、悪意のノードが他ノードと結びつくことを回避することも可能である。
UDPのライトウェイトの性質は或る種のトレードオフに関連する。誤り検査が少なく、誤り復元も行われない。幾つかの実装では、これらのUDPの制限は、アプリケーション・レイヤの機能として、誤り復元、順序付け、及び再送を実装することによって、アプリケーション・レベルで克服されることが可能である。アプリケーション・レベルで誤り検査を行うことは、ネットワークからオーバーヘッドを排除する。
一例では、ブロックチェーン・ネットワーク上の通常のノードは、マーチャント・ベースの支払いのような、M-netを介して処理されることを望むトランザクションを生成する。それはトランザクションをM-nodeへ送信することができ、M-nodeは次いでマルチキャストを使用してそれを他のM-nodeへブロードキャストしてもよいし、或いはM-nodeのIPマルチキャスト・アドレスを知っている場合には、トランザクションを複数のM-nodeへ直接的に送信してもよい。幾つかの例では、M-netのすべてのM-nodeは単一のマルチキャスト・アドレスのメンバーであり、従って、そのアドレスに送信される全てのトランザクションは、全てのM-nodeによって受信される;しかしながら、場合によっては、M-netに関連する1つより多いマルチキャスト・アドレスが存在してもよく、受信M-nodeは、トランザクションを完全なM-netへ伝搬するために、トランザクションの他のマルチキャスト・アドレスへの更なるブロードキャストが必要か否かをルーティング情報から評価してもよい。
マルチキャストは、全てのM-nodeへの新しいトランザクションの高速な初期伝播を確実にすることを支援する;しかしながら、マルチキャスト・ソリューションは、トランザクション・スループットの増加に起因するブロックチェーン・ネットワークのスケーラビリティ問題に必ずしも取り組んでいない。ネットワークの各ノードは、典型的には、発見されて確認されていないトランザクションを含むメモリプールであって、プルーフ・オブ・ワークを完了するマイナーによって未だブロックチェーンに組み込まれていないメモリプールを維持する。支払処理での使用から生じるトランザクション数の著しい増加は、各メモリプールに格納するトランザクション量を増やす。従って、M-net中のノードは、ほぼ同時に新しいトランザクションを受信することができるが、それらは、大きく且つ急速に変化するメモリプールに関して、記憶能力の制限を有し得る。
この問題に対処するために、M-nodeは、マルチキャストを使用する代替例として、分散ハッシュ・テーブル(DHT)によって実装される共有メモリを使用することができる。
500バイトというトランザクション(TX)の平均サイズ、~10TX/sという伝送レートを仮定すると、M-netは、毎日約400GBの入力データを受信し得る。このデータは全て、未確認トランザクションのメモリプールの中でさまざまな期間にわたって格納されることを要する。従って、M-netは、データを高速に記憶するために、かなりのストレージ及び能力を必要とする。個々のM-nodeそれぞれに過剰に多くの要求を課さないために、M-nodeはDHTを当てにする共有メモリを実装する。各M-nodeが全ての到来するTXを自身のメモリプールに保持する代わりに、各M-nodeは全体のうちの特定の部分と、残りの部分のハッシュ及び関連するキー値とを保持するのみである。
DHTは非セントラル化された分散システムのクラスであり、ノード間のキー・セットのメンバシップ分割を可能にし、所与のキーの所有者に対してのみ効率的かつ最適化された方法でメッセージを送信することができる。ネットワークの各ノードはハッシュ・テーブルのアレイのセルとして見ることが可能である。DHTは、多数のノードを管理するために設計され、新しいノードがネットワークに参加し、古いノードが離脱及びクラッシュする可能性を、共有データの完全性を損なうことなく許容する。DHTは、非セントラル化(中央の権限も中央による調整もない)、スケーラビリティ(システムは何百万ものノードで効率的な動作をする)、及びフォールト・トレランス(システムは信頼性があり、ネットワークに参加、離脱又はクラッシュするノードを管理することができる)を保証する。ネットワークの各ノードは、少数の他ノードとのみ接触し続けることができ、従って、変化があった際又は新しいデータの存在下において、ネットワークはオーバーロードにならない。
同じ概念は、UTXOデータベース、即ちブロックチェーン上のすべての未使用アウトプット力のセットを含むデータベースに適用され得る。UTXOデータベースは、一群のノードの間で内容を共有するために、DHTを使用して構築され得る。
M-netのための共有メモリを実装するために使用され得る多くの可能なDHTアーキテクチャ及びプロトコルがある。一例はPastry(商標)であるが、他にも多くの例がある。Pastry(商標)は、分散システムで情報を格納して転送することが可能なオーバレイ・ネットワークを維持するために設計されたプロトコルである。Pastry(商標)ネットワークの各ノードには、128ビットの識別子が割り当てられ、識別子は(0から2128-1に及ぶ)巡回ノードID空間内のノードの位置を示すために使用される。IDは、ノードがネットワークに参加する場合にランダムに指定される。各ノードは、ルーティング・テーブル、隣接セット(a neighbourhood set)、及びリーフ・セット(a leaf set)を維持する。
ロバストなDHTの寸法決定において考慮すべき1つの要因は、ネットワーク全体のロバスト性と信頼性とを保証するために必要なレプリカの数である。既に述べたように、ノードはネットワークに参加したり立ち去ることが可能であり、このことはデータの利用可能性に影響を与えるべきでない。トランザクションAを格納するノードがネットワークを離れる場合、ネットワークの別の部分でトランザクションAを発見する必要がある。例えばビットコインのような既存のブロックチェーン・ネットワークでは、ネットワークは、ネットワーク内の全ノード数(平均5000レプリカ)に等しい数のブロックチェーン・レプリカを有しているが、このことはスケーラビリティに影響する。
1つのM-net構成では、メモリプールは、全てのM-nodeで完全に複製されるわけではなく、代わりにDHTによって実現される。信頼性を提供するために、DHTは、幾つかのオーバーラップを有するように実装されてもよく;即ち、各トランザクション・データ・アイテムは、1つより多いM-nodeで複製されるが、全てのM-nodeにおいてではない。例として、DHTは、2つのレプリカという最小数を指定するように実装され得る。これは、2つのノードが任意の所与の1時間に一度に落ちる確率をもたらし、これは、次のようなノード間の完全な独立性を仮定している。
Figure 0007208164000001
従って、分散されたメモリプールに新しいトランザクションを格納するためのプロセスは、以下のステップを含み、ここで分散されたメモリプールはDHTを用いて実装される。プロセスは、ノードがM-nodeへトランザクションを送信することを含む。M-nodeは、キー値を取得するために、実装に応じてトランザクション又はトランザクションIDをハッシュする。キー値は、トランザクションが格納されるべきM-node又は複数のM-node(複製されたデータの場合)を指定する。次に、M-nodeはトランザクションを分散されたメモリプールに格納し、このプロセスは、M-net内のM-nodeのキー値及び割り当てられたIDに基づいて、トランザクションが格納されるべき正しいM-ノードへトランザクションをルーティングすることを含んでもよい。M-nodeは、関与するDHTプロトコルに応じて、確認応答を受信してもよい。M-nodeが正規のノードから新しいトランザクションを受信すると、M-nodeはトランザクションの真正を検証するために所定の検証オペレーションを実行することができる。
トランザクションは、トランザクションのキーを生成するためにハッシュされるかもしれない。キーは、現在のM-node以外のノードにあるかもしれない、DHT内のどこにトランザクションが格納されるべきかを示すことができる。M-nodeは、次いでトランザクションが既に動作中のDHTにあるか否かを評価する。各M-nodeは、M-netを構成するM-node間の鍵空間の分割に基づいて、格納されたトランザクションの一部を有する。幾つかの構成では、鍵空間は参加しているM-node間で分割される。この分割は、ネットワークの弾力性(resiliency)のための複製を引き起こすように、オーバーラップを含んでもよい。Pastry(商標)を使用するような幾つかの実装では、各々のM-nodeは固有のキー又はID番号の割り当てを受け、トランザクションは、トランザクションのキー値に対する近接性に基づいて、M-node又は複数のM-node(複製が望まれる場合)に格納されてもよい。M-nodeは、ローカルにトランザクションの格納された部分と、残りの部分のハッシュ値又はキー値とを有し得る。従って、M-nodeは、動作中のローカル・データに基づいて、新しいトランザクションがDHT内にあるか否かを評価することができる。
トランザクションがDHT内にない場合、M-nodeは、動作中に、そのキー値に基づいて、トランザクションをDHTに格納する。一般的な意味においてこれは、put(k,tx)オペレーションの形式をとることが可能であり、kはキー値であり、txはトランザクションである。適用可能なDHTルーティング・プロトコルは、トランザクションが適切なM-nodeへ送信され、そこで保存されることを保証する。DHTは、選択される実装に依存して、分散されたハッシュ・テーブルに関する種々のプロトコルに従って機能することができる。M-netにトランザクションを格納するためのDHTの使用は、全てのM-nodeにトランザクションをルーティングするために、M-net内でINV/GETDATAメッセージを使用することを回避する。
動作中に、M-nodeはこの例では、ブロックチェーン・ネットワークの通常のトランザクション転送プロトコルに従って、ブロックチェーン・ネットワーク内の正規のノードへトランザクションを送信することができる。例えば、通常のノードへの通信は、ノード・ツー・ノード接続のためにTCPを使用してもよい。
ある構成では、M-nodeは、プロセッサ、ネットワーク・インターフェース、及びメモリを含む。M-nodeは任意の適切なコンピューティング・ハードウェアを使用して実現されることが可能であり、そのコンピューティング・ハードウェアは、ネットワーク接続性を有し、本明細書に記載の機能を実行するのに十分な処理及びメモリ・リソースを有する。M-nodeは、本明細書に記載の機能を実装するためのプロセッサ実行可能命令を含んでもよい。幾つかのケースにおいて、プロセッサ実行可能命令はブロックチェーン・マーチャント・ノード・アプリケーションと呼ばれてもよいが、この命令は、ハードウェア及びオペレーティング・システムに応じて、1つ以上のモジュール、アプリケーション、スクリプト、又は他のプログラミング構造で実装され得ることが理解されるであろう。プロセッサはマルチ・コア・プロセッサ及び/又は複数のプロセッサを含んでもよい。
メモリは、部分的には、そのDHTキー値、即ちM-nodeIDに基づいて、DHTベースのメモリプールの割り当てられた部分を含むデータを格納する。この実装例では、メモリはルーティング・テーブル、近隣セット、及びリーフ・セットを更に格納する。ルーティング・テーブルは、M-net内の特定のルーティング宛先のリストを含み、ノードがデータのパケットを受信すると、そのデータを送信する場所を知るためにルーティング・テーブルを参照する。また、ルーティング・テーブルは、各宛先がM-nodeからどれだけ離れているかについての情報を含んでもよい。近隣セットは、例えば近接メトリック(例えば、ピンの待ち時間(ping latency))に基づいて、近接M-nodeに関する情報を含む。リーフ・セットは、数値的に近いM-nodeを含む。複数のM-nodeは、それらのキー値(ノードID)が数値的に近い場合、数値的に近い。メモリは、以下で更に説明されるように、M-nodeレピュテーション・テーブル(an M-node reputation table)を更に含む。
スケーラビリティを提供するために、DHTを使用してメモリプールを実装することに加えて、M-netは、ノードがM-netに参加することを許容する。新しいノードはM-netの既に存在する部分の少なくとも1つのM-nodeのアドレスを有する必要があり、そのため、M-nodeの1つへ参加リクエストを差し向けることができる。M-nodeは、新しいノードを照会することを含み得る所定の検証アクションを実行することができる。例えば、M-netは、M-netがM-nodeに対して指定する、M-netに参加することに関連する一組の最小限の基準を有していてもよい。例示として、基準は、利用可能な最小限の処理リソース、利用可能な最小限の空きメモリ、又は接続要件を含むことができる。
新しいノードを検証するために検証オペレーションが実行されるものが何であれ、M-nodeが完了したと仮定すると、DHTプロトコルがDHTのオペレーションを支配するものが何であれそれに従って、Joinrequest()をDHTへ転送する。次に、DHTは、新しいノードと通信し、ルーティング・テーブル、キー値(ノードID)、及び任意の他のデータを提供し、新たなノードがM-net上の新しいM-nodeとして機能することを可能にする。
ノードがM-netに参加し得ることの容易性は、悪意のノードがネットワークに参加し得るという脆弱性を生み出すことが理解されるであろう。潜在的な悪意のノードを識別して隔離するために、1つの構成は、ノードの挙動ランキングを追跡及び更新するために使用されるM-node評判テーブルを格納するM-nodeを提供する。新しいノードがネットワークに参加すると、ノードIDフィールドによって示されるようにして、そのノードはM-node評判テーブルに追加され得る。テーブルは、幾つかの実装において、参加時間を更に含んでもよい。テーブルはそのM-nodeに関するスコア及び格付けを含む。
スコアは、特定の行動メトリックに基づいて上下に調整され得る。例えば、M-nodeがトランザクションを転送することに失敗したり、一定期間にわたってサイレントのままであったり、トランザクションではないと判断されたトラフィックでM-netを溢れさせたり、あるいは、否定的な振る舞いに関わっている場合、そのランキングは、落とされたり又は減少させられたりする。ノードのスコアがあらかじめ設定された最小値を下回る場合、ノードはM-netから除外されるかもしれない。
特定のM-nodeで維持されるM-node評判テーブルは、完全なM-netではなく、その近隣のスコアを追跡することに限定されてもよい。従って、新しいM-nodeが時刻tでネットワークに参加する場合、その近隣のM-node評判テーブルは、新しいノードについての情報を含んでおらず、その時点tから、それらは、ノード・レジスタ・テーブルに情報を格納する新しいノードの評判を構築し始める。例えば、新しいノードがサイレント・ノードである場合、それはネットワーク上で受け取る情報を転送しないことを意味し、全ての隣接者は、例えば新しいノードのIDに負の値を割り当てるなど、各自それぞれのM-node評判テーブルにこの挙動を記録し始める。ある時間t+nの後、新しいノードに気付いている全てのノードのM-node評価テーブルが負の値を含んでいる場合、ノードは新しいノードを分離し、それをネットワークから禁止することを決定し得る。
M-netの分散されたメモリプール内のトランザクションは、確認される前、即ちブロックチェーンに追加され確認されるブロックに組み込まれる前に、かなりの時間待つかもしれない。ブロックはそれより上のブロックチェーンに十分な数の後続のブロックが追加された場合に「確認された」とみなされ、その結果、異なる枝又はフォークに変化するようにチェーンの成長を逆転させ及びブロックを除去することは計算上不可能であるようになる。
メモリプールのサイズと柔軟性とトランザクションの量とに起因して、ビットコインのような或るブロックチェーン実装よりも長い間、所与のトランザクションが確認されない可能性がある。従来のビットコイン実装では、トランザクションは、それがブロックに組み込まれるとすぐに、メモリプールから取り除かれる。これは、ブロックが、オーファン・ブロック(親ブロックの無いブロック)となった場合に、ブロック内の全てのトランザクションがネットワーク上で再送されることを意味する。これは、非現実的であるかもしれず、また、高速トランザクション・ネットワークの場合、特定のトランザクションを確認するために長い遅延を生じるかもしれない。
従って、幾つかの実装において、メモリプールは、トランザクションが組み込まれているブロックのコンファメーション数、即ちトランザクションが組み込まれたブロックに続くブロックチェーンに追加されたブロック数を追跡することができる。あらかじめ決められた数のコンファメーションが行われた後にのみ、トランザクションはメモリプールから除外される。所定の数は、所与の実装に関する4、5、6、7又は任意の適切な数であってもよい。メモリプール・データ入力は、トランザクションIDフィールド、トランザクション・フィールド、及びコンファメーション数(NoC)フィールドを含むように構成されてもよい。別の実装では、NoCを追跡するのではなく、メモリプール・データ入力は、単にブロック番号を記録してもよい。ブロック番号から、ブロックチェーンの現在のブロック番号に基づいて、何回のコンファメーションが発生したかを評価することが可能である。
いったん必要数のコンファメーションが行われると、トランザクションはメモリプールから安全に除外され得る。このようにして、オーファン・ブロックの場合にトランザクションの損失はなくなり、トランザクションは、必要数のコンファメーションの後に、永久的に削除される。
本明細書の以下の部分で説明されるようなソリューションは、上述したような高速検証ノードの修正されたタイプを使用する。新しいフル・ノード構成が説明され、これは、大規模ストレージ能力と改良された動作プロトコルとで強化されたM-node検証アーキテクチャである。M-nodeとストレージ・ノードとは一緒になって新しいフル・ノードのコアを構成する。必要な技術的要件と技術的ソリューションとを含む新しいノード構造が詳細に説明され、持続可能なインセンティブ・モデルが提供される。
ブロック・サイズ及びストレージ条件
現在のブロック・サイズは1Mbである。現在、ブロックは、所謂マジック・ナンバー(常に同じ値)と、ブロックの実際のサイズを示す値と、所謂ブロック・ヘッダと、ブロックに含まれるトランザクションの数と、そして最後に実際のトランザクションのリストとを含むフィールドで構成される。後者は常にコインベース・トランザクションから始まり、これはブロックをマイニングすることに対する報酬を含むトランザクションである。図1にブロックの全体構造が示されている。
ブロック・ヘッダは以下を含む:
1.バージョン番号(4バイト)
2.前のブロック・ヘッダのハッシュ(32バイト)
3.マークル・ルート・ハッシュ(32バイト)
4.時間(4バイト)
5.ターゲット閾値(nビットとしてエンコードされる-4バイト)
5.ノンス(4バイト)
現在、ブロックは約2000のトランザクションを含み、ブロックは約10分ごとに採掘される(10分のブロック時間は、最初のコンファメーション時間とチェーン分割に費やされる時間との間の妥協として設定されている)。これは、理論上最大7トランザクション/秒で、約3.5トランザクション/秒というトランザクション・レートを提供する。対照的に、VISAは約10000トランザクション/秒のレートで動作し、50000トランザクション/秒以上に到達し得る。
競争支払システムを構築するためには、現在の制約についての何らかの迂回策が必要であることは明らかである。10分間のブロック時間は十分に確立されているので、ブロック・サイズ、即ちブロックチェーン自体の変更を考慮することが必須である。本明細書では、例えば毎秒約50000トランザクションを処理し得るスケーラブルなソリューションが説明される。
現在のブロック・サイズの増加、あるいは制限の完全な撤廃でさえそれらは、多くの議論の的となっており、時には論争の話題となっている。現在のサイズを維持すること及びそれを増加させることは何れも多大な恩恵とトレードオフをもたらすので、双方の側に有力な主張があるように思われる。
トランザクション・レートをrと仮定すると、我々は必要なブロック・サイズを計算することができる。以下、(平均して)10分のブロック時間が仮定される。そこで、T(r)をブロック当たりのトランザクション数とする。
T(r)=r・6・10 block-1
Txがバイト単位の平均トランザクション・サイズである場合、ブロック・サイズB(r,sTx)は次のように表すことが可能である。
B(r,sTx)=sTx・T(r)=sTx・r・6・10
従って、r=50000Txs/s及びsTx=500バイトであるシナリオを考察すると、簡単なバック・オブ・エンベロープ計算は次のようになる。
Figure 0007208164000002
これは、O(10)Gb/yearというストレージ条件を導く。このサイズのブロックでは、ブロック伝搬とストレージの両方に対してわずかに異なるアプローチが必要であることは明らかである。以下の表1は、トランザクション・レート、平均トランザクション・サイズ、ブロック・サイズ、及び月次及び年次の必要なストレージ・スペース量を示す。
Figure 0007208164000003
表1:トランザクション・レート、平均トランザクション・サイズ、ブロック・サイズ、及び必要な月次及び年次ストレージ・スペース量の関係
新たなビットコイン・ネットワーク
ビットコイン・ネットワークに対して提案するアーキテクチャが図2に示されており、これは、ユーザがトランザクションをサブミットした時点からそれがブロックチェーン上で終了するまでのステップを示す動作図を示す。
特殊な検証ノード(分散ハッシュ・テーブルDHTによって自身の間で共有メモリプールを維持する)がトランザクションを受信し、それらを検証し、それらをメモリプールに割り振るシステムが提供される。その後、検証ノードは、有効なトランザクション・ハッシュのリストをマイナーに提供する各自のサービスを提供する。マイナーは、これらのハッシュに基づいてプレ・ブロック(ブロック・スケルトン)(pre-blocks(block skeletons))を組み立て、ハッシュ・パズルを解こうとする。パズルのソリューションが発見されると、勝利したマイナーはブロック・スケルトンを検証ノードへ返送する。これらは、ブロックを検証し、ブロックが保存されることを保証する。最初に、検証ノードがブロック自体を格納することは可能であり、実現可能である。ブロック・サイズが最終的にサイズの特定の閾値を超えると、検証ノードは:a)独自のストレージ機能を拡張するか;又はb)特殊なストレージ・ノードに格納することをアウトソースする。本明細書では2つのアーキテクチャが後に議論される。
新しいフル・ノード
O(10)GBというオーダーのブロック・サイズでは、ブロックチェーンのフル・イメージをホスティングするためのストレージ容量を提供するためにPCタイプのノードを当てにすることは、もはや実行不可能であるように思われる。その代わりに、O(1)PB又はより多くのストレージを提供する施設が必要とされる(表1参照)。そこで問題は、ネットワークの分散、非セントラル化、非トラスト性を維持しながら、新しいブロックを収容するシステムを構築することである。
2種類の完全なノード構造と、これらの2種類の組み合わせが考えられる:
1.関連するペタバイト・ストレージ・ラックを有する検証ノード
2.現在のビットコイン・ネットワークそれ自体に非常に類似する、内的に非セントラル化された分散されたピア・ツー・ピア(P2P)シングル・ノード・ネットワークに基づく関連ストレージ・プールを有する検証ノード
3.1及び2の組み合わせ
提案されるソリューションは、現在のビットコイン・ネットワークで動作する所謂フル・ノードに類似するノードを導入することにより、ブロックチェーンの分散された非セントラル化された記録を常に維持する問題を解決しようと試みるが、現在のビットコイン・ネットワークとは対照的に、ブロックのサイズとトランザクション数の増加に伴ってスケーリングできる能力を有する。
この相違は純粋に構造及びハードウェア関連の問題に限られない。書き込み時に動作する家庭用PCベースのフル・ノードとは対照的に、ここで提案される新たなノードは特殊なノードである。それらはかなりの額の投資を必要とし、従ってインセンティブの仕方は非常に異なる。スケーラブルなパラダイムでは、M-node(検証ノード)と新たなフル・ノード(検証ノードとストレージ・ノードとの組み合わせ)との両方が、それらのサービスに対する補償を期待している。
スペクトルの他方端では、非セントラル化され分散化されたストレージ・ソリューションがあり、その大部分は個人のノードで構成される。良い例は、Storj(Wilkinson et al.,2016)、Sia(NebulousLabs)及びメイドセーフ(Maidsafe)である。Storjの場合、その機能は、参加者がストレージ・スペースの提供に対して報酬を得ることに基づいている。
上述したように、ペタバイト(Pb)ラックとピア・ツー・ピア(P2P)ストレージ・システムの両方から構成されるスーパー・ノードを想定することも可能である。
ビットコイン・エコシステムは、非セントラル化された方法で分散されたブロックチェーン全体の複数のレプリカの存在に大きく依存しているので、全てのフル・ノードが補償されることは重要であることは明らかである。これは、本質的には勝者が全ての賞を獲得するゲームであるマイニングとは非常に相違する。マイナーは(勝ち取った)ブロックを当てにして公のブロックチェーンにたどり着くので、全てのノードを格納することに報いることは、彼らの利益になる。
ノードはスーパー・ノードとして機能するプールにグループ化される。ブロックチェーンの分散性を維持するためには、そのようなスーパー・ノードが一定数(100以上)存在しなければならない。スーパー・ノードは接続されるがオーバーラップしていない。
技術的要件
上述したように、新たなフル・ノードを議論する場合に考察されるべき2つの全体的に相違するアーキテクチャが存在する(表2参照)。
新たなフル・ノードは、2つのタイプのストレージを維持する必要がある:
1)メモリプールのための分散されたハッシュ・テーブル(DHT)メモリ/ストレージのようなランダム・アクセス・メモリ(RAM)
2)ブロックチェーンのストレージのような永続的なテープ/ディスク
上述したように、r=50000Tx/sのトランザクション・レートに関し、ブロックはO(10)Gbであるように期待され、これは、
~365×24×6×15Gb=7.9・10Gb=0.8Pb/yr
という年次ストレージ要求を意味する(表1参照)。
表2は現在のフル・ノードと将来のフル・ノードとの間の比較を示す:
Figure 0007208164000004
同時に、ラック/クラスタはメモリプールを維持する必要がある。これは速やかなブロック復元を許容する。メモリプールの必要なサイズを評価することはより困難である。現在、約1メガバイト(~1Mb)のブロック・サイズ、毎秒約4トランザクション(~4Tx/s)で、メモリプールで待機しているトランザクションの合計サイズは、2ないし約70メガバイト(~70Mb)の間で揺れている。図3は、コンファメーションのためにメモリプールで待機しているトランザクションの合計サイズを示すグラフである。
上述したように、大量のデータを保存することができる、基本的に異なる2つの構造、及びそれらの組み合わせを想定している。2つの構造は図4及び図5に示されている。図4は、内的にセントラル化されたストレージ装置へのアクセスを有する複数のノードを含む構成を示す。図5は、各ノードが分散されたメモリプールと分散されたストレージ装置との両方の一部である構成を示す。図4に描かれたアーキテクチャは、幾つかの検証ノードを所有及び維持する、より大きなエンティティに適しているように思われ、その検証ノードは全てエンティティの自身のストレージ装置に対するアクセスを有する。これに対して、図5に示されるアーキテクチャは、完全に非セントラル化されている。これは、十分なストレージ容量を有する家庭で所有されるPCのような、共有された分散ストレージ・プールに参加することを望む個々のノードに適したソリューションである。このために使用される基本的なストレージ技術は既に存在している(例えば、Storj、Sia、MaidSafe)。
新しいフル・ノードがビットコイン・ネットワークにどのように適合するかを可視化する1つの方法が図6に示されており、図6は検証ノードがストレージ・プールのメンバーであるネットワーク構成を示す。プールは共に、非セントラル化された分散されたビットコイン・ネットワークを含む。
フル・ノード・オペレーション
ラージ・ブロックのシナリオでは、単にスペース要件に起因するだけではない別の状況に直面する。メモリプールは、ブロックに相当するもの、即ち約15ギガバイト(~15Gb)、好ましくは次に掘削されるブロックに対する等価量を収容できるべきである。これは、考慮する必要のあるオーバーヘッドと組み合わせる必要がある。
1)メモリプールは他の検証ノードと同期する必要がある。これは可逆ブルーム・フィルタ・ルックアップ・テーブル(Invertible Bloom filter Lookup Tables)を交換することを含む(Michael T.Goodrich,2011)
2)IBLTは精査され、欠落しているトランザクション(Tx’s)が取得される
3)追加的に取得されたTxは検証されることを要する
4)マイナー及び他のフル・ノードから受信されたブロック・スケルトンに基づいてブロックを組み立てる。
新たなフル・ノードは、最新のメモリプールを保持する。これは、マイナー、他の検証ノード及び新たなフル・ノードともに交換されるIBLTによって行われる。
マイナーは以下のものにより構成されるブロック・スケルトン(タプル)を送信する:
1.ノンス,n
2.IBLT
3.コインベース・トランザクション
これに基づいて、新たなフル・ノードは相応して(特定のルール・セットに従って)トランザクションを注文し、新たに採掘されたブロックを組み立てる。次に、新たなフル・ノードは、他の新たなフル・ノードにスケルトンを伝搬するだけでなく、各自自身のストレージにブロックを格納する処理を進める。プロトコルは本明細書で後に更に詳細に説明される。
インセンティブ
特定のコンフィギュレーションの1つの重要な特徴は、新たなノード構造とサービスの提供を奨励するためにシステムにインセンティブを構築することである。ブロックチェーンを格納することに付随する多大なコストに起因して、インセンティブが必要とされる。図7は新たなフル・ノードの機能を示す。新たなフル・ノードは、主に以下の2種類のサービスに対して報酬を与えられる:
1)検証されたトランザクションのリストをコンパイルし、マイニングに備える。トランザクションのハッシュ値(Merkle root)がマイナーへ送信され、そのマイナーはリストを選択してブロックを採掘する。
2)勝利したマイナーは採掘したブロックのスケルトンを幾つかの新たなフル・ノードへ送信する。スケルトンはコインベース・トランザクションを含み、以下のa~c.を含む:
a.マイニング報酬
b.検証されたリストを提供する支払メカニズムとして使用されるコミットメント・スキームの一部であるシークレット
c.ブロック検証、及び/又はブロックチェーンにおけるブロックのストレージに対する支払。
[トランザクション]検証ノードは、有料システムによってトランザクションの検証に関して払い戻しを受ける。受ける側の検証/新たなフル・ノードは以下のうちの1つ以上に関して報酬を受ける:
1)検証されたトランザクション(Tx)ハッシュのリストをマイナーに提供すること(上記b.参照)。
2)ブロック・スケルトンからブロックを組み立て直すこと(「定額」料金)。
3)ブロックのサイズ(「MBストレージ」単位の支払)。
インセンティブは100ブロック・コンファメーション時間T100の間にある。
1)マイナーは彼らの報酬を請求するためにt~T100の間待機する必要がある。
2)検証ノードは、ブロック中のTxを検証することに関して彼らの手数料を受ける前に、t~T100の間待機する必要がある。
3)新たなフル・ノードは、ブロック構築手数料及びサイズ依存性ストレージ支払を受ける前に、t~T100の間待機する必要がある。
従って、100ブロックのコンファメーション時間は、スケルトン・ブロック(支払いを含む)を、ある範囲内の新たなフル・ノードへ伝播させるために必要なインセンティブをマイナーに提供し、新たなフル・ノードは、スケルトン・ブロックを他の新たなフル・ノードに伝播するように刺激されるであろう。
また、ブロックに含まれることを希望する(トランザクションの)リストをマイナーが自由に選択することは、指摘されるべきである。かくて、マイナーがコミットメント・トランザクションによって選択及び購入することが可能な検証されたトランザクションのリストをまとめることによって、競合する検証ノードを含む市場を想定し得る。
改訂されたマイニング
ビットコイン・エコシステム(The Bitcoin ecosystem)は採掘の過程に依存する。マイナーは、トランザクション(Txs)をメモリプール(又はここで想定されるように、特殊な検証ノード)から収集し、それらをブロックに組織し、ハッシュ・パズルを解く解(ノンス)を発見しようと試みる。ブロック・ヘッダは、ブロックチェーンにおける前のブロックのハッシュ、トランザクションのマークル・ツリーのルート(根元)、及びマイナーによって含められるノンスを含む。パズルを解くことは、前のブロック・ハッシュ及びマークル・ルートと連結されたノンス(反復的に選択される)の二重SHA256ハッシュを計算すること、及びそれがいわゆる困難性ターゲットより小さいか否かを検査することから構成される。仮にそれがノンスを下回るならば、パズルは解決されており、仮にそれを上回るならば、ノンスに対する反復が続く。これは、新しいパラダイムでも変わらずに残る。問題をもたらすものは、非常に拡大されたブロック・サイズ、及びネットワークを横断する採掘されたブロックの分布である。Gbサイズのブロックでは、ネットワークにおいてブロック全体をブロードキャストすることは必ずしも必須でない。
むしろ我々は以下のステップに従うソリューションを提案する:
1.マイナーが、検証されたトランザクションのリストを、検証/M-node及び/又は新たなフル・ノードから受信する。
2.マイナー自身は所定の順序付けの慣例に従うTxハッシュ値の各自自身のメモリプールを運営してもしなくてもよく、そのような順序付けの一例は以下に示されている。
[https://www.cryptocoinsnews.com/bitcoin-in-bloom-how-iblts-allow-bitcoin-scale/]
3.マイナーはノンス,nを決定することによってハッシュ・パズルを解く。
4.次に、ハッシュ・ツリー(マークル・ツリー、ここではHTとして言及される)が計算され、ツリーのルートが格納される(次のセクションを参照されたい)。
5.TxsのこのリストはIBLTを作成するために使用される。IBLTは(例えば、メモリプールの)2つのセットの間の内容の相違を算出し、2つのセットをリコンサイル(reconcile)するために使用されることが可能である。
6.タプル{n;IBLT;コインベースTx:HTルート}が検証/M-nodeへブロードキャストされる。
7.新たなフル・ノードは、ブロックチェーンに関するストレージ及びメモリプールに関するDHTを運用する。
8.プールは、タプル{n;IBLT;コインベースTx:HTルート}に基づいてブロックを組み立て直し、a)ブロック自身を格納することにより、又はb)特殊なストレージ・ノードに格納することにより、ブロックチェーン上でブロックを記録する。
マイナー間の競争回避
マイナーは、幾つかの検証ノードで構成される市場から、検証済みトランザクションのリストを選択することができるであろう。特に断りのない限り、マイナーは、彼らの可能性のある収益を最大化するリストを選択するであろうと仮定することは妥当である。注意深い読者は、これはマイナーが主に同じノードから同じリストを選ぶことにつながり得ることを指摘するかもしれない。これは、何人ものマイナーが同じブロックを採掘しようとして、互いに競い合う状況を招くであろう。このことは、最大のハッシュ能力を有するマイナーに有利に働くであろう。
我々は、ブロック・ヘッダに追加フィールドを追加することを提案する。このフィールドは、各マイナーによって選択される乱数を含む。これは、各マイナーが異なる開始点から出発することを保証し、従って、そのブロックの解を探すことが単に、ハッシュする能力の問題に落とされてしまうことを防止する。これは、マイナーが同じような、しかし個々に選んだ、僅かに異なるブロックを採掘する傾向がある現在の状況に似ている。
プロトコル
ここで、新しいフル・ノードを動作させるために必要なプロトコルを説明する。提案したシステムが、関わりのあるノード(検証者、採掘者、新しいフル・ノード・・・)のメモリプールを機能させるためには、トランザクションの順序付け規則に従うべきである。ここで、ギャビン・アンダーセンによって提案された正規順序(the canonical ordering)を使用することを提案する。そこでは順序付けはブロック内のトランザクションのリストに関係しているが、ここで我々は、全ての検証ノードと新しいフル・ノードが、それらのメモリプールに同じ規則を使用するというアイディアを提示する。
規則は以下のように要約されることが可能である:
1)前のトランザクションのハッシュに関して昇順にトランザクションを並べる。
2)並べられたリストから、後続のトランザクションに依存しない最初のトランザクションを追加する。
前述したように、ブロックは所謂マークル・ルート・ハッシュを含む。これは、コインベース・トランザクションを含む全てのトランザクションをハッシュし、その後、マークル・ルート・ハッシュに到達するまで、ハッシュの連結をハッシュすることによって生成される。マイナーがコインベース・トランザクションを生産しているという事実がなければ、検証ノードはマークル・ツリー全体、従ってマークル・ルートと対応するハッシュを計算し得る、ということは明らかである。
ここで、次の方法の手続きを用いて計算されるマークル・ツリーを提案する:
検証ノードはリトル・マークル・ルート(a Little Merkle Root)を計算する。手順は、幾つかの例外と共に、標準的なマークル・ルートを計算する場合と同じである:
1)コインベース・トランザクションは省かれる。
2)いわゆる通信トランザクションが含められる。
3)マイナーはコインベース・トランザクションを生成し、それをリトル・マークル・ルート・ハッシュに連結し、マークル・ルート・ハッシュを生成する。
これは、新しいマークル・ツリー構造を示す図8に示されている。これは現在のプロトコルに対する修正を為すことに留意を要する。
ブロック・ヘッダに対する修正
上述したように、我々は、マイナーにより選択された乱数を含む追加のフィールドを、ブロック・ヘッダに追加することを提案する。従ってハッシュ・パズルを解くことは、以下のように変わる:
Figure 0007208164000005
Prev.Block Hash:赤
Marke Root:緑
nonce:青
RND:紫
従って我々は乱数を含む追加フィールドにより、採掘された新しいブロックのブロック・ヘッダが強化されることを提案する。ブロック・ヘッダは以下を含む:
1.バージョン番号(4バイト)
2.先行ブロック・ヘッダのハッシュ(32バイト)
3.マークル・ルート・ハッシュ(32バイト)
4.時間(4バイト)
5.ターゲット閾値(nビットとしてエンコードされる-4バイト)
6.ノンス(4バイト)
7.乱数(4バイト)
検証→マイナー
検証ノード:
○ 要求に応じて、検証ノード(新しいフル・ノードであってもなくてもよい)が、採掘される検証済みトランザクションのリストを準備する。
○ 検証者ノードがコミットメント・トランザクション(a commitment transaction)を作成する。
○ 所謂リトル・マークル・ルート(前節参照)が、包含されるコミットメント・トランザクションとともに算出される。
○ 検証者ノードが2つのIBLT:
1)ブロック内の全てのトランザクションについて(IBLT1);及び
2)ブロック内の全ての対応するTRxIDについて(IBLT2)
を準備する。
○ 検証者ノードがマイナーへ:
1)リトル・マークル・ルート
2)IBLT1
3)IBLT2(オプション-マイナーが自身のTxID-/メモリプールとともに動作する場合のみ)
4)先行ブロック・ハッシュ
5)上記のハッシュ・チェックサム
を送信する。
マイナー:
○ 検証ノードからデータを受信すると、マイナーは、コインベース・トランザクションを作成する処理を進め、これは、マイニングに対する報酬、及び新たなフル・ノードのブロック検証/ストレージに対する報酬(マイナーが採掘されたブロックを送信することを希望する送付先)を含む。更に、コインベース・トランザクションは、コミットメント・トランザクションにおけるシークレットと一致する、シークレットを有するアウトプット・フィールドを含む。
○ マイナーは、検証者ノードから受信したリトル・マークル・ルートを使用し、それをコインベース・トランザクションと結合し、マークル・ルート・ハッシュを作成する。
○ マイナーは今やハッシュ・パズルを解き始めるために必要な全ての情報を有している。
○ マイニングは上述した方法で進行する。
マイナー→新たなフル・ノード
マイナー:
○ ブロックがマイニングされると、マイナーは以下のものを新たなフル・ノードのリストに送信する:
○ ノンス(パズルに対する解),n
○ コインベース・トランザクション
○ ブロック・ヘッダ
○ マークル・ルート
○ リトル・マークル・ルート
○ IBLT1
○ IBLT2(オプション)
○ ハッシュ・チェックサム
新たなフル・ノード:
○ 適切な報酬がコインベース・トランザクションにあるか否かを検査する。
○ チェックサム(ハッシュ)を計算することにより、受信データは一貫していることをノードが確認する。
○ ブロック中のトランザクションがメモリプールに存在することを確認するためにノードがIBLT1を利用する。
○ IBLT1を利用してメモリプールを照会し、ノードがブロックを組み立てる。次いでブロックは格納される(新たなフル・ノード及びストレージに関するセクション参照)。
○ マイナーから受信したデータ他の新たなフル・ノードへブロードキャストされる。
カスタマイズされたトランザクション・リスト
我々は、検証されるトランザクションのマーケットがマイナーのニーズに適合するような状況を想定している。マイナーは、彼らの可能性を最大化するリストを選ぶ傾向があり、検証中のM-nodeは、そのような傾向でピック・アップを行うであろう。
2つ以上のリストからトランザクションを組み合わせることにより、マイナーが自身のブロックをカスタマイズすることを希望するケースがあるかもしれない。2つのIBLT間の相違を計算することにより、2つのセット間のセット調停(set reconciliation)を行うことが可能である。次に、マイナーは、差異を含むIBLTを提供ノードの1つへ返送し、このようにして、リストを作成するのに必要な情報を取得し、このリストは、両方のリストにある全てのトランザクションを含む。
マイナーが幾つかのリストに基づいて各自自身のリストを作成したい場合には、さらなる課題が生じるように思われる。ここでは、様々な点について簡単に述べる。
マイナーが様々な検証ノードからのリストを組み合わせるならば、マークル・ルートがどのように組み合わせられるべきかは不明確である。ここで我々は以下を提案する:
個々のリトル・マークル・ルートについてのビッグ・リトル・マークル・ルート(a Big Little Merkle root)を構築すること;及び
ビッグ・リトル・マークル・ルートをコインベース・トランザクションと結合すること。
追加費用は、リスト/ブロックに追加される追加トランザクションの量に比例しない。様々なメモリプールがかなりオーバーラップするであろうと仮定することは妥当であるので、リストを組み合わせることは、異なるリストから少数の(相対的に言って)トランザクションを追加することになるであろう。しかし、リストを組み合わせるために、マイナーは各検証ノードから(コミットメント・トランザクションによって)全リストを「購入」しなければならないであろう。これがマイナーにとって有益なアプローチとなるか否かは、まだ分からない。
幾つかの検証ノードからのリストを組み合わせることは、マイナーと検証ノードを提供する各々との間にコミットメントを必要とする。マイナーによるこのシステムの悪用を想像することが可能である。現在のところ、全てのコミットメント・トランザクションがブロックに行き着くことを強制するルール/プロトコルは存在しない。1つの可能性は、検証ノードが各ブロックをチェックし、トランザクションを含むブロックを拒否できることである。
サマリー
今日のビットコイン・ネットワークは、計算労力という意味で、非常にマイナーを中心にしている。トランザクション量の大幅な増加により、これは必ずしも実現可能であるとは限らない。本明細書で説明されるソリューションは、さまざまな作業を、それに応じて特化されたノードに委託することにつながり、マイナーはよりいっそう自ら専門化されることになる。検証されたトランザクションのリストをまとめ、ブロック・スケルトンに基づいてブロックを再構築し、保管することは、全てかなりのリソースを必要とする機能である。従って、ビットコイン・ネットワークの構造は変化し、それに伴ってインセンティブも変化すると予想される。これらの問題について本明細書で詳細に説明した。
本明細書で導入される新たな要素の中で以下の事項に言及することができる:
○ 新たなタイプのノード構造。本明細書で新たなフル・ノード又はスーパー・ノードと呼ばれ、検証するM-nodesに対する拡張であってもなくてもよい。
○ ノードは、検証ノードからマイナーへ及びマイナーから新しいフル・ノードへの双方についてのGbサイズ・ブロックのブロードキャストを効果的に可能にするプロトコルで動作する。
○ ブロックチェーンを記憶するための2つの全体的な記憶構造。これは、提案される新しいフル・ノードの一部であってもなくてもよい。
○ 検証されるトランザクションの前ブロック・リストのマーケットの作成、及びブロックの組み立て及び格納を可能にするインセンティブ・モデル。
○ マイナーが各自自身のメモリプールを維持する必要性から解放する新たなマークル・ツリー構造。
○ 乱数を有するブロック・ヘッダの追加フィールドの追加。乱数は、マイニング活動が単にハッシュ処理能力に基づく競争になってしまうことを回避するために、マイナーによって選択される。
○ 検証は特殊なコミットメント・トランザクションを利用して報いられる。
ブルーム・フィルタ及びIBLTs
このセクションでは、いわゆる「ブルーム・フィルタ(Bloom filters)」の特性と、「可逆ブルーム・ルックアップ・テーブル」と呼ばれるものへの拡張とを要約する。
最も簡易な形式では、ブルーム・フィルタはアレイである。アレイはそれに関連付けられる2つのパラメータ、M及びkを有する。Mはアレイのビット数であり、kは以下の数式のような異なるハッシュ関数Hの数であり、
Figure 0007208164000006
ここで、S16は16進文字列の空間であり、そこにハッシュ関数が作用する。トランザクションTxが集合に属するか否かを決定するために、ブルーム・フィルタが作成され、我々はH(Tx)・・・H(Tx)を計算し、次いで対応するビットがアレイの中で1に設定されているか否かを検査する必要がある。図9はブルーム・フィルタを作成する際のワークフローを示す。
1つ以上がそうでない場合、Txは確実に対象集合には無い。しかしながら、ブルーム・フィルタは偽陽性(false positives)を許容する。これは、ビットを1に変化させるハッシュ関数の確率が、
p=1/|アレイのサイズ|=1/M
であるという事実に由来する。従って、所謂
Figure 0007208164000007
により、所与のハッシュ関数によってビットは1に設定されない。従って、k個のハッシュ関数が存在する場合、所与のビットが1に設定されない確率は次のようになる:
Figure 0007208164000008
n個の要素が挿入される必要がある場合、それは次のようになる:
Figure 0007208164000009
ブルーム・フィルタの明らかな欠点の1つは、任意の特定の順序を追跡せず維持しないことである。フィルタリングされるべきアイテムのインデックスを維持することを希望する場合、我々はフィルタの機能を拡張する必要があることは、直ぐに明らかになる。ここでは、可逆ブルーム・フィルタ(IBFs)及び可逆ブルーム・ルックアップ・テーブル(IBLTs)加わる。
アレイにおいてビットをアクティブ化するだけではなく、鍵のXOR合計、ハッシュ値(前述のように)、及び全体のカウンタが、IBFの各フィールドに格納される。この手順は図10に示されており、図10は、IBF/IBLTにおいてトランザクションがどのようにエンコードされるかを示すワークフローを示す。
アプリケーション
2つのノードN及びNを有し、それぞれがメモリプールm及びmを維持していると仮定する。各メモリプールは16進文字列全体S16のうちの要素を含む。更に、Andresenにより提案され、本明細書で上記で概説されているように、メモリプールは順序規則(an ordering convention)に従っていると仮定する。NがmをNへ送り、今やNは2つの方法でセット・リコンシリエーションにアプローチすることができる:
1)Δm=m-mにより集合の差分を計算する((David Eppstein,2011),(Michael T.Goodrich,2011)を参照されたい)。
2)mにおけるトランザクションに関して反復を行い、Nのメモリプールに存在するか否かをチェックする。
IBLTは少なくとも2つの目的で使用され得ることが分かる:
1)各自のメモリプールに既に有しているトランザクションに基づいて、ノードに、採掘されたブロックをアセンブルさせ、それらが有していないブロックを識別及び取得することを支援すること。
2)異なるノードに所属するメモリプールの間で所定レベルの同期を維持すること。
トランザクションはビットコインを転送することができるが、ユーザは、情報、契約、及びトークン等の本明細書に記載される方法及びシステムを使用して、他のリソースを交換することができることが理解されるべきである。トークンは、トークンに関連付けられたスマート契約に従って資産又はリソースを表し、その結果、トークンのコントロールが、資産又はリソースのコントロールをもたらす。スマート契約それ自体はブロックチェーン外で格納されてもよいし、あるいは1つ以上のトランザクションの中に格納されてもよい。
リファレンス
An Integrated World.(n.d.).Retrieved from https://www.anintegratedworld.com/whats-in-a-block/
David Eppstein,M.T.(2011).What’s the Difference? Efficient Set Reconciliation without Prior Context.ACM. maidsafe.(n.d.).Retrieved from github.com: https://github.com/maidsafe/Whitepapers
Michael T.Goodrich,M.M.(2011).Invertible Bloom Lookup Tables.Communication,Control, and Computing(Allerton),2011 49th Annual Allerton Conference on.
NebulousLabs.(n.d.).Retrieved from github.com: https://github.com/NebulousLabs/Sia O(1) Block Propagation. (n.d.).Retrieved from github.com:https://gist.github.com/gavinandresen/e20c3b5a1d4b97f79ac2
Wikipedia.(n.d.).Retrieved from https://en.wikipedia.org/wiki/Distributed_hash_table
Wilkinson et al.(2016, December 15). Retrieved from https://storj.io/storj.pdf
上述の実施形態は本発明を限定するものではなく、本発明を例示するものであること、当業者は、添付の特許請求の範囲によって定義される本発明の範囲から逸脱することなく、多くの代替実施形態を設計することが可能であることに留意すべきである。特許請求の範囲においては、括弧内に付された如何なる参照符号も、特許請求の範囲を限定するものと解釈されてはならない。「~を含んでいる」及び「~を含む」等の用語は、何れかの請求項又は明細書全体に列挙されたもの以外の要素又は工程の存在を排除しない。本明細書において、「~を含む」とは、「~を含む、又は~から構成される」ことを意味し、「~を含んでいる」とは、「~を含んでいる、又は~から構成されている」ことを意味する。要素の単独的な参照は、複数のそのような要素の参照を除外するものではなく、その逆もまた同様である。本発明は、幾つかの別個の要素を含むハードウェアによって、及び適切にプログラムされたコンピュータによって実施され得る。幾つかの手段を列挙する装置クレームにおいては、これらの手段の幾つかは、1つの同一ハードウェア・アイテムによって具体化されてもよい。複数の事項が相互に異なる従属請求項で引用されているという単なる事実は、これらの事項の組み合わせが有利に使用できないことを示すものではない。

Claims (24)

  1. ブロックチェーン・ネットワークのノードに対するコンピュータで実現される方法であって、前記ブロックチェーン・ネットワークにおいて、検証するノードはマイニングのノードとは区別され、当該方法は
    複数の検証されたトランザクションに対応する採掘されたデータを前記ブロックチェーン・ネットワークから受信するステップ;
    前記採掘されたデータに基づいて複数のブロックを組み立てるステップ;及び
    ブロックチェーンにおいて格納するためにストレージ・エンティティへ、組み立てられたブロックを送信するステップ;
    を含む方法。
  2. 前記ブロックチェーン・ネットワークから受信される前記採掘されたデータは、前記検証されたトランザクションに対応するブロック・ヘッダを含む、請求項1に記載のコンピュータで実現される方法。
  3. 前記採掘されたデータは、前記採掘されたデータに基づいてブロックを組み立てることに対する見返りとしてディジタル資産のトランザクションを含む、請求項1又は2に記載のコンピュータで実現される方法。
  4. 前記採掘されたデータは、組み立てられたブロックの格納に対する見返りとしてディジタル資産のトランザクションを含む、請求項1-3のうち何れか1項に記載のコンピュータで実現される方法。
  5. 前記ディジタル資産を受け取る前に、最低限のブロック数に関連する期間tの間待機する条件を更に含む請求項3又は4に記載のコンピュータで実現される方法。
  6. 前記採掘されたデータに基づいて複数のブロックを組み立てる前記ステップが、各ブロックが少なくとも2メガバイトのサイズを有するラージ・ブロックを組み立てるステップを含む、請求項1-5のうち何れか1項に記載のコンピュータで実現される方法。
  7. 前記ブロックはマイナーにより提供される乱数を含むブロック・ヘッダを含む、請求項1-6のうち何れか1項に記載のコンピュータで実現される方法。
  8. 前記ブロックチェーンに前記ブロックを格納するステップを更に含む請求項1-7のうち何れか1項に記載のコンピュータで実現される方法。
  9. 前記ストレージ・エンティティは前記ブロックチェーン・ネットワークにおける複数のノード間で共有され、前記複数のノードは前記ブロックチェーン・ネットワークにおけるスーパー・ノードを形成し、前記共有されるストレージ・エンティティは、共通のストレージ・ノード、分散されたストレージ、又は両者の組み合わせのうちの何れかである、請求項1-8のうち何れか1項に記載のコンピュータで実現される方法。
  10. 前記ブロックチェーン・ネットワークからトランザクションを受信するステップ;
    前記ブロックチェーン・ネットワークから受信したトランザクションを検証するステップ;
    前記ブロックチェーン・ネットワークにおける他のノードとともに、検証されたトランザクションについての分散された非セントラル化されたストレージを維持するステップ;及び
    前記検証されたトランザクションに対応するデータであって検証されたトランザクションのリストを含むデータを、マイニングのために前記ブロックチェーン・ネットワークへ分配するステップ;
    を更に含む請求項1-9のうち何れか1項に記載のコンピュータで実現される方法。
  11. 前記ブロックチェーン・ネットワークにおける他のノードとともに、検証されたトランザクションについての分散された非セントラル化されたストレージを維持する前記ステップが、検証されたトランザクションの最新のリストを非セントラル化された分散された方法で維持するために、前記ブロックチェーン・ネットワークにおけるノードを同期させるステップを含む、請求項10に記載のコンピュータで実現される方法。
  12. 前記ノードは、可逆ブルーム・フィルタ・ルックアップ・テーブルを交換することにより同期させられる、請求項11に記載のコンピュータで実現される方法。
  13. 前記検証されたトランザクションの分散された非セントラル化されたストレージを維持するために、前記ブロックチェーン・ネットワークにおけるノードにわたって共通の順序体系が使用されるように、前記検証されたトランザクションが所定の順序でソートされる、請求項10-12のうち何れか1項に記載のコンピュータで実現される方法。
  14. 前記検証されたトランザクションの分散された非セントラル化されたストレージを維持するために、前記検証されたトランザクションは、正規の順序体系を利用して前記所定の順序ソートされる、請求項13に記載のコンピュータで実現される方法。
  15. 前記検証されたトランザクションに対応するデータを、マイニングのために前記ブロックチェーン・ネットワークへ分配する前記ステップが:
    検証されたトランザクションのリストに対応するデータを準備するステップ
    を含む、請求項10-14のうち何れか1項に記載のコンピュータで実現される方法。
  16. 前記検証されたトランザクションに対応するデータを、マイニングのために前記ブロックチェーン・ネットワークへ分配する前記ステップが:
    前記検証されたトランザクションのリストに対応する前記データをマイナーに提供することに対する見返りとしてディジタル資産のコミットメント・トランザクションを作成するステップ
    を含む請求項10-15のうち何れか1項に記載のコンピュータで実現される方法。
  17. ハッシュ・ツリー、パトリシア・ツリー、又は他のタイプのラディックス・ツリーが、包含される前記コミットメント・トランザクションとともに算出される、請求項16に記載のコンピュータで実現される方法。
  18. 前記検証されたトランザクションに対応する前記データは、可逆ブルーム・ルックアップ・テーブル及び任意の付随するデータの形式で前記ブロックチェーン・ネットワークへ分配され、前記検証されたトランザクションはブロックに含まれる、請求項10-17のうち何れか1項に記載のコンピュータで実現される方法。
  19. 実行されると請求項1-18のうち何れか1項に記載の方法を実行するようにプロセッサを構築するコンピュータ実行可能命令を含むコンピュータ読み取り可能な記憶媒体。
  20. インターフェース・デバイス;
    前記インターフェース・デバイスに結合される1つ以上のプロセッサ;
    前記1つ以上のプロセッサ結合されるメモリ;
    を含む電子デバイスであって、前記メモリは、実行されると請求項1-18のうち何れか1項に記載の方法を実行するように前記1つ以上のプロセッサを構築するコンピュータ読み取り可能な命令を格納している、電子デバイス。
  21. 請求項1-18のうち何れか1項に記載の方法を実行するように構成される、ブロックチェーンのノード。
  22. 請求項21に記載のノード複数個;及び
    前記ブロックチェーンを格納する共有されるストレージ・エンティティ;
    を含む、ブロックチェーンのスーパー・ノードであって、前記共有されるストレージ・エンティティは、共通のストレージ・ノード、分散されたストレージ、又は両者の組み合わせのうちの何れかであり、
    前記複数のノードにより組み立てられるブロックは、前記共有されるストレージ・エンティティへ送信及び格納されることにより、前記共有されるストレージ・エンティティは前記ブロックチェーンを維持する、スーパー・ノード。
  23. 前記共有されるストレージ・エンティティは少なくとも100ギガバイトのストレージ容量を有する、請求項22に記載のスーパー・ノード。
  24. 請求項22又は23に記載のスーパー・ノードを複数個含むブロックチェーン・ネットワークであって、
    前記スーパー・ノードは前記ブロックチェーン・ネットワークで接続されており、各スーパー・ノードの前記共有されるストレージ・エンティティは前記ブロックチェーンのコピーを格納するように構成されており、前記ブロックチェーン・ネットワークは少なくとも10個のスーパー・ノードを含む、ブロックチェーン・ネットワーク。
JP2019564132A 2017-06-07 2018-06-05 ブロックチェーン・ネットワークにおいてラージ・ブロックを管理するためのコンピュータ実装システム及び方法 Active JP7208164B2 (ja)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP2023000329A JP2023036931A (ja) 2017-06-07 2023-01-05 ブロックチェーン・ネットワークのノードに関する方法

Applications Claiming Priority (5)

Application Number Priority Date Filing Date Title
GB1709098.6 2017-06-07
GB1709099.4 2017-06-07
GBGB1709098.6A GB201709098D0 (en) 2017-06-07 2017-06-07 Computer-Implemented system and method
GBGB1709099.4A GB201709099D0 (en) 2017-06-07 2017-06-07 Computer-Implemented system and method
PCT/IB2018/054007 WO2018224955A1 (en) 2017-06-07 2018-06-05 Computer-implemented system and method for managing large blocks over a blockchain network

Related Child Applications (1)

Application Number Title Priority Date Filing Date
JP2023000329A Division JP2023036931A (ja) 2017-06-07 2023-01-05 ブロックチェーン・ネットワークのノードに関する方法

Publications (2)

Publication Number Publication Date
JP2020522786A JP2020522786A (ja) 2020-07-30
JP7208164B2 true JP7208164B2 (ja) 2023-01-18

Family

ID=62816886

Family Applications (5)

Application Number Title Priority Date Filing Date
JP2019564132A Active JP7208164B2 (ja) 2017-06-07 2018-06-05 ブロックチェーン・ネットワークにおいてラージ・ブロックを管理するためのコンピュータ実装システム及び方法
JP2019564126A Active JP7053677B2 (ja) 2017-06-07 2018-06-05 ブロックチェーン・ネットワークにおいてトランザクションを管理するためのコンピュータ実装システム及び方法
JP2022058089A Active JP7278453B2 (ja) 2017-06-07 2022-03-31 ブロックチェーン・ネットワークにおいてトランザクションを管理するための方法、記憶媒体、電子デバイス、トランザクション検証ノード、スーパー・ノード及びブロックチェーン・ネットワーク
JP2023000329A Pending JP2023036931A (ja) 2017-06-07 2023-01-05 ブロックチェーン・ネットワークのノードに関する方法
JP2023076998A Pending JP2023103330A (ja) 2017-06-07 2023-05-09 ブロックチェーン・ネットワークにおけるトランザクション検証ノードのための方法、記憶媒体、電子デバイス、トランザクション検証ノード、スーパー・ノード及びブロックチェーン・ネットワーク

Family Applications After (4)

Application Number Title Priority Date Filing Date
JP2019564126A Active JP7053677B2 (ja) 2017-06-07 2018-06-05 ブロックチェーン・ネットワークにおいてトランザクションを管理するためのコンピュータ実装システム及び方法
JP2022058089A Active JP7278453B2 (ja) 2017-06-07 2022-03-31 ブロックチェーン・ネットワークにおいてトランザクションを管理するための方法、記憶媒体、電子デバイス、トランザクション検証ノード、スーパー・ノード及びブロックチェーン・ネットワーク
JP2023000329A Pending JP2023036931A (ja) 2017-06-07 2023-01-05 ブロックチェーン・ネットワークのノードに関する方法
JP2023076998A Pending JP2023103330A (ja) 2017-06-07 2023-05-09 ブロックチェーン・ネットワークにおけるトランザクション検証ノードのための方法、記憶媒体、電子デバイス、トランザクション検証ノード、スーパー・ノード及びブロックチェーン・ネットワーク

Country Status (5)

Country Link
US (3) US11468077B2 (ja)
EP (3) EP3635607B1 (ja)
JP (5) JP7208164B2 (ja)
CN (2) CN110741372A (ja)
WO (2) WO2018224955A1 (ja)

Families Citing this family (63)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP3413530B1 (de) * 2017-06-09 2019-07-31 Siemens Aktiengesellschaft Verfahren und vorrichtung zum austauschen von nachrichten
EP3649558B8 (en) * 2017-07-06 2024-04-17 Chromaway AB Method and system for a distributed computing system
EP3665858B1 (en) * 2017-08-09 2022-05-25 Visa International Service Association Verification of interactions system and method
US11412383B2 (en) * 2018-01-03 2022-08-09 Helium Systems , Inc. Systems and methods for providing and using a decentralized wireless network
US20190303363A1 (en) * 2018-03-29 2019-10-03 AnApp Technologies Limited System and method for operating a blockchain network
EP3811259B1 (en) * 2018-09-21 2023-08-16 NEC Corporation Method for signing a new block in a decentralized blockchain consensus network
US11399284B1 (en) 2018-09-28 2022-07-26 Helium Systems, Inc. Systems and methods for providing and using proof of coverage in a decentralized wireless network
US11368446B2 (en) * 2018-10-02 2022-06-21 International Business Machines Corporation Trusted account revocation in federated identity management
EP3866094A4 (en) * 2018-10-11 2022-04-20 Hefei Dappworks Technology Co., Ltd. RESOURCE FLOW TRANSACTION METHOD AND APPARATUS
CN112232817A (zh) * 2018-10-25 2021-01-15 创新先进技术有限公司 基于区块链的交易处理方法及装置、电子设备
KR20200083937A (ko) 2018-12-28 2020-07-09 알리바바 그룹 홀딩 리미티드 전역적 가속 노드를 사용한 블록체인 트랜잭션 속도 향상
JP6899911B2 (ja) 2018-12-28 2021-07-07 アドバンスド ニュー テクノロジーズ カンパニー リミテッド アクセラレーションノードを用いたブロックチェーンネットワーク内のトランザクション配信の高速化
JP6892514B2 (ja) 2018-12-28 2021-06-23 アドバンスド ニュー テクノロジーズ カンパニー リミテッド トランザクションの再送信を使用してブロックチェーンネットワークにおけるトランザクション配信の加速化
US11418402B1 (en) * 2019-01-17 2022-08-16 Artema Labs, Inc Robust and secure proof of space based mining
WO2020158973A1 (ko) * 2019-01-30 2020-08-06 주식회사 아티프렌즈 가설 수락 프로토콜-2 방식의 블록체인 합의 시스템 및 방법
CN111598564B (zh) * 2019-02-20 2023-11-21 华为技术有限公司 区块链节点连接建立方法、装置及设备
KR102544628B1 (ko) * 2019-03-08 2023-06-19 한국전자통신연구원 블록체인 기반의 분산 데이터 공유 환경에서 데이터 공유 플랫폼을 위한 시스템, 상기 시스템에서 데이터 검색 방법 및 상기 시스템에서 검색 인덱스를 제공하는 방법
US11777712B2 (en) * 2019-03-22 2023-10-03 International Business Machines Corporation Information management in a database
US20200314648A1 (en) * 2019-03-29 2020-10-01 Parallel Wireless, Inc. Distributed HSS Using Blockchain
US10939405B1 (en) 2019-04-08 2021-03-02 Helium Systems, Inc. Systems and methods for implementing permissionless network consensus using blockchain
GB2582978B (en) * 2019-04-12 2022-05-04 Nchain Holdings Ltd Methods and devices for propagating blocks in a blockchain network
US11539527B2 (en) 2019-05-29 2022-12-27 International Business Machines Corporation Peer node recovery via approximate hash verification
US11516000B2 (en) * 2019-05-29 2022-11-29 International Business Machines Corporation Approximate hash verification of unused blockchain output
US11570002B2 (en) 2019-05-29 2023-01-31 International Business Machines Corporation Reduced-step blockchain verification of media file
US11711202B2 (en) 2019-05-29 2023-07-25 International Business Machines Corporation Committing data to blockchain based on approximate hash verification
US11429738B2 (en) 2019-05-29 2022-08-30 International Business Machines Corporation Blockchain endorsement with approximate hash verification
CN110188300B (zh) * 2019-05-30 2023-04-07 吉林大学 一种面向汽车领域的采购信息的处理方法及装置
CN112039930B (zh) * 2019-06-03 2023-04-07 本无链科技(深圳)有限公司 一种基于大节点构建移动区块链的方法及系统
US20220353080A1 (en) * 2019-06-20 2022-11-03 INDIAN INSTITUTE OF TECHNOLOGY MADRAS (IIT Madras) Colosseum, a scalable and byzantine-fault tolerant consensus mechanism for permissioned systems
CN110544167B (zh) * 2019-07-25 2022-03-01 晋商博创(北京)科技有限公司 基于cpk的联盟链的数据处理方法、服务器及存储介质
CN110599144B (zh) * 2019-09-24 2023-08-22 腾讯科技(深圳)有限公司 一种区块链节点的入网方法以及装置
US11522670B2 (en) 2019-12-04 2022-12-06 MaataData, Inc. Pyramid construct with trusted score validation
EP3852305B1 (en) * 2020-01-17 2022-11-16 Fetch.ai Limited Transaction verification system and method of operation thereof
US11271742B2 (en) 2020-01-26 2022-03-08 International Business Machines Corporation Decentralized secure data sharing
US11356260B2 (en) 2020-01-26 2022-06-07 International Business Machines Corporation Decentralized secure data sharing
US11088833B1 (en) * 2020-01-26 2021-08-10 International Business Machines Corporation Decentralized secure data sharing
CN111324633A (zh) * 2020-02-18 2020-06-23 杭州复杂美科技有限公司 一种区块链交易分布式缓存方法和系统、设备及存储介质
CN111325346B (zh) * 2020-02-20 2023-04-18 中南大学 比特币矿池的身份推理方法及其推理系统
CN111352968B (zh) * 2020-02-28 2023-09-29 杭州云象网络技术有限公司 一种基于区块链网络的智能制造要素识取方法
US20210374843A1 (en) * 2020-05-26 2021-12-02 Mitsubishi Electric Research Laboratories, Inc. Debt Resource Management in a Distributed Ledger System
CN111638962A (zh) * 2020-06-08 2020-09-08 杭州复杂美科技有限公司 交易池动态伸缩方法、设备和存储介质
KR102318947B1 (ko) * 2020-08-21 2021-10-27 세종대학교산학협력단 개인 정보 보호 방법과 이를 수행하기 위한 컴퓨팅 장치 및 시스템
KR102319416B1 (ko) * 2020-08-21 2021-10-28 세종대학교산학협력단 블록체인 기반의 블룸 필터 생성 방법과 이를 수행하기 위한 컴퓨팅 장치 및 시스템
US20220083537A1 (en) * 2020-09-14 2022-03-17 International Business Machines Corporation Ensuring secure provisioning of blockchain infrastructure
EP4002786B1 (en) * 2020-11-11 2023-06-21 Deutsche Post AG Distributed ledger system
CN112565368B (zh) * 2020-11-26 2023-05-19 中国船舶集团有限公司系统工程研究院 基于区块链的海上装备自组网系统、方法和介质
CN112671908B (zh) * 2020-12-25 2023-03-21 成都质数斯达克科技有限公司 网络管理方法、装置、电子设备及可读存储介质
CN112988891B (zh) * 2021-03-11 2023-04-21 重庆文理学院 存储区块链账本的方法、装置、电子设备及存储介质
CN113612810B (zh) * 2021-05-18 2023-06-27 中国信息通信研究院 基于dht的集群节点间性能优化方法、电子设备及存储介质
US11790353B2 (en) * 2021-06-16 2023-10-17 Song Hwan KIM System and method for online/offline payment with virtual currency for nodes included in mobile-based blockchain distributed network
CN113535849B (zh) * 2021-07-08 2023-03-07 电子科技大学 一种区块链的可扩展共识方法
GB2608841A (en) * 2021-07-14 2023-01-18 Nchain Licensing Ag Blockchain blocks & proof-of-existence
GB2608845A (en) * 2021-07-14 2023-01-18 Nchain Licensing Ag Blockchain blocks & proof-of-existence
GB2608844A (en) * 2021-07-14 2023-01-18 Nchain Licensing Ag Blockchain blocks & proof-of-existence
GB2608842A (en) * 2021-07-14 2023-01-18 Nchain Licensing Ag Blockchain Blocks & Proof-of-existence
CN113609231B (zh) * 2021-09-30 2022-01-04 支付宝(杭州)信息技术有限公司 一种维护区块链系统的网络架构信息的方法和装置
US11640603B1 (en) * 2021-11-18 2023-05-02 Joseph Freire System and method for crypto token linked assets
US11847137B2 (en) 2021-11-18 2023-12-19 Fivetran Inc. Database synchronization using resizable invertible bloom filters with database snapshots
CN114363349B (zh) * 2021-12-31 2024-04-02 支付宝(杭州)信息技术有限公司 区块链子网的启动方法及装置
CN114066456B (zh) * 2022-01-13 2022-04-08 环球数科集团有限公司 一种基于erc1155的跨链nft转移和结算系统
CN114390063B (zh) * 2022-02-25 2023-09-29 蚂蚁区块链科技(上海)有限公司 用于区块链网络的消息广播方法、区块链节点和区块链系统
CN115766745B (zh) * 2023-01-09 2023-05-23 杭州安碣信息安全科技有限公司 一种区块链节点内存池交易数据收集、广播的方法和装置
CN116668066B (zh) * 2023-04-18 2024-03-08 华北电力大学 一种基于区块链的智能电网隐私保护方法、装置、非易失性存储介质及电子装置

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20160342977A1 (en) 2015-05-20 2016-11-24 Vennd.io Pty Ltd Device, method and system for virtual asset transactions
WO2017038507A1 (ja) 2015-09-03 2017-03-09 日本電信電話株式会社 許諾情報管理システム、利用者端末、権利者端末、許諾情報管理方法、および、許諾情報管理プログラム
CN106548349A (zh) 2016-11-02 2017-03-29 江苏通付盾科技有限公司 交易信息验证方法及系统

Family Cites Families (48)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9389965B1 (en) 2012-03-12 2016-07-12 Emc Corporation System and method for improving performance of backup storage system with future access prediction
US8817541B2 (en) 2012-11-09 2014-08-26 Sandisk Technologies Inc. Data search using bloom filters and NAND based content addressable memory
US10068228B1 (en) 2013-06-28 2018-09-04 Winklevoss Ip, Llc Systems and methods for storing digital math-based assets using a secure portal
US9633100B2 (en) * 2014-01-15 2017-04-25 Dell Products, L.P. System and method for data structure synchronization
US9672499B2 (en) 2014-04-02 2017-06-06 Modernity Financial Holdings, Ltd. Data analytic and security mechanism for implementing a hot wallet service
US11270298B2 (en) * 2014-04-14 2022-03-08 21, Inc. Digital currency mining circuitry
US9830593B2 (en) 2014-04-26 2017-11-28 Ss8 Networks, Inc. Cryptographic currency user directory data and enhanced peer-verification ledger synthesis through multi-modal cryptographic key-address mapping
US9703644B1 (en) 2014-12-09 2017-07-11 EMC IP Holding Company LLC Methods for generating a synthetic backup and for consolidating a chain of backups independent of endianness
US9965628B2 (en) 2015-03-02 2018-05-08 Dell Products Lp Device reporting and protection systems and methods using a secure distributed transactional ledger
AU2016242888A1 (en) * 2015-03-31 2017-11-16 Nasdaq, Inc. Systems and methods of blockchain transaction recordation
JP6636058B2 (ja) * 2015-07-02 2020-01-29 ナスダック, インコーポレイテッドNasdaq, Inc. 分散トランザクションデータベースにおける出所保証のシステムおよび方法
US20170091756A1 (en) 2015-07-14 2017-03-30 Fmr Llc Point-to-Point Transaction Guidance Apparatuses, Methods and Systems
US20170228731A1 (en) 2016-02-09 2017-08-10 Fmr Llc Computationally Efficient Transfer Processing and Auditing Apparatuses, Methods and Systems
WO2017011601A1 (en) 2015-07-14 2017-01-19 Fmr Llc Computationally efficient transfer processing, auditing, and search apparatuses, methods and systems
US20180331832A1 (en) 2015-11-05 2018-11-15 Allen Pulsifer Cryptographic Transactions System
US20170132625A1 (en) * 2015-11-05 2017-05-11 Mastercard International Incorporated Method and system for use of a blockchain in a transaction processing network
US20170132615A1 (en) * 2015-11-11 2017-05-11 Bank Of America Corporation Block chain alias for person-to-person payments
US20170140408A1 (en) * 2015-11-16 2017-05-18 Bank Of America Corporation Transparent self-managing rewards program using blockchain and smart contracts
CN105488675B (zh) * 2015-11-25 2019-12-24 布比(北京)网络技术有限公司 一种区块链的分布式共享总账构建方法
CN108701325B (zh) 2015-12-21 2022-11-22 星茶瓦公司 自调节交易系统以及用于该系统的方法
US10887665B2 (en) * 2016-01-05 2021-01-05 Visible World, Llc Value-based TV advertising audience exchange
US9825931B2 (en) * 2016-01-26 2017-11-21 Bank Of America Corporation System for tracking and validation of an entity in a process data network
US20170213221A1 (en) * 2016-01-26 2017-07-27 Bank Of America Corporation System for tracking and validation of multiple instances of an entity in a process data network
US10116667B2 (en) * 2016-01-26 2018-10-30 Bank Of America Corporation System for conversion of an instrument from a non-secured instrument to a secured instrument in a process data network
US11374935B2 (en) * 2016-02-11 2022-06-28 Bank Of America Corporation Block chain alias person-to-person resource allocation
US20170236123A1 (en) 2016-02-16 2017-08-17 Blockstack Inc. Decentralized processing of global naming systems
US10026118B2 (en) * 2016-02-22 2018-07-17 Bank Of America Corporation System for allowing external validation of data in a process data network
US10475030B2 (en) * 2016-02-22 2019-11-12 Bank Of America Corporation System for implementing a distributed ledger across multiple network nodes
WO2017162904A1 (en) 2016-03-23 2017-09-28 Nokia Technologies Oy Management of cryptographic transactions
WO2017189027A1 (en) * 2016-04-29 2017-11-02 Digital Asset Holdings Digital asset modeling
US20170345011A1 (en) * 2016-05-26 2017-11-30 Hitfin, Inc. System and method executed on a blockchain network
US10417217B2 (en) * 2016-08-05 2019-09-17 Chicago Mercantile Exchange Inc. Systems and methods for blockchain rule synchronization
CN106296191A (zh) * 2016-08-13 2017-01-04 深圳市樊溪电子有限公司 一种区块链功耗感知的PoW共识机制
CN106372868B (zh) * 2016-09-06 2020-02-18 联动优势科技有限公司 一种对写入区块链的交易数据的验证方法和装置
CN106452785B (zh) * 2016-09-29 2019-05-17 财付通支付科技有限公司 区块链网络、分支节点及区块链网络应用方法
CN106656974B (zh) * 2016-10-17 2019-07-16 江苏通付盾科技有限公司 区块链的分组共识方法及系统
US10291627B2 (en) 2016-10-17 2019-05-14 Arm Ltd. Blockchain mining using trusted nodes
CN106506638B (zh) * 2016-11-04 2020-01-07 江苏通付盾科技有限公司 区块链中的区块存储方法及装置
US10491378B2 (en) * 2016-11-16 2019-11-26 StreamSpace, LLC Decentralized nodal network for providing security of files in distributed filesystems
US10862959B2 (en) 2016-11-28 2020-12-08 Keir Finlow-Bates Consensus system and method for adding data to a blockchain
US10586210B2 (en) 2016-11-30 2020-03-10 International Business Machines Corporation Blockchain checkpoints and certified checkpoints
CN106603198A (zh) * 2016-12-02 2017-04-26 深圳大学 具有网络编码的区块链分布式存储方法及系统
US11631077B2 (en) * 2017-01-17 2023-04-18 HashLynx Inc. System for facilitating secure electronic communications between entities and processing resource transfers
US20180276626A1 (en) * 2017-03-21 2018-09-27 Dappsters, LLC Blockchain systems and methods
US10812270B2 (en) * 2017-04-07 2020-10-20 Citizen Hex Inc. Techniques for increasing the probability that a transaction will be included in a target block of a blockchain
US10397328B2 (en) 2017-05-17 2019-08-27 Nec Corporation Method and system for providing a robust blockchain with an integrated proof of storage
US11018850B2 (en) * 2017-12-26 2021-05-25 Akamai Technologies, Inc. Concurrent transaction processing in a high performance distributed system of record
US11829351B2 (en) * 2018-11-26 2023-11-28 Akamai Technologies, Inc. High performance distributed system of record with hosted origin services

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20160342977A1 (en) 2015-05-20 2016-11-24 Vennd.io Pty Ltd Device, method and system for virtual asset transactions
WO2017038507A1 (ja) 2015-09-03 2017-03-09 日本電信電話株式会社 許諾情報管理システム、利用者端末、権利者端末、許諾情報管理方法、および、許諾情報管理プログラム
CN106548349A (zh) 2016-11-02 2017-03-29 江苏通付盾科技有限公司 交易信息验证方法及系统

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
永田 和之 ほか,ブロックチェーンにおける本人性確認の方法に関する考察,研究報告コンピュータセキュリティ(CSEC),日本,情報処理学会,2017年02月23日,vol. 2017-CSEC-76,no. 19,pp.1-6

Also Published As

Publication number Publication date
CN110741372A (zh) 2020-01-31
JP7053677B2 (ja) 2022-04-12
US20210083852A1 (en) 2021-03-18
US20200278963A1 (en) 2020-09-03
JP7278453B2 (ja) 2023-05-19
JP2023103330A (ja) 2023-07-26
JP2020522919A (ja) 2020-07-30
US11468077B2 (en) 2022-10-11
JP2023036931A (ja) 2023-03-14
EP4350560A2 (en) 2024-04-10
US20230113492A1 (en) 2023-04-13
EP3635607A1 (en) 2020-04-15
JP2020522786A (ja) 2020-07-30
EP3635608A1 (en) 2020-04-15
WO2018224954A1 (en) 2018-12-13
JP2022091923A (ja) 2022-06-21
CN110741373A (zh) 2020-01-31
EP3635607B1 (en) 2024-04-24
WO2018224955A1 (en) 2018-12-13

Similar Documents

Publication Publication Date Title
JP7278453B2 (ja) ブロックチェーン・ネットワークにおいてトランザクションを管理するための方法、記憶媒体、電子デバイス、トランザクション検証ノード、スーパー・ノード及びブロックチェーン・ネットワーク
JP7408619B2 (ja) ブロックチェーンネットワークにおいて大規模分散メモリプールを管理するためのコンピュータ実装されたシステム及び方法
Jesus et al. A survey of how to use blockchain to secure internet of things and the stalker attack
US11468411B2 (en) Method and system of mining blockchain transactions provided by a validator node
Alizadeh et al. A survey of secure internet of things in relation to blockchain
JP7477576B2 (ja) ブロックチェーンネットワークにおける整合性のある分散型メモリプールのための方法及びシステム
CN113395363B (zh) 基于区块链的数据处理方法、装置、设备及存储介质
CN112053271B (zh) 基于区块链的公益平台数据存证管理方法及系统
Alrehaili et al. A comparative analysis of scalability issues within blockchain-based solutions in the internet of things
Gupta Blockchain Optimization Techniques and its Application in Fintech
Suyeon et al. New Function and Configuration of Future Network for Blockchain Platform Operation
Fei et al. Dis: A Decentralized and Interoperable Scheme for Facilitating Manufacturing Service Collaboration

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20210507

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20220228

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20220315

A601 Written request for extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A601

Effective date: 20220523

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20220915

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20221206

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20230105

R150 Certificate of patent or registration of utility model

Ref document number: 7208164

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150