JP7450339B2 - ブロックチェーンのためのリソースの公平性のためのシステム、方法、およびコンピュータ・プログラム - Google Patents

ブロックチェーンのためのリソースの公平性のためのシステム、方法、およびコンピュータ・プログラム Download PDF

Info

Publication number
JP7450339B2
JP7450339B2 JP2019042365A JP2019042365A JP7450339B2 JP 7450339 B2 JP7450339 B2 JP 7450339B2 JP 2019042365 A JP2019042365 A JP 2019042365A JP 2019042365 A JP2019042365 A JP 2019042365A JP 7450339 B2 JP7450339 B2 JP 7450339B2
Authority
JP
Japan
Prior art keywords
transaction
blockchain
nodes
node
blockchain network
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
JP2019042365A
Other languages
English (en)
Other versions
JP2019160316A (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.)
International Business Machines Corp
Original Assignee
International Business Machines Corp
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
Application filed by International Business Machines Corp filed Critical International Business Machines Corp
Publication of JP2019160316A publication Critical patent/JP2019160316A/ja
Application granted granted Critical
Publication of JP7450339B2 publication Critical patent/JP7450339B2/ja
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • 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/38Payment protocols; Details thereof
    • G06Q20/40Authorisation, e.g. identification of payer or payee, verification of customer or shop credentials; Review and approval of payers, e.g. check credit lines or negative lists
    • G06Q20/407Cancellation of a transaction
    • 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
    • G06Q30/00Commerce
    • G06Q30/04Billing or invoicing
    • 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/27Replication, distribution or synchronisation of data between databases or within a distributed database system; Distributed database system architectures therefor
    • 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/04Payment circuits
    • G06Q20/06Private payment circuits, e.g. involving electronic currency used among participants of a common payment scheme
    • G06Q20/065Private payment circuits, e.g. involving electronic currency used among participants of a common payment scheme using 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/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
    • 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
    • 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
    • G06Q2220/00Business processing using cryptography
    • 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

Landscapes

  • Engineering & Computer Science (AREA)
  • Business, Economics & Management (AREA)
  • Theoretical Computer Science (AREA)
  • Accounting & Taxation (AREA)
  • General Physics & Mathematics (AREA)
  • Physics & Mathematics (AREA)
  • General Business, Economics & Management (AREA)
  • Finance (AREA)
  • Strategic Management (AREA)
  • Computer Security & Cryptography (AREA)
  • Development Economics (AREA)
  • Databases & Information Systems (AREA)
  • Economics (AREA)
  • Marketing (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Computing Systems (AREA)
  • Data Mining & Analysis (AREA)
  • General Engineering & Computer Science (AREA)
  • Financial Or Insurance-Related Operations Such As Payment And Settlement (AREA)

Description

本出願は、一般に、ブロックチェーン・ネットワークに関連し、より詳細には、ブロックチェーンのためのリソースの公平性(resource equity)に関連する。
台帳は、一般に、トランザクションが記録される会計簿(account book of entry)として定義される。分散型台帳は、複数のコンピュータに全体的または部分的に複製された台帳である。暗号分散型台帳(CDL:Cryptographic Distributed Ledger)は、不可逆性(トランザクションが記録された後に、そのトランザクションを無効にすることができない)、アクセス可能性(いずれかの関係者がCDLに全体的または部分的にアクセスできる)、経時的でタイムスタンプが付けられている(すべての関係者が、トランザクションがいつ台帳に追加されたかを知る)、合意に基づく(トランザクションが、ネットワーク上の関係者によって、通常は全員一致で、承認された場合にのみ追加される)、検証可能性(すべてのトランザクションが暗号によって検証され得る)という特性のうちの少なくとも一部を有することができる。ブロックチェーンは、CDLの例である。本明細書における説明および図は、ブロックチェーンに関して説明されているが、本出願は任意のCDLに同様に適用される。
分散型台帳は、継続的に増大するレコードのリストであり、通常は、他のブロックに関連する暗号学的ハッシュを格納することなどの、暗号手法を適用する。ブロックチェーンは、分散型台帳の1つの一般的例であり、情報を格納するためのパブリックな台帳として使用されてよい。ブロックチェーンは、主に金融トランザクションに使用されるが、商品およびサービスに関連するさまざまな情報(すなわち、製品、パッケージ、状態など)を格納することができる。非集中的方式は、権限および信用を非集中的ネットワークに提供し、そのノードが継続的かつ連続的にトランザクションをパブリックな「ブロック」に記録できるようにし、ブロックチェーンと呼ばれる一意の「チェーン」を作成する。暗号は、トランザクション・ソース(transaction source)の認証を保護するためにハッシュ・コードを介して使用され、中央の仲介を取り除く。ブロックチェーンは、ブロックチェーンのブロック内の継続的に増大するレコードのリストを維持する分散データベースであり、変更不可能な特性のため、改ざんおよび改訂から保護される。各ブロックは、タイムスタンプおよび前のブロックへのリンクを含む。ブロックチェーンは、情報の保持、追跡、転送、および検証に使用され得る。ブロックチェーンは分散システムであるため、トランザクションをブロックチェーン台帳に追加する前に、すべてのピアが合意状態に達する必要がある。
従来、プルーフ・オブ・ステーク割り当てモデル(proof of stake(PoS) allocationmodels)は、参加者を不要な危険にさらし、ブロックチェーン・ネットワーク内の最も重要なノードに報酬を与えるのではなく、トークンおよびノードが少数のトークン所有者に集中することを促進する。
そのため、特にプライベート・ブロックチェーン・ネットワークまたは許可型(permissioned)ブロックチェーン・ネットワークにおいて、ノードへのより公平なトークンの割り当てが必要である。
1つの実施形態例は、トランザクションをサブミットするように構成された1つまたは複数のユーザ・デバイス、およびブロックチェーン・ネットワークを含んでいるシステムを提供してよい。ブロックチェーン・ネットワークは、複数のノードのうちの1つまたは複数の検証ノードを含み、ユーザ・デバイスに接続される。ブロックチェーン・ネットワークは、トランザクションを受信することに応答して、1つまたは複数の検証ノードから、トランザクションを検証するために入札のサブミット(submit bids)のうちの1つまたは複数を実行することと、1つまたは複数の検証ノードによって、サブミットされた入札に基づいてトランザクション・パラメータを計算することと、1つまたは複数の検証ノードによってトランザクションを検証することと、トランザクションを実行することと、トランザクションのチャージバック(chargeback)を計算することと、チャージバックを1つまたは複数の検証ノードのうちの少なくとも1つに配信することとを実行するように構成される。
別の実施形態例は、ブロックチェーン・ネットワークによってトランザクションをユーザ・デバイスから受信することと、1つまたは複数の検証ノードから、トランザクションを検証するために入札をブロックチェーン・ネットワーク内のノードにサブミットすることと、1つまたは複数の検証ノードによって、サブミットされた入札に基づいてトランザクション・パラメータを計算することと、1つまたは複数の検証ノードによって、トランザクションを検証することと、ブロックチェーン・ネットワーク内のノードによってトランザクションを実行することと、トランザクションのチャージバックを計算することと、チャージバックを1つまたは複数の検証ノードのうちの少なくとも1つに配信することとのうちの1つまたは複数を含む方法を提供してよい。
さらに別の実施形態例は、命令を含んでいるコンピュータ・プログラム、およびそのコンピュータ・プログラムを記憶する記憶媒体を提供してよく、それらの命令は、プロセッサによって読み取られたときに、プロセッサに、ブロックチェーン・ネットワークによってトランザクションをユーザ・デバイスから受信することと、1つまたは複数の検証ノードから、トランザクションを検証するために入札をブロックチェーン・ネットワーク内のノードにサブミットすることと、1つまたは複数の検証ノードによって、トランザクション・パラメータを計算することと、1つまたは複数の検証ノードによって、トランザクションを検証することと、ブロックチェーン・ネットワーク内のノードによってトランザクションを実行することと、トランザクションのチャージバックを計算することと、チャージバックを1つまたは複数の検証ノードのうちの少なくとも1つに配信することとのうちの1つまたは複数を実行させる。
実施形態例に記載されている、ブロックチェーン・システムのネットワーク図である。 実施形態例に記載されている、インセンティブ・メカニズム(incentive mechanism)の計算を示す図である。 実施形態例に記載されている、アセット共有のシナリオに関する、例示的なピア・ノード・ブロックチェーン・アーキテクチャの構成(peer node blockchain architecture configuration)を示す図である。 実施形態例に記載されている、例示的なピア・ノード・ブロックチェーン構成を示す図である。 実施形態例に記載されている、許可型ブロックチェーン・ネットワークを示す図である。 実施形態例に記載されている、トランザクションおよびチャージバックを実行するためのシステム・メッセージ図である。 実施形態例に記載されている、トランザクションのチャージバックを計算してブロックチェーン内で配信する例示的な方法のフロー図である。 実施形態例に記載されている、ブロックチェーン内でトランザクション料金に資金を提供する例示的な方法のフロー図である。 実施形態例に記載されている、本明細書において説明される1つまたは複数の動作に従って、ブロックチェーンに対してさまざまな動作を実行するように構成された例示的な物理的インフラストラクチャを示す図である。 実施形態例に記載されている、契約当事者間での例示的なスマート・コントラクトの構成、およびブロックチェーンに対してスマート・コントラクトの条件を実施するように構成された仲介サーバを示す図である。 実施形態例のうちの1つまたは複数をサポートするように構成された例示的なコンピュータ・システムを示す図である。
本明細書の図において概略的に説明され、示されているように、本明細書のコンポーネントが、多種多様な異なる構成で配置および設計されてよいということが、容易に理解されるであろう。したがって、添付の図において表された方法、装置、コンピュータ・プログラム、およびシステムのうちの少なくとも1つの実施形態に関する以下の詳細な説明は、請求されている適用の範囲を制限するよう意図されておらず、単に選択された実施形態を代表している。
本明細書全体を通して説明された特徴、構造、または特性は、1つまたは複数の実施形態において、任意の適切な方法で組み合わせられてよい。例えば、語句「実施形態例」、「一部の実施形態」、またはその他の同様の言葉の使用は、本明細書全体を通じて、実施形態に関連して説明された特定の特徴、構造、または特性が少なくとも1つの実施形態に含まれてよいということを指している。したがって、語句「実施形態例」、「一部の実施形態において」、「その他の実施形態において」、またはその他の同様の言葉の出現は、本明細書全体を通じて、必ずしもすべてが実施形態の同じグループを指しておらず、説明された特徴、構造、または特性は、1つまたは複数の実施形態において、任意の適切な方法で組み合わせられてよい。
加えて、「メッセージ」という用語が実施形態の説明において使用されていることがあるが、本出願は、パケット、フレーム、データグラムなどの多くの種類のネットワーク・データに適用されてよい。「メッセージ」という用語は、パケット、フレーム、データグラム、および任意のこれらと同等のものも含む。さらに、特定の種類のメッセージおよび信号伝達が実施形態例において示されることがあるが、それらは特定の種類のメッセージに限定されず、本出願は特定の種類の信号伝達に限定されない。
本出願は、一実施形態ではブロックチェーン・ネットワークに関連しており、さらに別の実施形態では、分散型台帳(ブロックチェーンなど)での、公平なリソースに基づくトランザクションの検証を提供することに関連している。
実施形態例は、ブロックチェーンのためのリソースの公平性を実現する方法、デバイス、ネットワーク、またはシステム、あるいはその組み合わせを提供する。ビットコインなどのオープンなパブリック・ブロックチェーン・ネットワークが最初にブロックチェーン技術の使用を世に広めたが、プライベート・ブロックチェーンまたは許可型ブロックチェーンには、ビジネス・ネットワーク内での多くの有望な応用が存在している。ブロックチェーン・ネットワークは、確立された一連の参加者によって維持され、ブロックチェーンの「ノード」を操作してトランザクションを検証する参加者を補償するために、インセンティブ構造が使用される。例えば、一般的に使用される方式の1つは、プルーフ・オブ・ステークである。プルーフ・オブ・ステークでは、デジタル・トークンの供給を保持している関係者は、ブロックチェーン・トランザクションを検証する能力を取得し、それらの関係者の作業の見返りに、追加のトークンが支払われる。問題は、プルーフ・オブ・ステークのような合意アルゴリズムが、価値が変動するトークンの大量の供給を保持するよう参加者に対して要求し、したがって参加者を不要な危険にさらすことである。プルーフ・オブ・ステークを使用して付与される報酬が、実行された作業の量ではなく、保持されているトークンの数に比例するため、プルーフ・オブ・ステークは、分散ネットワークを促進すること、またはビジネス・ネットワーク内の最も重要な関係者に報酬を与えることではなく、トークンおよびノードが少数のトークン所有者に集中することを促進する。
同様に、暗号通貨に基づく信用システム(trust system)と暗号通貨に基づかない信用システムの間には断絶が存在し、それぞれが独自の長所を持っている。許可型ブロックチェーンでは、暗号通貨を導入せずに、公平なモデルに従うことが課題である。本出願は、許可型ブロックチェーン・ネットワーク内のトランザクションを処理するためにインセンティブ・メカニズムを使用して、公平な計算の公平性モデル(equitable compute equity model)に伴うこの課題に対処する。
ブロックチェーン・ネットワークのための検証ノードになることは、非常に高価である可能性があり、多くの場合、特殊なハードウェアの必要性を要求する。暗号化および暗号解読の絶え間ない必要性は、電気で支払わなければならない大量の計算リソースを消費することがある。分散型台帳の性質は、ノード自身がどんなに多くのトランザクションを台帳にサブミットしても、すべてのノードが同じ量の作業を実行しなければならないということを意味している。このことは、ブロックチェーン・ネットワークが実際には極めて少数のノードを含むことがあるという潜在的な欠点を生む。
パブリック・ブロックチェーンでは、このような問題を防ぐために、インセンティブが合意に組み込まれている。ビットコインおよびイーサリアムはプルーフ・オブ・ワーク・システムを使用し、このシステムでは、台帳がサードパーティのマイナーによって操作され、マイナーは、新しいブロックに組み込まれるトランザクションを検証するための計算を実行する。見返りとして、検証ノード(マイナー)は、それらの検証ノードが署名するブロックにトークンが埋め込まれて、報酬を受ける。それらの報奨金は、労力に対して検証ノードに報酬を与え、他の人がネットワークに参加することを促進する。プルーフ・オブ・ステーク・システムでは、デジタル通貨を所有している一連の関係者によって台帳が維持され、このデジタル通貨は、トランザクションの新しいブロックに署名する能力をそれらの関係者に与える。関係者の投資を保護することに加えて(ブロックチェーンに価値がない場合、関係者の通貨も価値がなくなる)、関係者は、新しいコインを含んでいるブロックに署名することに対して報酬を受ける。したがって、報酬は、トークンまたはデジタル通貨の保持に比例する。
ブロックチェーンは、互いに通信する複数のノードを含んでいる分散システムである。ブロックチェーンは、チェーンコード(例えば、スマート・コントラクトなど)と呼ばれるプログラムを操作し、状態および台帳のデータを保持し、トランザクションを実行する。一部のトランザクションは、チェーンコード上で呼び出される動作である。一般に、ブロックチェーン・トランザクションは、特定のブロックチェーン・メンバーによって「署名」されなければならず、署名されたトランザクションのみが、ブロックチェーンにコミットされてよく、ブロックチェーンの状態に影響を与える。署名されていない他のトランザクションは、無視される。管理機能およびパラメータのための1つまたは複数の特殊なチェーンコードが存在することがあり、それらは、システム・チェーンコードと総称される。
ノードは、ブロックチェーン・システムの通信エンティティである。「ノード」は、異なる種類の複数のノードが同じ物理サーバ上で実行され得るという意味で、論理機能を実行してよい。ノードは、信頼できるドメイン(trust domains)内でグループ化され、さまざまな方法でそれらのノードを制御する論理エンティティに関連付けられる。ノードは、トランザクション呼び出しを署名者(例えば、ピア)にサブミットし、トランザクション提案を順序付けサービス(ordering service)(例えば、順序付けノード(ordering node))にブローキャストするクライアントまたはサブミット・クライアント・ノードなどの、さまざまな種類を含んでよい。別の種類のノードは、クライアントがサブミットしたトランザクションを受信し、トランザクションをコミットし、ブロックチェーン・トランザクションの台帳の状態およびコピーを維持することができるピア・ノードであることができる。ピアは署名者の役割を持つこともできるが、これは必須要件ではない。順序付けサービス・ノードまたは整理者(orderer)は、すべてのノードのための通信サービスを実行するノードであり、トランザクションをコミットするとき、およびブロックチェーンの世界状態(world state)(通常は制御情報および設定情報を含んでいる初期ブロックチェーン・トランザクションの別の名前)を変更するときの、システム内の各ピア・ノードへのブロードキャストなどの、配信保証を実施する。
台帳は、ブロックチェーンのすべての状態遷移の順序付けられた不正使用防止機能付きレコードである。状態遷移は、参加している関係者(例えば、クライアント・ノード、順序付けノード、署名者ノード、ピア・ノードなど)によってサブミットされたチェーンコード呼び出し(すなわち、トランザクション)から生じてよい。トランザクションは、1つまたは複数のオペランド(作成、更新、削除など)として台帳にコミットされているアセットのキーと値のペアのセットをもたらしてよい。台帳は、変更不可能な順序付けられたレコードをブロックに格納するために使用されるブロックチェーン(チェーンとも呼ばれる)を含む。台帳は、ブロックチェーンの現在の状態を維持する状態データベースも含む。通常は、1つのチャネルにつき1つの台帳が存在する。各ピア・ノードは、それらのピア・ノードがメンバーになっているチャネルごとに、台帳のコピーを維持する。
チェーンは、ハッシュ・リンク・ブロック(hash-linked blocks)として構造化されたトランザクション・ログであり、各ブロックはN個のトランザクションのシーケンスを含んでおり、Nは1以上である。ブロック・ヘッダーは、ブロックのトランザクションのハッシュ、および前のブロックのヘッダーのハッシュを含んでいる。このようにして、台帳のすべてのトランザクションが順序付けられ、暗号によって互いにリンクされてよい。したがって、ハッシュ・リンクを壊さずに台帳データを改ざんすることはできない。最も最近追加されたブロックチェーンのブロックのハッシュは、それ以前に発生したチェーン上のすべてのトランザクションを表し、すべてのピア・ノードが一貫性のある信頼できる状態にあることを保証できるようにする。チェーンは、ブロックチェーンのワークロードの追加専用という性質を効率的にサポートするピア・ノードのファイル・システム(すなわち、ローカル、取り付けられたストレージ、クラウドなど)に格納されてよい。
変更不可能な台帳の現在の状態は、チェーンのトランザクション・ログに含まれているすべてのキーの最新の値を表す。現在の状態は、チャネルに知られている最新のキーの値を表すため、世界状態と呼ばれることもある。チェーンコード呼び出しは、台帳の現在の状態のデータに対してトランザクションを実行する。それらのチェーンコードの相互作用を効率的にするために、最新のキーの値が状態データベースに格納されてよい。状態データベースは、単にチェーンのトランザクション・ログへのインデックス付きビューであってよく、したがって、いつでもチェーンから再生成され得る。状態データベースは、ピア・ノードの起動時に、トランザクションが受け取られる前に、自動的に回復されて(必要な場合は、生成されて)よい。
図1は、実施形態例に従って、ブロックチェーン・システムのネットワーク図を示している。図1を参照すると、ブロックチェーン・システム100は1つまたは複数のユーザ・デバイス104を含んでいる。ユーザ・デバイス104は、ユーザ・デバイス104に関連付けられたユーザのトランザクション120を生成するコンピュータである。トランザクション120は、ブロックチェーン・ネットワーク108によって処理される任意のトランザクションであってよく、商品またはサービスの購入トランザクション、ドキュメントまたはレコードの転送、イベントの記録または通知、および投票関連の情報を含むが、これらに限定されない。ブロックチェーン・システム100は、ユーザの代わりにトランザクションを処理するブロックチェーン・ネットワーク108を含む。好ましい実施形態では、ブロックチェーン・ネットワーク108は、プライベート・ブロックチェーン・ネットワークまたは許可型ブロックチェーン・ネットワーク108である。ただし、ブロックチェーン・ネットワーク108は、パブリック・ブロックチェーン・ネットワーク108であってもよい。
ブロックチェーン・ネットワーク108は、ブロックチェーン・ノード112A、112B、112Cを含み、これらのブロックチェーン・ノードは、トランザクション120を受信して処理し、ブロックチェーン・ネットワーク108に関連付けられたすべての活動を管理する。図1は、ブロックチェーンのノード1(112A)、ノード2(112B)、およびノード3(112C)として識別された3つのブロックチェーン・ノード112を含んでいるブロックチェーン・ネットワーク108を示している。3つのノード112が示されているが、ブロックチェーン・ネットワーク108内には任意の数のノード112が存在してよいということが、理解されるべきである。少なくとも1つのノード112が、116A、116B、および116Cとして識別されたインセンティブ管理機能116を含んでおり、インセンティブ管理機能116は、ブロックチェーン・システム100内のトランザクション・パラメータおよびトランザクション検証に対する補償を計算して管理する。一部の実施形態では、ブロックチェーン・システム108のすべてのノード112またはノード112の大部分が、インセンティブ管理機能116を含む。示されている実施形態では、各ノード1~3(112A~112C)が、インセンティブ管理機能116A~116Cをそれぞれ含んでいる。ノード1(112A)は、トランザクション120を受信し、トランザクション120をブロックチェーン・ネットワーク108にサブミットする(すなわち、ノード1(112A)はコミッターである)。
インセンティブ管理機能116は、トークンの所有ではなくトランザクション120を検証する作業に基づいて参加者に報酬を与えるインセンティブ・プロセスを開発することによって、ブロックチェーン・ネットワーク108が、プルーフ・オブ・ステークまたはプルーフ・オブ・ワークのような暗号通貨に基づく信用システムの欠点を克服できるようにする。新しいプロセスが、ブロックチェーン・ネットワーク108内のどのノード112も制御していないトランザクションごとに価格を確立し、できるだけ多くのトランザクション120を検証するための動機をすべてのノード112に与える。このメカニズムは、1トランザクション当たりの料金をユーザに請求することによってこれを実現し、この料金の価格は、ノード112によって、インセンティブ管理機能116内で計算される比例割り当てオークション・メカニズム(proportional allocation auction mechanism)にサブミットされた入札によって、決定される。比例割り当てメカニズムは、すべての入札しているノード112による入札の総量に対する競争入札者(ノード112)の入札の割合に比例して、固定リソース(例えば、計算リソース、メモリ)へのアクセスを競争入札者(ノード112)に提供する。
その後、トランザクション料金(およびトランザクション・コストの仮定)が、トランザクションを検証する速度を最大化するための動機をノード112に与える式を使用して、合意に参加しているノード112に配信される。このプロセスは、ノード112が、検証されるトランザクションの数を減らして価格をつり上げることによって、トランザクションの価格に暗黙的に影響を与えることを許さない。このプロセスは、ノード112が、より安価なハードウェア上でブロックチェーンを操作して、より遅いトランザクション速度のコストをブロックチェーン・ネットワーク108の他の部分に対して強制しようとすることも阻止する。
このプロセスは、署名者、整理者、およびコミッターなどのトランザクションの役割を割り当てることに適用されてもよく、この割り当ては、ブロックチェーン・ネットワーク108に提供されるサービスによって決まることがある。計算リソースの割り当てを望まないノード112は、単にトランザクションを処理するための料金を支払うことができる。さらに、現在存在している均一で不公平なモデルとは対照的に、料金のネッティング(fee netting)および調整を提供する(公正なチャージバック・システムのための手段をノード112の運用者に与える)ために、料金台帳430がノード112間で維持されてよい。料金台帳430は、インセンティブ管理機能116内にあってよく、またはブロックチェーン・ネットワーク108内の信頼できるノード112に一意的に割り当てられてよい。
図2は、実施形態例に従って、インセンティブ・メカニズムの計算を示している。図2を参照すると、インセンティブ管理機能は、トランザクション検証に参加することを望んでいるすべてのノードから入札を受信することに応答して、トランザクション・パラメータを計算する(415)。インセンティブ管理機能116は、ノード112がブロックチェーン・ネットワーク108にサブミットした入札に基づいて、特定の期間内に、参加している各ノード112に一定の数のトランザクションを割り当てる。この期間は任意であり、事前に決定され、参加している各ノード112で同じ期間が使用されている限り、任意の長さの時間であってよい。まず、インセンティブ管理機能116は、ブロックチェーン・ネットワーク108がすべてのノード112によって1つの期間につき検証できるトランザクションの数を決定する。方程式(1)では、この数に値Lが割り当てられている。検証されたトランザクション120は、ブロックチェーンの台帳に追加される。すべての入札が受信された後に、インセンティブ管理機能116は、参加している各ノードi112によってブロックチェーン・ネットワーク108にサブミットされたトランザクションの数を計算する。各ノードi112は、参加しているすべてのノード112がsum(w)に等しい入札をサブミットするように、入札wをサブミットし、x個のトランザクションをネットワークにサブミットする能力を受け取る。次に、インセンティブ管理機能116は、参加しているノード112ごとに次のようにxを計算する。
(1)x = (w/sum(w))*L
例えば、1つの期間(1分)内に検証されるL=10のトランザクション、w=ノードi112の1ドルの入札、およびsum(w)=10ドルを仮定すると、x = (1/10)*10であり、ノードiによって1分ごとに1つのトランザクションがブロックチェーン・ネットワークにサブミットされてよい。
次に、インセンティブ管理機能116は、方程式(2)を使用して、参加しているすべてのノードi112についてトランザクション価格Pを計算する。インセンティブ管理機能116は、次のようにPを計算する。
(2)P = sum(W)/L
現在の例と同じパラメータを使用して、P=10ドル/10=1ドルのトランザクション価格(料金)になる。トランザクション価格Pは、参加しているすべてのノードi112で同じである。有利なことに、このプロセスのトランザクション価格Pは、トークンの価格またはノード112の共同体によって確立される料金によってではなく、需要によって全体的に決定される。
トランザクション価格Pが決定された後に、チャージバックを介して、入札による収入を検証ノード112に割り当てることができる。チャージバックは、中央機関によって、またはブロックチェーン・ネットワーク108をインスタンス化する前にすべての関係者が合意した分散アルゴリズムによって管理され得る。図2はインセンティブ管理機能116を含んでいるノード112のみを示しているが、他の実施形態では、ノード112の代わりに、中央機関または信頼できるエンティティがチャージバックの計算を実行するということが理解されるべきである。ブロックチェーン・ネットワーク108のスループットが、最も遅いノード112の速度であるため、チャージバックの式が価格決定力を遅いノード112に与えないということは、重要である。
ブロックチェーン・ネットワーク108は、P*Lの総収入を受け取る。現在の例の場合、総収入はP*L=1ドル*10=10ドルになる。参加している各ノード112には、式f(L)に従ってトランザクションの総数の一部が割り当てられる。実際に使用される式fおよびfは適用に依存してよく、異なるパラメータは、参加している各ノード112への異なる支払いの割り当てを生成する。例えば送信された金銭または発送であるトランザクションを受信する関係者によって操作されるノード112は、それらの関係者がブロックチェーン・ネットワーク108に参加するように、チャージバックによって援助され得る。例えば、発送ネットワーク(shipping network)は、ブロックチェーン・ネットワーク108に参加するために、多数のポートを必要とすることがある。別の例として、トランザクションを受信する大規模な関係者が、それらの関係者にトランザクションを送信する小規模な関係者を援助する(大規模な小売業者が卸売業者を援助するなど)。各ノードi112は、次の計算(3)に従って支払いを受け取る。
(3)Payment = P-i * f(L) - P * f(L)
-iは、ブロックチェーン・ネットワーク108内の別の(異なる)ノード112のスループットに基づく実勢価格であり、Pは、ノードiのトランザクションのスループットに基づく価格である。P-iは、ノードi112を除く、ブロックチェーン・ネットワーク108内のいずれかの他の参加しているノード112のスループットに基づくトランザクション価格を示す。したがって、4つの参加しているノード112を含むブロックチェーン・ネットワーク108の場合、現在のノードiがたまたまノード3であれば、P-3は、ノード1、2、または4のスループット(すなわち、「ブロックチェーン・ネットワーク108内の別のノード112のスループット」)からのトランザクション価格を使用して計算されたトランザクション価格を意味する。
実勢価格は、ブロックチェーン・ネットワーク108内の別のノード112のスループットを使用したトランザクション価格である。計算においてどの他のノード112が使用されるかは、式に応じて変わる可能性があるが、式は、選択された任意の他のノード112に適用できる。各ノード112のスループットが、2番目のペナルティ項を介してのみ、それらのノードの支払いに対して影響を与えるため、この式は効果的である。その結果、各ノードの支払いは、それらのノードが処理するトランザクションの数において増加し、ノード112がスループットを最大化して、トランザクションを検証するために効率的なハードウェアに投資することを促進する。例えば、f=L=10およびf=(N-1)/Nを仮定すると(Nは参加しているノード112の数)、N=4、f=(N-1)/N=(4-1)/4=3/4である。その後、各ノードは、他のノード112のスループットよりも遅らせるためのペナルティによって割り引かれたL/Nを受信する。-iが、ノードi112よりも速いノード112(例えば、最も速いノード112など)に基づいて設定された場合、支払いは収入を超えない。最も重要な参加しているノード112(最も多くのトランザクション120を受信するノード)が検証ノード112になることを促進するために、トランザクション120のフローによって決まるように式をカスタマイズすることもできる。このオプションは、投資に対する正の利益を得るための十分なトークンを有しているノードによってノードが操作されるプルーフ・オブ・ステーク・プロトコルを上回る別の利点を提供する。ノード112は、ブロックチェーン・ネットワーク108に参加し、トランザクションを素早く処理することによってブロックチェーン・ネットワーク108の運用を強化するために十分なリソースを割いていることに対して、報酬を受ける。これに対して、プルーフ・オブ・ステーク・ネットワークは、ブロックチェーン・ネットワークを運用するために役立つ活動ではなく、リソースをホストすることに関係のない、トークンを所有することに対して報酬を与える。
図3は、実施形態例に従って、ブロックチェーン・アーキテクチャの構成200を示している。図3を参照すると、ブロックチェーン・アーキテクチャ200は、特定のブロックチェーン要素(例えば、ブロックチェーン・ノードのグループ202)を含んでよい。ブロックチェーン・ノード202は、1つまたは複数のノード204~210を含んでよい(単に例として、4つのノードが示されている)。これらのノードは、ブロックチェーン・トランザクションの追加および検証プロセス(合意)などの、複数の活動に参加する。ブロックチェーン・ノード204~210のうちの1つまたは複数は、トランザクションに署名してよく、アーキテクチャ200内のすべてのブロックチェーン・ノードのための順序付けサービスを提供してよい。ブロックチェーン・ノードは、ブロックチェーン認証を開始し、ブロックチェーン層216に格納されたブロックチェーンの変更不可能な台帳に書き込もうとしてよく、この書き込みのコピーが、基盤になる物理的インフラストラクチャ214にも格納されてよい。ブロックチェーンの構成は、格納されたプログラム/アプリケーション・コード220(例えば、チェーンコード、スマート・コントラクトなど)にアクセスして実行するためにアプリケーション・プログラミング・インターフェイス(API:application programming interfaces)222にリンクされた1つまたは複数のアプリケーション224を含んでよく、プログラム/アプリケーション・コード220は、参加者によって要求されてカスタマイズされた構成に従って作成することができ、それら自身の状態を維持し、それら自身のアセットを制御し、外部の情報を受信することができる。ブロックチェーンの構成は、トランザクションとしてデプロイし、分散型台帳に追加することによって、すべてのブロックチェーン・ノード204~210にインストールすることができる。
ブロックチェーン・ベースまたはプラットフォーム212は、ブロックチェーン・データのさまざまな層と、サービス(例えば、暗号信用サービス(cryptographic trust services)218、仮想実行環境216など)と、新しいトランザクションを受信して格納し、データ・エントリにアクセスしようとしている監査人にアクセスを提供するために使用されてよい、基盤になる物理的コンピュータ・インフラストラクチャ214とを含んでよい。ブロックチェーン層216は、プログラム・コードを処理し、物理的インフラストラクチャ214に参加させるために必要な仮想実行環境へのアクセスを提供するインターフェイスを公開してよい。暗号信用サービス218は、アセット交換トランザクションなどのトランザクションを検証し、情報をプライベートに保つために使用されてよい。
図3のブロックチェーン・アーキテクチャの構成は、ブロックチェーン・プラットフォーム212によって公開された1つまたは複数のインターフェイスおよび提供されたサービスを介して、プログラム/アプリケーション・コード220を処理および実行してよい。アプリケーション・コード220は、ブロックチェーンのアセットを制御してよい。例えば、アプリケーション・コード220は、データを格納および転送することができ、スマート・コントラクトおよび条件を含む関連するチェーンコードまたは実行の対象になるその他のコード要素の形態で、ノード204~210によって実行されてよい。非限定的な例として、リマインダ、更新、または変更、更新の対象になるその他の通知、あるいはその組み合わせなどを実行するために、スマート・コントラクトが作成されてよい。スマート・コントラクト自体は、権限付与およびアクセスの要件ならびに台帳の使用に関連付けられたルールを識別するために使用され得る。例えば、ノードからの入札は、ブロックチェーン層216に含まれている1つまたは複数の処理エンティティ(例えば、仮想マシン)によって処理されてよい。その後、アプリケーション・コード220は、トランザクション価格(図示されていない)および検証ノード228へのチャージバックを計算してよい。物理的インフラストラクチャ214は、本明細書に記載されたデータまたは情報のいずれかを取り出すために利用されてよい。
チェーンコード内で、高水準のアプリケーションおよびプログラミング言語を使用して、スマート・コントラクトが作成され、その後、ブロックチェーン内のブロックに書き込まれてよい。スマート・コントラクトは、ブロックチェーン(例えば、ブロックチェーン・ピアの分散ネットワーク)への登録、格納、または複製、あるいはその組み合わせが実行される実行可能コードを含んでよい。トランザクションは、スマート・コントラクトが満たされていることに関連付けられた条件に応答して実行され得る、スマート・コントラクト・コードの実行である。スマート・コントラクトの実行は、デジタル・ブロックチェーン台帳の状態に対する信頼できる変更をトリガーしてよい。スマート・コントラクトの実行によって引き起こされるブロックチェーン台帳に対する変更は、1つまたは複数の合意プロトコルを介して、ブロックチェーン・ピアの分散ネットワーク全体に自動的に複製されてよい。
スマート・コントラクトは、データをキーと値のペアの形式でブロックチェーンに書き込んでよい。さらに、スマート・コントラクト・コードは、ブロックチェーンに格納された値を読み取り、それらをアプリケーションの動作において使用することができる。スマート・コントラクト・コードは、さまざまな論理演算の出力をブロックチェーンに書き込むことができる。このコードは、仮想マシンまたはその他のコンピューティング・プラットフォーム内の一時的データ構造を作成するために使用されてよい。ブロックチェーンに書き込まれたデータは、パブリックになること、またはプライベートとして暗号化されて維持されること、あるいはその両方が行われ得る。スマート・コントラクトによって使用/生成される一時的データは、提供された実行環境によってメモリ内に保持され、ブロックチェーンに必要なデータが識別された後に削除される。
チェーンコードは、追加機能と共に、スマート・コントラクトのコード解釈を含んでよい。本明細書に記載されているように、チェーンコードは、コンピューティング・ネットワーク上にデプロイされるプログラム・コードであってよく、合意プロセス中に、チェーン・バリデータ(chain validators)によって一緒に実行されて検証される。チェーンコードは、ハッシュを受信し、以前に格納された特徴抽出機能(feature extractor)の使用によって作成されたデータ・テンプレートに関連付けられたハッシュをブロックチェーンから取り出す。ハッシュ識別子のハッシュと、格納された識別子テンプレート・データから作成されたハッシュが一致する場合、チェーンコードは、権限付与キーを、要求されたサービスに送信する。チェーンコードは、暗号の詳細に関連付けられたデータをブロックチェーンに書き込んでよい。図3では、インセンティブ管理116を含んでいるブロックチェーン・プラットフォーム212は、トランザクションで入札しようとしているブロックチェーン・ノードから入札を受信する226。1つの機能は、チャージバックをノードに与える228ことであってよく、このチャージバックは、ノード204~210のうちの1つまたは複数に提供されてよい。
図4は、一実施形態例に従って、ブロックチェーンのノード間のトランザクション・フロー250の例を示している。図4を参照すると、トランザクション・フローは、アプリケーション・クライアント・ノード260またはクライアント・デバイスによって署名ピア・ノード(endorsing peer node)281に送信されるトランザクション提案291を含んでよい。署名ピア・ノード281は、クライアントの署名を検証し、チェーンコード関数を実行してトランザクションを開始してよい。出力は、チェーンコードの結果、チェーンコードに読み取られたキー/値のバージョンのセット(読み取られたセット)、およびチェーンコードに書き込まれたキー/値のセット(書き込まれたセット)を含んでよい。提案応答292が、承認されている場合は署名と共に、クライアント・ノード260に返送される。クライアント・ノード260は、署名をトランザクションのペイロード293にまとめて、順序付けサービス・ノード284にブロードキャストする。その後、順序付けサービス・ノード284は、順序付けられたトランザクションをチャネル上でブロックとしてすべてのピア・ノード281~283に配信する。ブロックチェーンへのコミットの前に、各ピア・ノード281~283がトランザクションを検証してよい。例えば、ピア・ノードは、指定されたピア・ノードの正しい割り当てが結果に署名し、トランザクションのペイロード293に対する署名を認証したことを確認するために、署名ポリシーをチェックしてよい。
再び図4を参照すると、クライアント・ノード260が、要求を構築してピア・ノード281(署名者)に送信することによって、トランザクション291を開始する。クライアント・ノード260は、NODE、JAVA、PYTHONなどのサポートされているソフトウェア開発キット(SDK:software development kit)を利用するアプリケーションを含んでよく、このアプリケーションは、使用可能なAPIを利用してトランザクション提案を生成する。提案は、データが台帳から読み取られること、または台帳に書き込まれること(すなわち、アセットの新しいキーと値のペアを書き込むこと)、あるいはその両方を実行できるように、チェーンコード関数を呼び出すことを求める要求である。SDKは、トランザクション提案を、適切に設計された形式(例えば、遠隔手続呼び出し(RPC:remote procedure call)を経由するプロトコル・バッファ)にパッケージ化するためのシム(shim)として機能し、クライアントの暗号認証情報を受け取って、トランザクション提案の一意の署名を生成してよい。
それに応じて、署名ピア・ノード281は、(a)トランザクション提案が適切に形成されていること、(b)トランザクションが過去にすでにサブミットされていないこと(リプレイ・アタック保護)、(c)署名が有効であること、および(d)そのチャネルに対する提案された操作を実行するための適切な権限がサブミッター(例では、クライアント・ノード260)に与えられていることを検証してよい。署名ピア・ノード281は、トランザクション提案の入力を、呼び出されるチェーンコード関数への引数として受け取ってよい。その後、チェーンコードが、現在の状態データベースに対して実行され、応答値、読み取りセット、および書き込みセットを含んでいるトランザクション結果を生成する。ただしこの時点では、台帳に対する更新は行われない。提案応答292で、値のセットが、署名ピア・ノード281の署名とともに、提案応答292としてクライアント・ノード260のSDKに返され、このSDKが、アプリケーションが使用するためのペイロードを構文解析する。
それに応じて、クライアント・ノード260のアプリケーションが、署名ピアの署名を検査/検証し、提案応答を比較して、提案応答292が同じであるかどうかを判定する。チェーンコードが単に台帳に問い合わせた場合、アプリケーションは問い合わせ応答を検査し、通常は、トランザクションを順序付けサービス・ノード284にサブミットしない。クライアント・アプリケーションが、台帳を更新するためにトランザクション291を順序付けサービス・ノード284にサブミットしようとしている場合、アプリケーションは、サブミットする前に、指定された署名ポリシーが満たされているかどうか(すなわち、トランザクション291に必要なすべてのピア・ノードがトランザクションに署名したかどうか)を判定する。ここで、クライアント・ノード260は、トランザクションの複数の関係者のうちの1つのみを含んでよい。この場合、各クライアント・ノード260は、それ自身の署名ノードを含んでよく、各署名ノードがトランザクションに署名する必要がある。アーキテクチャは、アプリケーションが応答292を検査しないことを選択するか、またはその他の方法で署名されていないトランザクションを転送する場合でも、署名ポリシーが、ピア・ノード281~283によってまだ実施され、コミット検証フェーズで維持されるようにする。
検査に成功した後に、ステップ293で、クライアント・ノード260が、署名をトランザクションにまとめ、順序付けノード284へのトランザクション・メッセージ293内でトランザクション提案およびトランザクション応答をブロードキャストする。トランザクション293は、読み取り/書き込みセット、署名ピアの署名、およびチャネルIDを含んでよい。順序付けノード284は、その動作を実行するために、トランザクション293の内容全体を検査する必要はなく、代わりに順序付けノード284は、単に、トランザクションをネットワーク内のすべてのチャネルから受信して、チャネル別に経時的に順序付けし、チャネルごとにトランザクションのブロックを作成してよい。
トランザクションのブロックは、順序付けノード284からチャネル上のすべてのピア・ノード281~283に配信される。いずれかの署名ポリシーが満たされていることを保証するため、および読み取りセットがトランザクションの実行によって生成されて以来、読み取りセットの変数に関して台帳の状態に対する変更がないことを保証するために、ブロック内のトランザクション294が検証される。ブロック内のトランザクション294は、有効または無効であるとしてタグ付けされる。さらに、ステップ295で、各ピア・ノード281~283は、ブロックをチャネルのチェーンに追加し、有効なトランザクション294ごとに、書き込みセットが現在の状態データベースにコミットされる。トランザクション(呼び出し)が変更不可能なようにチェーンに追加されたことをクライアント・アプリケーションに通知するため、およびトランザクション294が有効にされたか、または無効にされたかを通知するために、イベントが発行される。
図5は許可型ブロックチェーン・ネットワーク310の例を示しており、許可型ブロックチェーン・ネットワーク310は、分散型の非集中的ピアツーピア・アーキテクチャ、ならびにユーザの役割および権限を管理する認証局318を特徴とする。この例では、ブロックチェーン・ユーザ302は、トランザクションを許可型ブロックチェーン・ネットワーク310にサブミットしてよい。この例では、トランザクションは、デプロイ、呼び出し、または問い合わせであることができ、SDKを利用するクライアント側のアプリケーションを介して、REST APIを介して直接的に、または同様の方法によって、発行されてよい。信頼できるビジネス・ネットワークは、監査人(例えば、米国の株式市場における証券取引委員会)などの規制者システム(regulator system)314にアクセスを提供してよい。一方、ノード312のブロックチェーン・ネットワーク運用者システムは、規制者システム314を「監査人」として登録し、ブロックチェーン・ユーザ302を「クライアント」として登録するなどの、メンバーの権限を管理する。監査人を、台帳への問い合わせのみに制限することができ、一方、特定の種類のチェーンコードのデプロイ、呼び出し、および問い合わせを行うための権限をクライアントに与えることができる。
ブロックチェーン開発者システム316は、チェーンコードおよびクライアント側のアプリケーションを書き込む。ブロックチェーン開発者システム316は、RESTインターフェイスを介して、チェーンコードをネットワークに直接デプロイすることができる。従来のデータ・ソース330からの認証情報をチェーンコードに含めるために、開発者システム316は、帯域外接続を使用してデータにアクセスすることができる。この例では、ブロックチェーン・ユーザ302は、ピア・ノード312を介してネットワークに接続する。ピア・ノード312は、いずれかのトランザクションを開始する前に、ユーザの登録およびトランザクション証明書を認証局318から取得する。場合によっては、ブロックチェーン・ユーザ302は、許可型ブロックチェーン・ネットワーク310上でトランザクションを実行するために、それらのデジタル証明書を有しなければならない。一方、チェーンコードを動作させようとしているブロックチェーン・ユーザ302は、従来のデータ・ソース330上のそれらのブロックチェーン・ユーザ302の認証情報を検証することが必要になることがある。ユーザの権限付与を確認するために、チェーンコードは、従来の処理プラットフォーム320を介して、このデータへの帯域外接続を使用することができる。
図6は、実施形態例に従って、トランザクションおよびチャージバックを実行するためのシステム・メッセージ図を示している。図6を参照すると、システム図400は、1人または複数のユーザ410、1つまたは複数のブロックチェーン・ノード420、および料金台帳430を含んでいる。1人または複数のユーザ410は、ノード420を含んでいるブロックチェーン・ネットワーク108への新しいトランザクションを作成する(412)。ノード420は、トランザクションを受信し(413)、受信したトランザクション413を他のノード420に通知する。それに応じて、検証入札プロセス(validation bidding process)に参加することを望むノード420は、入札をブロックチェーン・ネットワーク108のノード420にサブミットする(414)。ノードは、図2を参照して説明されたように、トランザクション・パラメータを計算する(415)。トランザクション412の実行に備えて、ノード420は、トランザクションのペイロードをブロックチェーンに解放する(418)。その後、トランザクション414の入札をサブミットしたノード420は、トランザクションを検証する(421)。トランザクション421を検証するノード420は、検証されたトランザクションを、分散型台帳(図示されていない)のトランザクションのコピーに追加する。トランザクションを検証するために、検証ノード420が入札またはトランザクションをサブミットする必要がないということに注意するべきである。
トランザクション412の種類に応じて、トランザクションが検証された(421)後に、ノード420が、トランザクションのペイロード418に基づいてトランザクションを実行する(422)。一実施形態では、その後、入札プロセスに関与する各ノード420は、図2に示されている計算の結果に応じて、1つまたは複数のノード420へのチャージバックを計算する(423)。別の実施形態では、ブロックチェーン・ネットワーク内の信頼できるエンティティ(ノード420であってよい)が、1つまたは複数のノード420へのチャージバックを計算する(423)。その後、ノード420は、料金台帳を更新し(424)、料金台帳に対して責任を負う信頼できるエンティティが、既定の時間(すなわち、日、週、月、四半期などの最後)にチャージバックを1つまたは複数のノード420に配信する(425)。これによって、有利なことに、絶え間ない中断およびコストを伴わずに、料金がブロックチェーン・ネットワーク108内を流れることができるようにしてよい。
図7は、実施形態例に従って、トランザクションのチャージバックを計算してブロックチェーン内で配信する例示的な方法のフロー図500を示している。図7を参照すると、方法500は、トランザクションを検証するためにノードが入札をサブミットすること(504)を含んでよい。ノード420の総数よりも少ないノード420が入札をサブミットしてよく、少なくとも1つのノード420が入札をサブミットする。方法500は、トランザクション価格およびノードごとのトランザクション数を計算するステップ(508)を含んでもよい。これらの計算は、多くの形態を取ってよく、図2は、可能性のある一連の計算を示している。方法500は、トランザクションの検証に備えて、トランザクションをブロックチェーンにサブミットするステップ(512)を含んでもよい。方法500は、ノードがブロックチェーン・トランザクションを検証するステップ(516)を含んでもよい。トランザクションを検証するステップは、ブロックチェーン技術において十分理解されている。方法500は、チャージバックを計算するステップ(520)を含んでもよい。この計算は、図2の例においても表されており、トランザクションを検証したノード420に支払われる量である。最後に、方法500は、トランザクションの検証に対する補償としてノード420がチャージバックを受信するステップ(524)を含んでもよい。最後に、方法500は、トランザクションをサブミットしたノードまたはクライアント・デバイスに対して、トランザクション料金を請求することを含んでもよい(図示されていない)。
図8は、実施形態例に従って、トランザクション料金を計算する例示的な方法のフロー図550を示している。方法550は、トランザクション料金に資金を提供することを求める要求を受信すること(554)を含んでよい。方法550は、資金提供されるトランザクション料金の数値に基づいて各トランザクション料金を計算するステップ(558)を含んでもよい。方法550は、資金提供されるトランザクション料金を請求するステップ(562)を含んでもよい。方法550は、資金提供されるトランザクション料金を支払うための資金を受信するステップ(566)を含んでもよい。方法550は、資金提供されるトランザクション料金に関連する情報を格納するステップ(570)を含んでもよい。
図9は、実施形態例に記載されている動作の例示的な方法のうちの1つまたは複数に従って、ブロックチェーンに対してさまざまな動作を実行するように構成された例示的な物理的インフラストラクチャを示している。図9を参照すると、例示的な構成600は、ブロックチェーン620およびスマート・コントラクト640を含んでいる物理的インフラストラクチャ610を含んでおり、物理的インフラストラクチャ610は、実施形態例のいずれかに含まれている動作のステップ612のいずれかを実行してよい。ステップ/動作612は、1つまたは複数のフロー図または論理図あるいはその両方において説明されたか、または示されたステップのうちの1つまたは複数を含んでよい。これらのステップは、コンピュータ・システムの構成の物理的インフラストラクチャ610上に存在する1つまたは複数のスマート・コントラクト640またはブロックチェーン620あるいはその両方に書き込まれるか、またはこれらから読み取られる、出力されたか、または書き込まれた情報を表してよい。実行されたスマート・コントラクト640またはブロックチェーン620あるいはその両方から、データが出力され得る。物理的インフラストラクチャ610は、1つまたは複数のコンピュータ、サーバ、プロセッサ、メモリ、または無線通信デバイス、あるいはその組み合わせを含んでよい。
図10は、実施形態例に従って、契約当事者間での例示的なスマート・コントラクトの構成、およびブロックチェーンに対してスマート・コントラクトの条件を実施するように構成された仲介サーバを示している。図10を参照すると、構成650は、通信セッション、アセット転送セッションまたはプロセスあるいは手順を表してよく、これらは、1つまたは複数のユーザ・デバイス652または656あるいはその両方を明示的に識別するスマート・コントラクト640によって動作させられる。スマート・コントラクトの実行、動作、および実行結果は、サーバ654によって管理されてよい。スマート・コントラクト640の内容は、スマート・コントラクト・トランザクションの関係者であるエンティティ652および656のうちの1つまたは複数によるデジタル署名を要求してよい。スマート・コントラクト640の実行結果は、ブロックチェーン・トランザクションとしてブロックチェーンに書き込まれてよい。
前述の実施形態は、ハードウェアにおいて、プロセッサによって実行されるコンピュータ・プログラムにおいて、ファームウェアにおいて、またはこれらの組み合わせにおいて実装されてよい。コンピュータ・プログラムは、ストレージ媒体などのコンピュータ可読媒体に具現化されてよい。例えば、コンピュータ・プログラムは、ランダム・アクセス・メモリ(RAM:random access memory)、フラッシュ・メモリ、読み取り専用メモリ(ROM:read-only memory)、消去可能プログラマブル読み取り専用メモリ(EPROM:erasable programmable read-only memory)、電子的消去可能プログラマブル読み取り専用メモリ(EEPROM:electrically erasable programmable read-only memory)、レジスタ、ハード・ディスク、取り外し可能なディスク、コンパクト・ディスク読み取り専用メモリ(CD-ROM:compact disk read-only memory)、または従来技術において知られた任意のその他の形態のストレージ媒体に存在してよい。
例示的なストレージ媒体は、プロセッサがストレージ媒体から情報を読み取り、ストレージ媒体に情報を書き込むことができるように、プロセッサに接続されてよい。代替方法では、ストレージ媒体はプロセッサと一体であってよい。プロセッサおよびストレージ媒体は、特定用途向け集積回路(ASIC:application specific integrated circuit)に存在してよい。代替方法では、プロセッサおよびストレージ媒体は、個別のコンポーネントとして存在してよい。例えば、図11は、前述したコンポーネントのいずれかなどで表すか、またはそれらに統合されてよい、例示的なコンピュータ・システム・アーキテクチャ700を示している。
図11は、本明細書に記載された本出願の実施形態の使用または機能の範囲に関して、いかなる制限を示唆することも意図されていない。いずれにせよ、コンピューティング・ノード700は、前述した機能のいずれかを実装すること、または実行すること、あるいはその両方を行うことができる。コンピューティング・ノード700内には、他の多数の汎用または特殊用途のコンピューティング・システム環境または構成で運用できるコンピュータ・システム/サーバ702が存在する。コンピュータ・システム/サーバ702と共に使用するのに適した周知のコンピューティング・システム、環境、または構成、あるいはその組み合わせの例は、パーソナル・コンピュータ・システム、サーバ・コンピュータ・システム、シン・クライアント、シック・クライアント、ハンドヘルドまたはラップトップ・デバイス、マルチプロセッサ・システム、マイクロプロセッサベース・システム、セット・トップ・ボックス、プログラマブル・コンシューマ・エレクトロニクス、ネットワークPC、ミニコンピュータ・システム、メインフレーム・コンピュータ・システム、およびこれらの任意のシステムまたはデバイスを含む分散クラウド・コンピューティング環境などを含むが、これらに限定されない。
コンピュータ・システム/サーバ702は、コンピュータ・システムによって実行されているプログラム・モジュールなどの、コンピュータ・システムによって実行可能な命令との一般的な関連において説明されてよい。通常、プログラム・モジュールは、特定のタスクを実行するか、または特定の抽象データ型を実装するルーチン、プログラム、オブジェクト、コンポーネント、論理、データ構造などを含むことができる。コンピュータ・システム/サーバ702は、通信ネットワークを介してリンクされたリモート処理デバイスによってタスクが実行される、分散クラウド・コンピューティング環境で実行されてよい。分散クラウド・コンピューティング環境において、プログラム・モジュールは、メモリ・ストレージ・デバイスを含む、ローカルおよびリモートの両方のコンピュータ・システム・ストレージ媒体に配置されてよい。
図11に示すように、クラウド・コンピューティング・ノード700内のコンピュータ・システム/サーバ702は、汎用コンピューティング・デバイスの形態で示されている。コンピュータ・システム/サーバ702のコンポーネントは、1つまたは複数のプロセッサまたは処理ユニット704、システム・メモリ706、およびシステム・メモリ706を含むさまざまなシステム・コンポーネントをプロセッサ704に接続するバスを含んでよいが、これらに限定されない。
バスは、メモリ・バスまたはメモリ・コントローラ、ペリフェラル・バス、アクセラレーテッド・グラフィックス・ポート、および任意のさまざまなバス・アーキテクチャを使用するプロセッサまたはローカル・バスを含む、1つまたは複数の任意の種類のバス構造を表す。例として、そのようなアーキテクチャは、ISA(Industry Standard Architecture)バス、MCA(Micro Channel Architecture)バス、EISA(Enhanced ISA)バス、VESA(Video Electronics Standards Association)ローカル・バス、およびPCI(Peripheral Component Interconnects)バスを含むが、これらに限定されない。
コンピュータ・システム/サーバ702は、通常、さまざまなコンピュータ・システム可読媒体を含む。そのような媒体は、コンピュータ・システム/サーバ702によってアクセスできる任意の使用可能な媒体であってよく、揮発性および不揮発性媒体、取り外し可能および取り外し不可の媒体を含む。システム・メモリ706は、一実施形態では、他の図のフロー図を実装する。システム・メモリ706は、ランダム・アクセス・メモリ(RAM:random access memory)710またはキャッシュ・メモリ712あるいはその両方などの、揮発性メモリの形態でのコンピュータ・システム可読媒体を含むことができる。コンピュータ・システム/サーバ702は、その他の取り外し可能/取り外し不可、揮発性/不揮発性のコンピュータ・システム・ストレージ媒体をさらに含んでよい。単に例として、取り外し不可、不揮発性の磁気媒体(図示されておらず、通常は「ハード・ドライブ」と呼ばれる)に対する読み取りと書き込みを行うために、ストレージ・システム714を提供することができる。図示されていないが、取り外し可能、不揮発性の磁気ディスク(例えば、「フロッピー・ディスク」)に対する読み取りと書き込みを行うための磁気ディスク・ドライブ、およびCD-ROM、DVD-ROM、またはその他の光媒体などの取り外し可能、不揮発性の光ディスクに対する読み取りと書き込みを行うための光ディスク・ドライブを提供することができる。そのような例では、それぞれを、1つまたは複数のデータ媒体インターフェイスによってバスに接続することができる。下で詳細に示され、説明されるように、メモリ706は、本出願のさまざまな実施形態の機能を実行するように構成された一連の(例えば、少なくとも1つの)プログラム・モジュールを備える少なくとも1つのプログラム製品を含んでよい。
例えば、一連の(少なくとも1つの)プログラム・モジュール718を含んでいるプログラム/ユーティリティ716がメモリ706に格納されてよいが、これに限定されず、オペレーティング・システム、1つまたは複数のアプリケーション・プログラム、その他のプログラム・モジュール、およびプログラム・データも格納されてよい。オペレーティング・システム、1つまたは複数のアプリケーション・プログラム、その他のプログラム・モジュール、およびプログラム・データまたはこれらの組み合わせは、それぞれネットワーク環境の実装を含んでよい。プログラム・モジュール718は、通常、本明細書に記載された本出願のさまざまな実施形態の機能または方法あるいはその両方を実行する。
当業者によって理解されるように、本出願の態様は、システム、方法、またはコンピュータ・プログラム製品として具現化されてよい。したがって、本出願の態様は、完全にハードウェアの実施形態、完全にソフトウェアの実施形態(ファームウェア、常駐ソフトウェア、マイクロコードなどを含む)、またはソフトウェアの態様とハードウェアの態様を組み合わせる実施形態の形態を取ってよく、これらはすべて、本明細書では、一般に「回路」、「モジュール」、または「システム」と呼ばれてよい。さらに、本出願の形態は、コンピュータ可読プログラム・コードが具現化されている1つまたは複数のコンピュータ可読媒体において具現化されたコンピュータ・プログラム製品の形態を取ってよい。
また、コンピュータ・システム/サーバ702は、キーボード、ポインティング・デバイス、ディスプレイ722などの1つまたは複数の外部デバイス720、ユーザがコンピュータ・システム/サーバ702と情報をやりとりできるようにする1つまたは複数のデバイス、またはコンピュータ・システム/サーバ702が1つまたは複数の他のコンピューティング・デバイスと通信できるようにする任意のデバイス(例えば、ネットワーク・カード、モデムなど)、あるいはその組み合わせと通信してもよい。このような通信は、I/Oインターフェイス724を介して行うことができる。さらに、コンピュータ・システム/サーバ702は、ローカル・エリア・ネットワーク(LAN:local area network)、一般的な広域ネットワーク(WAN:wide area network)、またはパブリック・ネットワーク(例えば、インターネット)、あるいはその組み合わせなどの1つまたは複数のネットワークと、ネットワーク・アダプタ726を介して通信することができる。図示されているように、ネットワーク・アダプタ726は、バスを介してコンピュータ・システム/サーバ702の他のコンポーネントと通信する。図示されていないが、その他のハードウェア・コンポーネントまたはソフトウェア・コンポーネントあるいはその両方を、コンピュータ・システム/サーバ702と併用できるということが理解されるべきである。その例として、マイクロコード、デバイス・ドライバ、冗長処理ユニット、外部ディスク・ドライブ・アレイ、RAIDシステム、テープ・ドライブ、およびデータ・アーカイブ・ストレージ・システムなどが挙げられるが、これらに限定されない。
システム、方法、およびコンピュータ・プログラムのうちの少なくとも1つの実施形態例が添付の図面において示され、前述の詳細な説明において説明されたが、本出願が、開示された実施形態に限定されず、以下の特許請求の範囲によって示され、定義されているように、多数の再配置、変更、および置き換えを行うことができるということが理解されるであろう。例えば、さまざまな図のシステムの機能は、本明細書に記載されたモジュールまたはコンポーネントのうちの1つまたは複数によって、あるいは分散アーキテクチャにおいて実行することができ、送信器、受信器、またはその両方のペアを含んでよい。例えば、個々のモジュールによって実行される機能の全部または一部は、それらのモジュールのうちの1つまたは複数によって実行されてよい。さらに、本明細書に記載された機能は、さまざまな時間に、さまざまなイベントに関して、モジュールまたはコンポーネントの内部または外部で、実行されてよい。また、さまざまなモジュールの間で送信される情報は、データ・ネットワーク、インターネット、音声ネットワーク、インターネット・プロトコル・ネットワーク、無線デバイス、有線デバイスのうちの少なくとも1つを介して、または複数のプロトコルを介して、あるいはその組み合わせを介して、モジュール間で送信され得る。また、モジュールのいずれかによって送信または受信されるメッセージは、直接的に、または他のモジュールのうちの1つまたは複数を介して、あるいはその両方によって、送信または受信されてよい。
当業者は、「システム」を、パーソナル・コンピュータ、サーバ、コンソール、PDA(personal digital assistant)、携帯電話、タブレット・コンピューティング・デバイス、スマートフォン、または任意のその他の適切なコンピューティング・デバイス、あるいはデバイスの組み合わせとして具現化できるということを、理解するであろう。「システム」によって実行されている前述の機能を提示することは、本出願の範囲を限定するように全く意図されておらず、多くの実施形態のうちの1つの例を提供するよう意図されている。実際に、本明細書で開示された方法、システム、および装置は、計算技術に一致する局所的な分散された形態で実装されてよい。
本明細書において説明されたシステムの特徴の一部が、それらの実装の独立性を特に強調するために、モジュールとして提示されていることに、注意するべきである。例えば、モジュールは、カスタム超大規模集積(VLSI:very large-scale integration)回路またはゲート・アレイ、論理チップなどの市販の半導体、トランジスタ、またはその他の個別のコンポーネントを備えているハードウェア回路として実装されてよい。モジュールは、フィールド・プログラマブル・ゲート・アレイ、プログラマブル・アレイ論理、プログラマブル論理デバイス、グラフィックス処理ユニットなどの、プログラム可能なハードウェア・デバイスにおいて実装されてもよい。
モジュールは、さまざまな種類のプロセッサによって実行するために、ソフトウェアにおいて少なくとも部分的に実装されてもよい。例えば、実行可能コードの識別されたユニットは、例えばオブジェクト、プロシージャ、または関数として編成されてよいコンピュータ命令の1つまたは複数の物理的または論理的ブロックを備えてよい。それにもかかわらず、識別されたモジュールの実行ファイルは、物理的に一緒に配置される必要はなく、異なる位置に格納された異種の命令を含んでよく、それらの命令は、論理的に一緒に結合された場合にモジュールを構成し、モジュールの規定された目的を達成する。さらに、モジュールはコンピュータ可読媒体に格納されてよく、このコンピュータ可読媒体は、例えば、ハード・ディスク・ドライブ、フラッシュ・デバイス、ランダム・アクセス・メモリ(RAM)、テープ、またはデータの格納に使用される任意のその他の媒体であってよい。
実際に、実行可能コードのモジュールは、単一の命令であるか、または多くの命令であることができ、複数の異なるコード・セグメントにわたって、異なるプログラム間および複数のメモリ・デバイスにまたがって、分散されてもよい。同様に、操作可能なデータが、識別され、本明細書ではモジュール内で示されてよく、任意の適切な形態で具現化され、任意の適切な種類のデータ構造内で編成されてよい。操作可能なデータは、単一のデータ・セットとして収集されてよく、または異なるストレージ・デバイスを含む、異なる位置にわたって分散されてよく、システムまたはネットワーク上の単なる電子信号として、少なくとも部分的に存在してよい。
本明細書の図において概略的に説明され、示されているように、本出願のコンポーネントが、多種多様な異なる構成で配置および設計されてよいということが、容易に理解されるであろう。したがって、実施形態の詳細な説明は、請求される本出願の範囲を限定するよう意図されておらず、単に、本出願の選択された実施形態を表している。
当業者は、開示された順序とは異なる順序でステップを使用して、または開示された構成におけるハードウェア要素とは異なるハードウェア要素を使用して、あるいはその両方を使用して、前述の内容を実践できるということを、容易に理解するであろう。したがって、本出願は、これらの好ましい実施形態に基づいて説明されたが、特定の変更、変形、および代替の構造が明白であるということは、当業者にとって明らかであろう。
本出願の好ましい実施形態が説明されたが、説明された実施形態が単なる例であり、それらの実施形態と同等のものおよびそれらの実施形態に対する変更の完全な範囲(例えば、プロトコル、ハードウェア・デバイス、ソフトウェア・プラットフォームなど)で考えた場合、本出願の範囲が添付の特許請求の範囲のみによって定義されるべきであるということが、理解されるべきである。
100 ブロックチェーン・システム
104 ユーザ・デバイス
108 ブロックチェーン・ネットワーク
112 ブロックチェーン・ノード
116 インセンティブ管理機能
120 トランザクション
200 ブロックチェーン・アーキテクチャ
202 ブロックチェーン・ノード
212 ブロックチェーン・ベースまたはプラットフォーム
214 物理的コンピュータ・インフラストラクチャ
216 ブロックチェーン層
218 暗号信用サービス
220 プログラム/アプリケーション・コード
222 アプリケーション・プログラミング・インターフェイス
224 アプリケーション
260 アプリケーション・クライアント・ノード
281 署名ピア・ノード
284 順序付けサービス・ノード
291 トランザクション提案
292 提案応答
293 トランザクションのペイロード
294 トランザクション
302 ブロックチェーン・ユーザ
310 許可型ブロックチェーン・ネットワーク
312 ピア・ノード
314 規制者システム
316 ブロックチェーン開発者システム
318 認証局
320 処理プラットフォーム
330 データ・ソース
410 ユーザ
420 ブロックチェーン・ノード
430 料金台帳
610 物理的インフラストラクチャ
620 ブロックチェーン
640 スマート・コントラクト
652 ユーザ・デバイス、エンティティ
654 サーバ
656 ユーザ・デバイス、エンティティ
700 コンピュータ・システム・アーキテクチャ、クラウド・コンピューティング・ノード
702 コンピュータ・システム/サーバ
704 処理ユニット
706 システム・メモリ
710 ランダム・アクセス・メモリ
712 キャッシュ・メモリ
714 ストレージ・システム
716 プログラム/ユーティリティ
718 プログラム・モジュール
720 外部デバイス
722 ディスプレイ
724 I/Oインターフェイス
726 ネットワーク・アダプタ

Claims (8)

  1. トランザクションをサブミットするように構成されたユーザ・デバイスと、
    複数のノードのうちの1つまたは複数の検証ノードを含んでいる、前記ユーザ・デバイスに接続されたブロックチェーン・ネットワークであって、前記トランザクションの受信に応答して、
    前記1つまたは複数の検証ノードから、前記トランザクションを検証するために入札を前記ブロックチェーン・ネットワーク内の前記1つまたは複数の検証ノードとは異なるノードにサブミットすることと、
    前記1つまたは複数の検証ノードによってサブミットされた入札の合計を既定の期間内に前記ブロックチェーン・ネットワークによって検証できるトランザクションの量で除することでトランザクション料金を算出することと、
    前記1つまたは複数の検証ノードによって、前記トランザクションを検証することと、
    前記トランザクションを実行することと、
    を実行するように構成されている、前記ブロックチェーン・ネットワークとを備えた、
    システム。
  2. 前記ブロックチェーン・ネットワークが許可型ブロックチェーン・ネットワークである、請求項1に記載のシステム。
  3. 前記ブロックチェーン・ネットワークは、前記ユーザ・デバイスに対して前記トランザクション料金を請求する、請求項2に記載のシステム。
  4. ブロックチェーン・ネットワークによって、ユーザ・デバイスからトランザクションを受信することと、
    複数のノードのうち1つまたは複数の検証ノードから、前記トランザクションを検証するために入札を前記ブロックチェーン・ネットワーク内の前記1つまたは複数の検証ノードとは異なるノードにサブミットすることと、
    前記1つまたは複数の検証ノードによってサブミットされた入札の合計を既定の期間内に前記ブロックチェーン・ネットワークによって検証できるトランザクションの量で除することでトランザクション料金を算出することと、
    前記1つまたは複数の検証ノードによって、前記トランザクションを検証することと、
    前記ブロックチェーン・ネットワーク内のノードによって、前記トランザクションを実行することと、を含む、
    方法。
  5. 前記ブロックチェーン・ネットワークが許可型ブロックチェーン・ネットワークである、請求項4に記載の方法。
  6. 命令を含んでいるコンピュータ・プログラムであって、前記命令が、プロセッサによって読み取られたときに、前記プロセッサに、
    ブロックチェーン・ネットワークによって、ユーザ・デバイスからトランザクションを受信することと、
    複数のノードのうち1つまたは複数の検証ノードから、前記トランザクションを検証するために入札を前記ブロックチェーン・ネットワーク内の前記1つまたは複数の検証ノードとは異なるノードにサブミットすることと、
    前記1つまたは複数の検証ノードによってサブミットされた入札の合計を既定の期間内に前記ブロックチェーン・ネットワークによって検証できるトランザクションの量で除することでトランザクション料金を算出することと、
    前記1つまたは複数の検証ノードによって、前記トランザクションを検証することと、
    前記ブロックチェーン・ネットワーク内のノードによって、前記トランザクションを実行することと、
    を含むプログラムを実行させる、コンピュータ・プログラム。
  7. 前記ブロックチェーン・ネットワークが許可型ブロックチェーン・ネットワークである、請求項に記載のコンピュータ・プログラム。
  8. 前記ブロックチェーン・ネットワークは、前記ユーザ・デバイスに対して前記トランザクション料金を請求する、請求項又はに記載のコンピュータ・プログラム。
JP2019042365A 2018-03-15 2019-03-08 ブロックチェーンのためのリソースの公平性のためのシステム、方法、およびコンピュータ・プログラム Active JP7450339B2 (ja)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US15/922,639 US20190287107A1 (en) 2018-03-15 2018-03-15 Resource equity for blockchain
US15/922639 2018-03-15

Publications (2)

Publication Number Publication Date
JP2019160316A JP2019160316A (ja) 2019-09-19
JP7450339B2 true JP7450339B2 (ja) 2024-03-15

Family

ID=67905803

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2019042365A Active JP7450339B2 (ja) 2018-03-15 2019-03-08 ブロックチェーンのためのリソースの公平性のためのシステム、方法、およびコンピュータ・プログラム

Country Status (2)

Country Link
US (1) US20190287107A1 (ja)
JP (1) JP7450339B2 (ja)

Families Citing this family (28)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10419225B2 (en) 2017-01-30 2019-09-17 Factom, Inc. Validating documents via blockchain
US10411897B2 (en) 2017-02-17 2019-09-10 Factom, Inc. Secret sharing via blockchains
US10817873B2 (en) 2017-03-22 2020-10-27 Factom, Inc. Auditing of electronic documents
US11159306B2 (en) * 2018-04-24 2021-10-26 Duvon Corporation Autonomous exchange via entrusted ledger token and transaction management
US10855446B2 (en) * 2018-04-24 2020-12-01 Duvon Corporation Autonomous exchange via entrusted ledger
US11170366B2 (en) 2018-05-18 2021-11-09 Inveniam Capital Partners, Inc. Private blockchain services
US11134120B2 (en) * 2018-05-18 2021-09-28 Inveniam Capital Partners, Inc. Load balancing in blockchain environments
CN109003078B (zh) 2018-06-27 2021-08-24 创新先进技术有限公司 基于区块链的智能合约调用方法及装置、电子设备
CN108898390B (zh) * 2018-06-27 2021-01-12 创新先进技术有限公司 基于区块链的智能合约调用方法及装置、电子设备
US11620642B2 (en) 2018-08-06 2023-04-04 Inveniam Capital Partners, Inc. Digital contracts in blockchain environments
US11989208B2 (en) 2018-08-06 2024-05-21 Inveniam Capital Partners, Inc. Transactional sharding of blockchain transactions
US11328290B2 (en) 2018-08-06 2022-05-10 Inveniam Capital Partners, Inc. Stable cryptocurrency coinage
JP7138233B2 (ja) 2018-08-10 2022-09-15 ティーゼロ・アイピー,エルエルシー スマートコントラクトベースの投資家のグローバルレジストリを参照するスマートコントラクトベースのコンプライアンス規則を実施する自己執行型証券トークン
US20200082405A1 (en) * 2018-09-12 2020-03-12 NEC Laboratories Europe GmbH Method and system for client support in a blockchain network
GB2577118B (en) * 2018-09-14 2022-08-31 Arqit Ltd Autonomous quality regulation for distributed ledger networks
JP6651083B1 (ja) * 2019-10-01 2020-02-19 イーサセキュリティ パシフィックホールディングス プライベート リミテッド 仮想通貨運用方法
WO2020035089A2 (en) 2019-11-08 2020-02-20 Alipay (Hangzhou) Information Technology Co., Ltd. System and method for blockchain-based decentralized application development
WO2020035090A2 (en) 2019-11-08 2020-02-20 Alipay (Hangzhou) Information Technology Co., Ltd. Lightweight decentralized application platform
CN113383364B (zh) * 2019-12-03 2023-05-16 深圳市迅雷网络技术有限公司 验证人节点选择方法、电子设备、系统及介质
JP6710401B1 (ja) 2019-12-05 2020-06-17 bacoor dApps株式会社 対象物を管理する方法及び管理サーバ
CN111881147B (zh) * 2019-12-13 2023-09-22 深圳数字生命研究院 计算任务的处理方法和装置、存储介质及处理器
SG10201912999VA (en) * 2019-12-23 2020-09-29 Islamic Res And Training Institute Method and System for Transaction Validation in a Distributed Computing System
CN111127160B (zh) * 2019-12-24 2024-04-09 京东科技信息技术有限公司 用于碳资产交易的数据处理方法、装置和区块链系统
US11343075B2 (en) 2020-01-17 2022-05-24 Inveniam Capital Partners, Inc. RAM hashing in blockchain environments
CN113568980B (zh) * 2021-08-09 2023-10-31 北京恒安嘉新安全技术有限公司 区块链信息监测方法、装置、设备及存储介质
JP7175046B1 (ja) 2021-11-09 2022-11-18 充宏 前田 取引支援システム、取引支援方法及びプログラム
JP7223462B1 (ja) 2021-11-09 2023-02-16 充宏 前田 取引支援システム、取引支援方法及びプログラム
WO2024061453A1 (en) * 2022-09-21 2024-03-28 Huawei Cloud Computing Technologies Co., Ltd. Preventing denial of service by exploitive members in permissioned blockchain networks

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20140006264A1 (en) 2012-07-02 2014-01-02 Mastercard International Incorporated Systems and methods for settling chargeback transactions
WO2016161073A1 (en) 2015-03-31 2016-10-06 Nasdaq, Inc. Systems and methods of blockchain transaction recordation
US20170046664A1 (en) 2015-08-13 2017-02-16 The Toronto-Dominion Bank Systems and methods for tracking and transferring ownership of connected devices using blockchain ledgers

Family Cites Families (56)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CA2266208C (en) * 1999-03-19 2008-07-08 Wenking Corp. Remote road traffic data exchange and intelligent vehicle highway system
US7474668B2 (en) * 2002-06-04 2009-01-06 Alcatel-Lucent Usa Inc. Flexible multilevel output traffic control
US7444263B2 (en) * 2002-07-01 2008-10-28 Opnet Technologies, Inc. Performance metric collection and automated analysis
GB2396522B (en) * 2002-12-18 2006-01-04 Motorola Inc Method and apparatus for determining a transmit power
DE10339440A1 (de) * 2003-08-25 2005-04-07 Demag Cranes & Components Gmbh Verfahren zur Überwachung eines Kettenzuges und Kettenzug
US7594035B2 (en) * 2008-02-22 2009-09-22 Tactara, Llc Methods of providing published content
US8315940B2 (en) * 2010-04-27 2012-11-20 Omx Technology Ab System and method for rapidly calculating risk in an electronic trading exchange
US20150363782A1 (en) * 2014-06-16 2015-12-17 Bank Of America Corporation Cryptocurrency transaction validation system
US20160034884A1 (en) * 2014-08-01 2016-02-04 Mastercard International Incorporated Method and system for chargeback of counterfeit goods
US10692085B2 (en) * 2015-02-13 2020-06-23 Yoti Holding Limited Secure electronic payment
US10339523B2 (en) * 2015-07-14 2019-07-02 Fmr Llc Point-to-point transaction guidance apparatuses, methods and systems
US11488147B2 (en) * 2015-07-14 2022-11-01 Fmr Llc Computationally efficient transfer processing and auditing apparatuses, methods and systems
US20190005469A1 (en) * 2015-07-14 2019-01-03 Fmr Llc Collateral Management With Blockchain and Smart Contracts Apparatuses, Methods and Systems
US20190188700A1 (en) * 2017-12-15 2019-06-20 Fmr Llc Social Data Tracking Datastructures, Apparatuses, Methods and Systems
US20170091756A1 (en) * 2015-07-14 2017-03-30 Fmr Llc Point-to-Point Transaction Guidance Apparatuses, Methods and Systems
US20170109735A1 (en) * 2015-07-14 2017-04-20 Fmr Llc Computationally Efficient Transfer Processing and Auditing Apparatuses, Methods and Systems
US20170085555A1 (en) * 2015-07-14 2017-03-23 Fmr Llc Point-to-Point Transaction Guidance Apparatuses, Methods and Systems
US20180253702A1 (en) * 2015-11-24 2018-09-06 Gartland & Mellina Group Blockchain solutions for financial services and other transactions-based industries
US9992028B2 (en) * 2015-11-26 2018-06-05 International Business Machines Corporation System, method, and computer program product for privacy-preserving transaction validation mechanisms for smart contracts that are included in a ledger
EP3403213A2 (fr) * 2016-01-15 2018-11-21 Enrico Maim Procédés et systèmes mis en oeuvre dans une architecture en réseau de noeuds susceptibles de réaliser des transactions basées sur messages
WO2017134281A1 (en) * 2016-02-04 2017-08-10 Nasdaq Technology Ab Systems and methods for storing and sharing transactional data using distributed computer systems
EP4254220A3 (en) * 2016-02-12 2023-11-29 Royal Bank Of Canada Methods and systems for digital reward processing
GB2561727A (en) * 2016-02-23 2018-10-24 Nchain Holdings Ltd Blockchain-based exchange with tokenisation
US10992649B2 (en) * 2016-04-01 2021-04-27 Consensys Software Inc. Systems and methods for privacy in distributed ledger transactions
US10608825B2 (en) * 2016-04-21 2020-03-31 Protoblock, Inc. Decentralized exchanges in a distributed autonomous platform
US10580100B2 (en) * 2016-06-06 2020-03-03 Chicago Mercantile Exchange Inc. Data payment and authentication via a shared data structure
US10949922B2 (en) * 2016-06-30 2021-03-16 Chicago Mercantile Exchange Inc. Derivative contracts that settle based on transaction data
US10417217B2 (en) * 2016-08-05 2019-09-17 Chicago Mercantile Exchange Inc. Systems and methods for blockchain rule synchronization
US10249194B2 (en) * 2016-08-30 2019-04-02 International Business Machines Corporation Modifying behavior of autonomous vehicle based on advanced predicted behavior analysis of nearby drivers
US10360191B2 (en) * 2016-10-07 2019-07-23 International Business Machines Corporation Establishing overlay trust consensus for blockchain trust validation system
US10762564B2 (en) * 2016-11-10 2020-09-01 International Business Machines Corporation Autonomous peer-to-peer energy networks operating on a blockchain
AU2016101976A4 (en) * 2016-11-11 2016-12-08 Klianev, Ivan MR Open Network of Permissioned Ledgers
EP3571607A4 (en) * 2017-01-20 2020-07-22 Jiko Group, Inc. SYSTEMS AND METHODS OF CALCULATION AND RECONCILIATION OF DATA AT THE LEVEL OF PRIVATE Nodes
MX2019008243A (es) * 2017-01-27 2019-09-06 Walmart Apollo Llc Gestión de aparatos inteligentes que utiliza tecnología de cadena de bloques .
MX2019008244A (es) * 2017-01-27 2019-09-06 Walmart Apollo Llc Gestión de participación en un sistema monitorizado que utiliza tecnologia decadena de bloques.
US10764259B2 (en) * 2017-02-07 2020-09-01 Microsoft Technology Licensing, Llc Transaction processing for consortium blockchain network
CN111917864B (zh) * 2017-02-22 2023-08-22 创新先进技术有限公司 一种业务校验的方法及装置
US20200067697A1 (en) * 2017-03-22 2020-02-27 NEC Laboratories Europe GmbH Method for operating a blockchain
CN107196900B (zh) * 2017-03-24 2020-04-24 创新先进技术有限公司 一种共识校验的方法及装置
US11095432B2 (en) * 2017-04-05 2021-08-17 Samsung Sds Co., Ltd. System for processing data based on blockchain and operating method thereof
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
US11625785B2 (en) * 2017-06-05 2023-04-11 Chicago Mercantile Exchange Inc. Secure electronic tokens in an electronic tokening system
US10372417B2 (en) * 2017-07-13 2019-08-06 International Business Machines Corporation Multiply-add operations of binary numbers in an arithmetic unit
US10839379B2 (en) * 2017-07-20 2020-11-17 Chicago Mercantile Exchange Inc. Blockchain including linked digital assets
US20190057454A1 (en) * 2017-08-18 2019-02-21 United Parcel Service Of America, Inc. Immutable electronic platform for insurance selection
US20190005595A1 (en) * 2017-08-21 2019-01-03 Kyle Tautenhan System and Method of Peer-to-Peer Electronic Exchange of Intellectual Property
US20200265354A1 (en) * 2017-09-08 2020-08-20 Banco Bilbao Vizcaya Argentaria, S.A. Decision Making Entity Analytics Methods and Systems
US10733559B2 (en) * 2017-11-02 2020-08-04 Mastercard International Incorporated Systems and methods for generating chargeback analytics associated with service chargebacks
US20190156336A1 (en) * 2017-11-21 2019-05-23 Wipro Limited System and method to validate blockchain transactions in a distributed ledger network
US11797995B2 (en) * 2017-12-04 2023-10-24 Mastercard International Incorporated Method and system for risk scoring anonymized transactions
US11057225B2 (en) * 2017-12-07 2021-07-06 International Business Machines Corporation Enforcing compute equity models in distributed blockchain
US10609032B2 (en) * 2017-12-07 2020-03-31 International Business Machines Corporation Enforcing compute equity models in distributed blockchain
US10678598B2 (en) * 2017-12-07 2020-06-09 International Business Machines Corporation Enforcing compute equity models in distributed blockchain
US11132660B2 (en) * 2017-12-12 2021-09-28 Mastercard International Incorporated Systems and methods for distributed peer to peer analytics
EP3503012A1 (en) * 2017-12-20 2019-06-26 Accenture Global Solutions Limited Analytics engine for multiple blockchain nodes
US11146546B2 (en) * 2018-01-16 2021-10-12 Acuant, Inc. Identity proofing and portability on blockchain

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20140006264A1 (en) 2012-07-02 2014-01-02 Mastercard International Incorporated Systems and methods for settling chargeback transactions
WO2016161073A1 (en) 2015-03-31 2016-10-06 Nasdaq, Inc. Systems and methods of blockchain transaction recordation
US20170046664A1 (en) 2015-08-13 2017-02-16 The Toronto-Dominion Bank Systems and methods for tracking and transferring ownership of connected devices using blockchain ledgers

Also Published As

Publication number Publication date
US20190287107A1 (en) 2019-09-19
JP2019160316A (ja) 2019-09-19

Similar Documents

Publication Publication Date Title
JP7450339B2 (ja) ブロックチェーンのためのリソースの公平性のためのシステム、方法、およびコンピュータ・プログラム
JP7304116B2 (ja) ブロックチェーン確率的タイマー・トランザクション同期化
JP6873270B2 (ja) ブロックチェーンにおけるスマートコントラクトに基づくトランザクション活動の取扱注意データを保護するための方法及びデバイス
US11893637B2 (en) Systems and methods for cryptographic trading
US10915552B2 (en) Delegating credentials with a blockchain member service
US10691648B2 (en) Controlling volatility via blockchain
US20190356473A1 (en) Bespoke programmable crypto token
US20190026821A1 (en) Intermediate blockchain system for managing transactions
JP2022088536A (ja) 信頼度が低い、または信頼度が皆無の当事者間での価値転送を円滑化する装置、システム、または方法
US20200142986A1 (en) Offloaded chaincode execution for a database
US11062294B2 (en) Cognitive blockchain for customized interchange determination
WO2021184826A1 (zh) 基于区块链的资源转移方法、装置、节点设备及存储介质
TWI712974B (zh) 用於在區塊鏈系統中處理憑證的方法及裝置
US11769156B2 (en) Automated data projection for smart contract groups on a blockchain
US11940958B2 (en) Artificial intelligence software marketplace
US11379824B2 (en) Privacy preserving transactions with probabilistic transaction fees
US20220261461A1 (en) Secure resource management to prevent fraudulent resource access
CN111309745B (zh) 虚拟资源处理方法、装置、电子设备及存储介质
US11431503B2 (en) Self-sovereign data access via bot-chain
US11194911B2 (en) Blockchain technique for agile software development framework
US20220311611A1 (en) Reputation profile propagation on blockchain networks
US20220156725A1 (en) Cross-chain settlement mechanism
CN111433798A (zh) 基于区块链的可信保函
US10931438B2 (en) Generating a representative article
CN115099814A (zh) 信息处理方法、装置、设备及存储介质

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20210816

RD04 Notification of resignation of power of attorney

Free format text: JAPANESE INTERMEDIATE CODE: A7424

Effective date: 20220502

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20220929

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20221101

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20221208

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20230411

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20230629

A02 Decision of refusal

Free format text: JAPANESE INTERMEDIATE CODE: A02

Effective date: 20231003

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20240116

A911 Transfer to examiner for re-examination before appeal (zenchi)

Free format text: JAPANESE INTERMEDIATE CODE: A911

Effective date: 20240126

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: 20240220

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20240305

R150 Certificate of patent or registration of utility model

Ref document number: 7450339

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150