JP7003995B2 - ブロックチェーン管理装置、ブロックチェーン管理方法及びプログラム - Google Patents

ブロックチェーン管理装置、ブロックチェーン管理方法及びプログラム Download PDF

Info

Publication number
JP7003995B2
JP7003995B2 JP2019537467A JP2019537467A JP7003995B2 JP 7003995 B2 JP7003995 B2 JP 7003995B2 JP 2019537467 A JP2019537467 A JP 2019537467A JP 2019537467 A JP2019537467 A JP 2019537467A JP 7003995 B2 JP7003995 B2 JP 7003995B2
Authority
JP
Japan
Prior art keywords
block
ledger
blockchain management
reference information
management device
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
JP2019537467A
Other languages
English (en)
Other versions
JPWO2019038839A1 (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.)
NEC Corp
Original Assignee
NEC 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 NEC Corp filed Critical NEC Corp
Publication of JPWO2019038839A1 publication Critical patent/JPWO2019038839A1/ja
Application granted granted Critical
Publication of JP7003995B2 publication Critical patent/JP7003995B2/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/23Updating
    • G06F16/2379Updates performed during online database operations; commit processing
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/12Applying verification of the received information
    • H04L63/123Applying verification of the received information received data contents, e.g. message integrity
    • 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/23Updating
    • G06F16/2365Ensuring data consistency and integrity
    • 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
    • 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
    • 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

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Security & Cryptography (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Databases & Information Systems (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Data Mining & Analysis (AREA)
  • Business, Economics & Management (AREA)
  • Computer Hardware Design (AREA)
  • Computing Systems (AREA)
  • Bioethics (AREA)
  • General Health & Medical Sciences (AREA)
  • Software Systems (AREA)
  • Health & Medical Sciences (AREA)
  • Accounting & Taxation (AREA)
  • Strategic Management (AREA)
  • General Business, Economics & Management (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
  • Financial Or Insurance-Related Operations Such As Payment And Settlement (AREA)

Description

本発明は、ブロックチェーン管理装置、ブロックチェーン管理方法及びプログラムに関し、ネットワークに参加する複数のノード間で共通の台帳を管理するブロックチェーン管理装置、ブロックチェーン管理方法及びプログラムに関する。
近年、ビットコイン(非特許文献1を参照)を代表として、中央管理サーバーを必要とせず誰もが参加可能なピアツーピア(Peer to Peer:P2P)ネットワークで、ネットワークに参加するすべてのノード間で共通の台帳を管理することが可能なブロックチェーンの普及が拡大している。
ビットコインに代表されるブロックチェーンは、複数のブロックチェーン管理ノード(ブロックチェーン管理装置)が相互接続されたシステムである。ブロックチェーン管理ノードは、台帳格納手段と、トランザクション検証手段と合意形成手段とを備える。台帳格納手段は、ブロックチェーン上に蓄積する履歴情報(以下、「トランザクション」と呼ぶ)を発行するトランザクション発行者から発行されたトランザクションを蓄積する。トランザクション検証手段は、トランザクションを検証する。合意形成手段は、ブロックチェーン管理ノード間で蓄積するトランザクションの内容を同一にする処理(「合意形成」という。「マイニング」とも呼ばれる。)を行う。台帳格納手段に蓄積されるトランザクションはデータ構造として一つまたは複数のトランザクションを集約した単位をブロックとし、当該ブロックの中に少なくとも前のブロックのハッシュ値を含むブロックヘッダを含むという特徴を持つ。このように蓄積されたブロックの集合を台帳と呼ぶ。
そして、ブロックチェーンは概略以下のように動作する。各ブロックチェーン管理ノードは一人または複数のトランザクション発行者から発行された一つまたは複数のトランザクション情報を受信する。トランザクション検証手段は、受信した一つまたは複数のトランザクション情報の検証を行い、検証を通過した少なくとも一つ以上のトランザクションを集約してブロックを作成する。各ブロックチェーン管理ノードでブロックの内容は異なりうる。このため、合意形成手段が、ブロックチェーン管理ノード間で蓄積するブロックの内容を同一にする。合意形成手段により各ブロックチェーン管理ノードで同一となったブロックが台帳格納手段に格納される。
また、ブロックチェーン管理ノードにはトランザクションを受け取り、ブロックを正しく生成・蓄積していくことにインセンティブがあるように設計される。例えば、ビットコインでは、ブロックを生成することで、ブロックチェーン管理ノードが仮想通貨を得ることができる。このため、多くのブロックチェーン管理ノードは正しくブロックの検証・生成を行うようにふるまう。
このような構成及び動作により、ブロックチェーン管理ノードとして悪意のあるノードが参加した場合でも改ざんが困難かつ、各ブロックチェーン管理ノードで台帳の内容が同一となり、トランザクションが同一の順序で蓄積されていく。
また、ブロックチェーンは上述した構成及び動作をするブロックチェーン管理ノードが複数存在し、すべてのデータを複製して管理することから、データが改ざんされないことに加えて、データの消失が起こらないことも期待されている。このようなブロックチェーンの性質を利用して、トランザクションの形でデータを登録してブロックチェーンをデータベースシステムとして利用するようなサービスが出現している。
特許文献1には、記した合意形成(マイニング)に必要な端末の処理能力及び記憶容量を低減することができるという仮想通貨管理プログラム及び仮想通貨管理方法が開示されている。
特開2016-218633号公報
以下の分析は、本発明によって与えられたものである。上記した典型的なブロックチェーンの枠組みにおいて、ブロックチェーン管理ノードが個々のトランザクションを保持するモチベーションは、インセンティブを得るために、新たなブロックを生成したりトランザクションやブロックを検証するためにあり、そのような処理に必要の無い余分なデータを保持するモチベーションは低くなる傾向にある。以下、この点について検討する。
ビットコインに代表される既存のブロックチェーン技術は、ブロック全体に対するハッシュ値を取るのではなく、ブロックヘッダに対してのみハッシュ値を取り次のブロックへ含める。ブロックヘッダには主に直前のブロックのハッシュ値、ブロックに含められたすべてのトランザクションを基に生成されたハッシュ値などが含まれる。この場合、ブロックヘッダのハッシュ値の検証には個々のトランザクションの詳細な情報は必要ない。
また、古くなったトランザクションは、新しいブロック及びトランザクションを検証する際に必要ないのであれば保持する必要はない。たとえば、ビットコインではトランザクションは、複数の使用するコインを指定するインプット情報とトランザクションによって生成される複数の新しいコインを表すアウトプット情報を含んでおり、新しいトランザクションを検証する際に必要なトランザクションは、アウトプット情報に含まれるコインに未使用なものが残っているトランザクションのみであり、トランザクションに含まれるすべてのコインが使用済みである場合には二度と検証時に参照されない。この点、特許文献1の段落0005には、「マイニングに用いる端末には、取引の履歴すべてを自端末に保存しておく必要がある」との記載があるが、上記ビットコインに代表されるブロックチェーン技術ではそのような必要は無くなっている。
つまり、既存のブロックチェーンではブロックヘッダのハッシュの検証及び新しいブロックの検証に必要の無いトランザクションが存在するにも拘わらず、それらのトランザクションを保持し続けるモチベーションがブロックチェーン管理ノードにないため、一部のトランザクションが失われる可能性がある。ビットコインでは実際に不必要なトランザクションを捨てて台帳の容量を削減できるモードが実装されている。
このため、ブロックチェーン上にトランザクションの形でデータを登録してデータベースシステムとして利用するサービスは、データが消失してサービスの提供が困難になる可能性がある。
このように、背景技術に記載したブロックチェーンでは、ブロックチェーン管理ノードが台帳に含まれるトランザクションを永続的に保持するモチベーションが低いため、トランザクションの形で台帳に含まれる重要なデータが消失する可能性があるという問題点がある。これは、ブロックチェーンをデータベースシステムとして利用するサービスにとって特に問題となりうる。
本発明は、ブロックチェーン管理ノードにおいてトランザクションの形で台帳に含まれる重要なデータの消失可能性を低減させることのできるブロックチェーン管理装置、ブロックチェーン管理方法及びプログラムを提供することを目的とする。
第1の視点によれば、ブロックチェーン管理装置間で取り決めた所定のルールに基づいて台帳の所定の範囲の中から選択した参照情報の要約値を少なくとも一つ含むブロックヘッダを含むブロックを受信するブロック受信部を備えるブロックチェーン管理装置が提供される。このブロックチェーン管理装置は、さらに、前記所定のルールに基づいて前記台帳の所定の範囲の中から参照情報を選択し、前記ブロックに含まれる参照情報の要約値が前記参照情報に基づいて生成されているか否かにより、ブロックが正しく生成されたことを検証するブロック検証部を備える。このブロックチェーン管理装置は、さらに、前記ブロック検証部により前記ブロックが正しく生成されたと検証された場合に、他のブロックチェーン管理装置と当該ブロックを書き込むことに対して合意形成を行う合意形成部を備える。このブロックチェーン管理装置は、前記合意形成された前記ブロックを格納する台帳格納部と、を備える。
第2の視点によれば、台帳の所定の範囲の中から所定のルールに基づいて選択した参照情報の要約値を少なくとも一つ含むブロックヘッダを含むブロックを受信するステップと、前記台帳の所定の範囲の中から所定のルールに基づいて参照情報を選択し、前記ブロックに含まれる参照情報の要約値が前記参照情報に基づいて生成されているか否かにより、ブロックが正しく生成されたことを検証するステップと、前記検証により前記ブロックが正しく生成されたと検証された場合に、他のブロックチェーン管理装置と当該ブロックを書き込むことに対して合意形成を行うステップと、前記合意形成された前記ブロックを格納するステップと、を含むブロックチェーン管理方法が提供される。本方法は、他のブロックチェーン管理装置と連携して共通の台帳を管理するブロックチェーン管理装置という、特定の機械に結びつけられている。
第3の視点によれば、上記したブロックチェーン管理装置の機能を実現するためのコンピュータプログラムが提供される。なお、このプログラムは、コンピュータが読み取り可能な(非トランジエントな)記憶媒体に記録することができる。即ち、本発明は、コンピュータプログラム製品として具現することも可能である。
本発明によれば、ブロックチェーン管理ノードにおいてトランザクションの形で台帳に含まれる重要なデータの消失可能性を低減させることが可能となる。
本発明の一実施形態の構成を示す図である。 本発明の第1の実施形態の全体構成を示す図である。 本発明の第1の実施形態のブロックチェーン管理装置の構成を示す機能ブロック図である。 本発明の第1の実施形態のブロックチェーン管理装置が作成するブロックの一例を示す図である。 本発明の第1の実施形態のブロックチェーン管理装置の動作を表したフローチャートである。 本発明の第1の実施形態のブロックチェーン管理装置の台帳格納部に保持される台帳データの一例を示す図である。 本発明の第1の実施形態のブロックチェーン管理装置の動作(ブロック検証)を表したフローチャートである。 本発明の第1の実施形態のブロックチェーン管理装置の動作(合意形成)を表したフローチャートである。 本発明の第2の実施形態のブロックチェーン管理装置の構成を示す機能ブロック図である。 本発明の第2の実施形態の典型的な動作を示す図である。
はじめに本発明の一実施形態の概要について図面を参照して説明する。なお、この概要に付記した図面参照符号は、理解を助けるための一例として各要素に便宜上付記したものであり、本発明を図示の態様に限定することを意図するものではない。また、以降の説明で参照する図面等のブロック間の接続線は、双方向及び単方向の双方を含む。一方向矢印については、主たる信号(データ)の流れを模式的に示すものであり、双方向性を排除するものではない。
本発明は、その一実施形態において、図1に示すように、ブロック受信部101と、ブロック検証部102と、合意形成部103と、台帳格納部104と、を備えるブロックチェーン管理装置100Aと、同等の機能を持つブロックチェーン管理装置100Bをピアツーピア接続した構成にて実現できる。
より具体的には、ブロック受信部101は、他のブロックチェーン管理装置から、ブロックチェーン管理装置間で取り決めた所定のルールに基づいて台帳の所定の範囲の中から選択した参照情報の要約値を少なくとも一つ含むブロックヘッダを含むブロックを受信する。ブロック検証部102は、前記所定のルールに基づいて前記台帳の所定の範囲の中から参照情報を選択し、前記ブロックに含まれる参照情報の要約値が前記参照情報に基づいて生成されているか否かにより、受信したブロックが正しく生成されたことを検証する。合意形成部103は、前記ブロック検証部102により前記ブロックが正しく生成されたと検証された場合に、他のブロックチェーン管理装置と当該ブロックを書き込むことに対して合意形成を行う。台帳格納部104は、前記合意形成された前記ブロックを格納する。
上記した構成によれば、ブロックチェーン管理ノードにおけるトランザクションを保持することに対するインセンティブが付与され、なるべく多くのトランザクションがブロックチェーン管理ノードによって保持されるようになる。
その理由は以下のように分析できる。上記したブロックチェーン管理装置(例えば、ブロックチェーン管理装置100A)のブロック検証部102は、台帳の部分的情報である参照情報を知らなければ生成できない参照情報の要約値がブロックに含まれる場合に、ブロックが正しいと判断する。このため、あるブロックチェーン管理装置100Bが、ブロックを生成するためには台帳の任意の部分的情報にアクセスする必要がある。一方で、ブロック生成によるインセンティブを最大化するためにはブロックを生成できるノードが少ない方が良い。これらのことから、ブロックを生成するに足りる台帳情報を持たないブロックチェーン管理装置が、他のブロックチェーン管理装置から参照情報を取得することは困難であり、それぞれのブロックチェーン管理装置は、台帳上のなるべく多くの情報を保持するようになる。結果として、より多くのトランザクションが保持されるようになる。
[第1の実施形態]
続いて、本発明の第1の実施形態について図面を参照して詳細に説明する。図2は、本発明の第1の実施形態の構成を示す図である。図2を参照すると、4台のブロックチェーン管理装置(ブロックチェーン管理ノード)100が相互に接続された構成が示されている。これらのブロックチェーン管理装置100がトランザクション発行者から受け取ったトランザクションを検証する。そして、検証を通過したトランザクションを集約してブロックを作成する。ブロックを作成したブロックチェーン管理装置100は、他のブロックチェーン管理装置100に作成したブロックを配布する。それぞれのブロックチェーン管理装置100がその正当性を検証した上で台帳にブロックの内容を追加する。なお、上記の過程で、ブロックチェーン管理装置100がブロックの作成主体となりうるため、内容の異なるブロックが作成されることがある。また、悪意を持ったブロックチェーン管理装置100が存在する場合、不正なブロックが生成、配布される可能性もある。その場合、合意形成という手続を行って、ブロックチェーン管理ノード100間で蓄積するブロックの内容を同一にする。これにより、台帳の一貫性が保たれる。なお、図2の例では、4台のブロックチェーン管理装置を示しているが、ブロックチェーン管理装置の数は複数あればよく、図2の構成に限られない。
続いて、ブロックチェーン管理装置100の構成について図面を参照して詳細に説明する。図3は、本発明の第1の実施形態のブロックチェーン管理装置の構成を示す機能ブロック図である。図3を参照すると、ブロック受信部110と、ブロック検証部120と、合意形成部130と、台帳格納部140と、を含むブロックチェーン管理装置100が示されている。
ブロック受信部110は、ブロックチェーンのネットワークに送信されたブロックBを受信する。このブロックBは、図4に示すように、一つまたは複数のトランザクションに、ブロックヘッダBHを付加して構成される。さらに、このブロックヘッダBHは、直前のブロックに含まれるブロックヘッダを要約したブロックヘッダ要約値(図4のHash)と、特定のルールによって指定された台帳の部分的情報である参照情報に基づいて生成された少なくとも一つの参照情報の要約値(以下「参照情報要約値」)を含む。なお、参照情報は、台帳の複数の部分である場合も含まれる。この場合、参照情報は複数となり、参照情報要約値は、これら複数の参照情報から1つ、又は、複数生成される。
ブロック検証部120は、参照情報検証部121と、参照情報決定部122とを備え、受信したブロックが正しく生成されていることを検証する。具体的には、参照情報決定部122は、決定的なルール(所定のルール)を用いて、台帳の一部またはすべての情報に基づいた台帳の部分的情報である参照情報を決定する。参照情報検証部121は、参照情報要約値が前記参照情報に基づいて生成されていることを検証する。ここで、決定的なルールとは、すべてのブロックチェーン管理装置100が、台帳の情報から、同一の部分的情報である参照情報を特定できるようなルールを意味する。
合意形成部130は、他のブロックチェーン管理装置との間で、前記受信したブロックが前記ブロック検証部120で正しく生成されたと判断された場合に、蓄積するかどうかについて合意する合意形成手順を実施する。
台帳格納部140は、前記合意形成部130によって合意されたすべてのブロックの集合である台帳の一部またはすべてを格納する。
次に、ブロックチェーン管理装置100の動作について図面を参照して詳細に説明する。はじめに、図5を参照してブロックチェーン管理装置100が受信したブロックを検証し、台帳格納部140に格納するまでの一連の動作について説明する。
ブロック受信部110が、他のブロックチェーン管理装置100等からブロックを受信する(ステップA1)。ここでは、図4に示すブロックBを受信したとする。図4に示したとおり、このブロックBは、トランザクションの集合であるボディに、直前のブロックのブロックヘッダを要約したブロックヘッダ要約値(Hash)と、合意形成部130で使用されるNonceと呼ばれる値と、参照情報要約値を含んだブロックヘッダを付加した構成となっている。
次に、ブロック検証部120が前記受信したブロックBに対して検証を行う(ステップA2)。ここでの検証の内容については、後に、図7のフローチャートを用いて説明する。
前記検証の結果、前記ブロックが正しく生成されていないと判定された場合(ステップA3のNo)、ブロックチェーン管理装置100はブロックを廃棄する(ステップA4)。
一方、ブロックが正しく生成されたと判定した場合(ステップA3のYes)、合意形成部130が、他のブロックチェーン管理装置100と合意形成を行う(ステップA5)。この合意形成の仕方については、後に、図8のフローチャートを用いて説明する。
最後に、ブロックチェーン管理装置100は、他のブロックチェーン管理装置100と合意形成できたブロックを台帳格納部140に格納する。図6は、台帳格納部140に保持される台帳データの一例を示す図である。図6の例では、合意形成の結果、ブロックの高さ501のブロックが追加された状態を示している。なお、台帳格納部140における台帳の格納態様は、図6に示した例に限られず、種々の変更を加えることが可能である。例えば、図6の例では、ブロックの高さとブロック本体とを対応付けた構成としているが、この形態に限られるものではない。
続いて、図7のフローチャートを用いて、上記図5のステップA2におけるブロック検証部120によるブロックの検証処理について詳細に説明する。以下では、ブロックチェーン管理装置100が、図4に示すブロックを受信したものとして説明する。
検証対象となるブロックが入力されると、まず、ブロック検証部120の参照情報決定部122が、決定的なルールに従い、台帳の中の部分的な情報を識別できる識別子を少なくとも一つ生成して、参照情報として指定する(ステップB1)。
前記参照情報の識別子には、例えば、ブロックの高さなどを用いることができる。参照情報を指定するルール(決定的なルール)は、たとえば、次のものを用いることができる。
・直前のブロックの一部(Nonceの値や直前のブロックのハッシュ値など)に対してSHA-256等のハッシュ関数を用いて16進数の数値を作成する。
・この数値の一部分(下数桁など)に対して、最新のブロックの高さで剰余演算して得られた値に1を加える。
以上のようなルールを用いることで、どの高さのブロックを参照情報として指定するかを1~現在のブロック高さの間で決定することができる。
例えば、図6に示した台帳の中で直前のブロックである高さが500のブロックに含まれる直前のブロックのハッシュ値(つまり高さ499のブロックヘッダのハッシュ値)についてSHA-256ハッシュ関数でハッシュ値を取る。ここで、ハッシュ値として‘9a796cbfa5cc884d7f3e7ddf6c743dfeb9a78e876766d3243e893e4ded4e638d’という値が得られたものとする。その下16ケタの16進数‘3e893e4ded4e638d’に対して現在のブロック高さである500で剰余を取って+1することで参照するブロックは‘294’となる。
なお、参照情報の識別子及びその決定方法はこの限りではない。例えば、たとえば参照情報の識別子は、ブロックの高さと、ブロック内のトランザクションを識別する番号といった複数の情報で構成されてもよい。また、これらの複数の情報で構成される識別子を直前のブロックの複数の部分的情報から取得してもよいし、直近の複数のブロックなどからそれぞれ生成することでもよい。また、参照情報の識別子が複数存在し、複数の参照情報を指定してもよい。
このように参照情報を選択するための識別子は、台帳のデータをより多くより長期に保持することにインセンティブが働くものであればよく、台帳の中から参照情報を識別できる情報でよければその形態を問わない。また、参照情報の識別子は決定的なルールであり、ある程度一様に台帳の部分的情報が選択されるのであれば、その決定方法は問わない。
次に、参照情報検証部121は、台帳から前記参照情報決定部122により決定された一つまたは複数の参照情報の識別子に基づいて、一つまたは複数の参照情報を取得する(ステップB2)。ここでは、図6に示す台帳からブロックの高さ294のブロックが参照情報として取得されたものとする。
次に、参照情報検証部121は、前記受信したブロックに含まれる少なくとも一つの参照情報要約値が、前記参照情報に基づいて生成されたものであることを検証し、検証結果の正否を返す(ステップB3)。ここでは、ステップB2で図6に示す高さ294のブロックである参照情報に対するSHA-256などのハッシュ関数で計算されるハッシュ値が図4のブロックに含まれる参照情報要約値と一致するかどうかで検証を行う。参照情報である高さ294のブロックのハッシュ値が‘678e82d907d3e6e71f81D5cf3ddacc3671dc618c38a1b7a9f9393a83d025b296’であった場合、図4のブロックに含まれる参照情報要約値 ‘678e82d907d3e6e71f81D5cf3ddacc3671dc618c38a1b7a9f9393a83d025b296’と一致したと判定される。
なお、複数の参照情報があった場合に、それを連結して一つの参照情報要約値を検証してもよいし、複数の参照情報要約値をそれぞれ対応する参照情報で検証してもよい。また検証の方法は上記の方法に限定せず、参照情報要約値が参照情報から生成されたものであると検証できればよい。
続いて、図8のフローチャートを用いて、上記図5のステップA5における合意形成部130による合意形成処理について詳細に説明する。なお、以下の説明では、一例としてビットコインで採用されているProof of Workと呼ばれる仕組みによる合意形成について説明するが、他の合意形成方法でもよく、合意形成の方法については問わない。
図8を参照すると、まず、合意形成部130は、ブロックのハッシュ値を取得する(ステップC1)。ハッシュ値はブロック全体に対して取るのでもよいし、ブロックの特徴を要約した値について取るのでもよい。ここでは、図4に示すブロックのハッシュ値として、16進数で “0000000000000000000000000000000000000000000000002bcad85e7b40d3a4”という値が得られたものとして説明する。
最後に、合意形成部130は、ブロックのハッシュ値が目標値より小さいかどうかを判定し、ブロックのハッシュ値が小さい場合に合意形成ができたと判定とする(ステップC2)。ここで、目標値は事前にシステムに固有の値が決定されているのでもよいし、以前のブロックを参照して計算して生成されるのでもよい。ここで、図4に示されたブロックに対する目標値が、“0000000000000000000000000000000000000000000000010000000000000000”であった場合、前述した図4のブロックのハッシュ値<当該目標値となるため、合意形成ができたと判定される。
このような合意形成の方法はProof of Workと呼ばれ、ブロックを生成する際に、図4のブロックに示すようなNonceと呼ばれる値を変化させ、ブロックのハッシュ値が目標値より小さくなるようにブロックを生成する。ハッシュ値からNonceを逆算することはできないことから、ブロックチェーン管理装置100は、総当たりでNonceを試す必要がある。このため、ブロックの生成には、ある程度の計算コストと時間を所要する。ブロックの生成にかかる時間は目標値によってコントロールでき、たとえばビットコインでは直近のいくつかのブロックの生成間隔から、今後もブロックの生成にかかる時間が10分程度になるように調整される。Proof of Workを用いる合意形成手段130は、計算コストを掛けて生成されたブロックかどうかを、ブロックのハッシュ値によって検証できる。ブロックチェーンのネットワークに参加している大部分のブロックチェーン管理装置100が同じルールに従ってブロックのハッシュ値を検証し、検証を通過したブロックのみを台帳格納手段140に格納するブロックとすることで、ネットワーク全体では合意を形成することができる。
以上説明したように、本実施形態のブロックチェーン管理装置100によれば、トランザクションを保持することに対するインセンティブが働くようにすることができ、より多くのトランザクションがブロックチェーン管理装置100に保持されるようになる。
その理由は、ブロック検証部120におけるブロック検証の際に、より多くのトランザクションを保持しているノードがインセンティブを得られるように構成したことにある。具体的には、ブロック検証部120の参照情報検証部121はブロックに含まれる参照情報の要約値が、決定的なルールで決定される台帳の部分的情報である参照情報から生成されたものであると検証された場合にのみブロックが正しいと判断する。そして、合意形成部130は、他のブロックチェーン管理装置100と合意形成を行い、合意形成されたブロックが台帳格納部140に格納されることになる。このため、ブロックチェーン管理装置100が台帳に登録されるブロックを生成するためには台帳の任意の部分的情報にアクセスする必要がある。ブロック生成によるインセンティブを最大化するためにはブロックを生成できるノードが少ない方が良いことから、他のノードから参照情報を取得することは困難であり、それぞれのブロックチェーン管理装置100が台帳上のより多くの望ましくは全部の情報を保持する必要がある。このため、すべてのトランザクションがより多く、より長期に保持されることになる。
[第2の実施形態]
上記した実施形態では、ブロックチェーン管理装置100がトランザクション発行者からトランザクションを受け取ってブロックを生成する仕組みについては省略したが、ブロックチェーン管理装置100がこれらの機能を備えていてもよい。例えば、図9のように、ブロックチェーン管理装置100Cが、トランザクション受信部150と、ブロック生成部160と備えていてもよい(第2の実施形態)。
トランザクション受信部150は、トランザクション発行者または他のブロックチェーン管理装置100からトランザクションを受信する(図10の(1)参照)。そして、ブロック生成部160は、台帳格納部140に格納された直前のブロックのハッシュ値と参照情報決定部122によって決定された参照情報を要約した参照情報要約値と受信したトランザクションを一つ以上まとめてブロックを生成し、他のブロックチェーン管理装置100に配布する(図10の(2))。そして、このブロック生成部160が生成するブロックは、前述したProof of Workで合意形成をするために、一定の条件を満たすブロック(即ち、決定的ルールを用いて選択された参照情報の要約値を含むブロック)であることが望ましい。
以上のように、本発明は、トランザクションを受け取ってブロックを生成する機能を備えているブロックチェーン管理装置100にも適用可能である。
以上、本発明の各実施形態を説明したが、本発明は、上記した実施形態に限定されるものではなく、本発明の基本的技術的思想を逸脱しない範囲で、更なる変形・置換・調整を加えることができる。例えば、各図面に示したネットワーク構成、各要素の構成、台帳、ブロック等の表現形態は、本発明の理解を助けるための一例であり、これらの図面に示した構成に限定されるものではない。
例えば、図1、3、9に示したブロックチェーン管理装置の各部(処理手段)は、ブロックチェーン管理装置に搭載されたプロセッサに、そのハードウェアを用いて、上記した各処理を実行させるコンピュータプログラムにより実現することもできる。
最後に、本発明の好ましい形態を要約する。
[第1の形態]
(上記第1の視点によるブロックチェーン管理装置参照)
[第2の形態]
上記した所定のルールとして、
一つまたは複数の直近のブロックのすべてまたは一部の情報を用いて参照情報を決定するルールを用いることができる。
[第3の形態]
上記した所定のルールは、
前記台帳の一部またはすべての情報を入力として前記台帳の部分的情報を識別する識別子を一つまたは複数計算し、前記台帳から当該一つまたは複数の識別子に基づいて一つまたは複数の参照情報を抽出するルールであってもよい。
[第4の形態]
上記した台帳の部分的情報を識別する識別子として、一つまたは複数のブロックの高さを用いることができる。
[第5の形態]
上記した台帳の部分的情報を識別する識別子として、一つまたは複数のブロックの高さとトランザクションを識別する情報を用いることができる。
[第6の形態]
前記識別子は、0から前記台帳に格納された最新のブロックの高さの範囲で決定することが好ましい。
[第7の形態]
上記したブロックチェーン管理装置は、
さらに、
他の装置からトランザクションを受信するトランザクション受信部と、
前記台帳格納部に格納された最新のブロックから算出されるハッシュ値と、前記トランザクション受信部が受信したトランザクションを一つ以上まとめてブロックを生成するブロック生成部と
を備えていてもよい。
[第8の形態]
上記したブロックチェーン管理装置の前記ブロック生成部は、
前記ブロックから所定のルールで算出されるハッシュ値が所定の目標値と比較して事前に定められた条件を満たすようにブロックを生成するように構成することもできる。
[第9の形態]
(上記第2の視点によるブロックチェーン管理方法参照)
[第10の形態]
(上記第3の視点によるコンピュータプログラム参照)
なお、上記第8~第9の形態は、第1の形態と同様に、第2~第7の形態に展開することが可能である。
なお、上記の特許文献および非特許文献の各開示を、本書に引用をもって繰り込むものとする。本発明の全開示(請求の範囲を含む)の枠内において、さらにその基本的技術思想に基づいて、実施形態ないし実施例の変更・調整が可能である。また、本発明の開示の枠内において種々の開示要素(各請求項の各要素、各実施形態ないし実施例の各要素、各図面の各要素等を含む)の多様な組み合わせ、ないし選択が可能である。すなわち、本発明は、請求の範囲を含む全開示、技術的思想にしたがって当業者であればなし得るであろう各種変形、修正を含むことは勿論である。特に、本書に記載した数値範囲については、当該範囲内に含まれる任意の数値ないし小範囲が、別段の記載のない場合でも具体的に記載されているものと解釈されるべきである。
100、100A~100C ブロックチェーン管理装置
101、110 ブロック受信部
102、120 ブロック検証部
103、130 合意形成部
104、140 台帳格納部
121 参照情報検証部
122 参照情報決定部
150 トランザクション受信部
160 ブロック生成部
B ブロック
BH ブロックヘッダ

Claims (9)

  1. ブロックチェーン管理装置間で取り決めた所定のルールに基づいて台帳の所定の範囲の中から選択した参照情報の要約値を少なくとも一つ含むブロックヘッダを含むブロックを受信するブロック受信部と、
    前記所定のルールに基づいて前記台帳の所定の範囲の中から参照情報を選択し、前記ブロックに含まれる参照情報の要約値が前記参照情報に基づいて生成されているか否かにより、ブロックが正しく生成されたことを検証するブロック検証部と、
    前記ブロック検証部により前記ブロックが正しく生成されたと検証された場合に、他のブロックチェーン管理装置と当該ブロックを書き込むことに対して合意形成を行う合意形成部と、
    前記合意形成された前記ブロックを格納する台帳格納部と、
    を備え
    前記所定のルールは、
    前記台帳の一部またはすべての情報を入力として前記台帳の部分的情報を識別する識別子を一つまたは複数計算し、前記台帳から当該一つまたは複数の識別子に基づいて一つまたは複数の参照情報を抽出するルールである、ことを特徴とするブロックチェーン管理装置。
  2. 前記所定のルールとして、
    一つまたは複数の直近のブロックのすべてまたは一部の情報を用いて参照情報を決定するルールを用いる
    請求項1に記載のブロックチェーン管理装置。
  3. 前記台帳の部分的情報を識別する識別子として、一つまたは複数のブロックの高さを用いる
    請求項1又は2に記載のブロックチェーン管理装置。
  4. 前記台帳の部分的情報を識別する識別子として、一つまたは複数のブロックの高さとトランザクションを識別する情報を用いる
    請求項1又は2に記載のブロックチェーン管理装置。
  5. 前記識別子は、0から前記台帳に格納された最新のブロックの高さの範囲で決定される
    請求項3又は4に記載のブロックチェーン管理装置。
  6. さらに、
    他の装置からトランザクションを受信するトランザクション受信部と、
    前記台帳格納部に格納された最新のブロックから算出されるハッシュ値と、前記トランザクション受信部が受信したトランザクションを一つ以上まとめてブロックを生成するブロック生成部と
    を備える請求項1からいずれか一に記載のブロックチェーン管理装置。
  7. 前記ブロック生成部は、
    前記ブロックから所定のルールで算出されるハッシュ値が所定の目標値と比較して事前に定められた条件を満たすようにブロックを生成することを特徴とする、
    請求項に記載のブロックチェーン管理装置。
  8. 台帳の所定の範囲の中から所定のルールに基づいて選択した参照情報の要約値を少なくとも一つ含むブロックヘッダを含むブロックを受信するステップと、
    前記台帳の所定の範囲の中から所定のルールに基づいて参照情報を選択し、前記ブロックに含まれる参照情報の要約値が前記参照情報に基づいて生成されているか否かにより、ブロックが正しく生成されたことを検証するステップと、
    前記検証により前記ブロックが正しく生成されたと検証された場合に、他のブロックチェーン管理装置と当該ブロックを書き込むことに対して合意形成を行うステップと、
    前記合意形成された前記ブロックを格納するステップと、
    を含み、
    前記所定のルールは、
    前記台帳の一部またはすべての情報を入力として前記台帳の部分的情報を識別する識別子を一つまたは複数計算し、前記台帳から当該一つまたは複数の識別子に基づいて一つまたは複数の参照情報を抽出するルールである、ブロックチェーン管理方法。
  9. ブロックチェーン管理装置を構成するコンピュータに、
    台帳の所定の範囲の中から所定のルールに基づいて選択した参照情報の要約値を少なくとも一つ含むブロックヘッダを含むブロックを受信する処理と、
    前記台帳の所定の範囲の中から所定のルールに基づいて参照情報を選択し、前記ブロックに含まれる参照情報の要約値が前記参照情報に基づいて生成されているか否かにより、ブロックが正しく生成されたことを検証する処理と、
    前記検証により前記ブロックが正しく生成されたと検証された場合に、他のブロックチェーン管理装置と当該ブロックを書き込むことに対して合意形成を行う処理と、
    前記合意形成された前記ブロックを格納する処理と、
    を実行させ
    前記所定のルールは、
    前記台帳の一部またはすべての情報を入力として前記台帳の部分的情報を識別する識別子を一つまたは複数計算し、前記台帳から当該一つまたは複数の識別子に基づいて一つまたは複数の参照情報を抽出するルールである、
    プログラム。
JP2019537467A 2017-08-22 2017-08-22 ブロックチェーン管理装置、ブロックチェーン管理方法及びプログラム Active JP7003995B2 (ja)

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
PCT/JP2017/029998 WO2019038839A1 (ja) 2017-08-22 2017-08-22 ブロックチェーン管理装置、ブロックチェーン管理方法及びプログラム

Publications (2)

Publication Number Publication Date
JPWO2019038839A1 JPWO2019038839A1 (ja) 2020-10-15
JP7003995B2 true JP7003995B2 (ja) 2022-01-21

Family

ID=65439996

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2019537467A Active JP7003995B2 (ja) 2017-08-22 2017-08-22 ブロックチェーン管理装置、ブロックチェーン管理方法及びプログラム

Country Status (3)

Country Link
US (1) US11314727B2 (ja)
JP (1) JP7003995B2 (ja)
WO (1) WO2019038839A1 (ja)

Families Citing this family (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11646879B2 (en) * 2018-06-12 2023-05-09 Electronics And Telecommunications Research Institute Method and apparatus for selecting distributed consensus node based on proof of nonce
GB201811263D0 (en) * 2018-07-10 2018-08-29 Netmaster Solutions Ltd A method and system for managing digital using a blockchain
US11502847B2 (en) * 2018-07-13 2022-11-15 Waters Technologies Ireland Limited Techniques for managing analytical information using distributed ledger technology
US11010394B2 (en) * 2019-02-15 2021-05-18 Drfirst.Com, Inc. Efficient access of chainable records
CN109981405B (zh) * 2019-03-20 2021-04-23 上海和数软件有限公司 节点管理方法、装置及计算机可读存储介质
CN110825755B (zh) * 2019-10-30 2021-05-04 北京海益同展信息科技有限公司 区块链的共识方法、共识节点、电子设备、存储介质
JP7327100B2 (ja) * 2019-11-15 2023-08-16 富士フイルムビジネスイノベーション株式会社 データ管理システム、データ管理装置及びデータ管理プログラム
CN111339109B (zh) 2020-02-21 2024-01-12 百度在线网络技术(北京)有限公司 一种区块链的资源处理方法、装置、设备和介质
US20230125542A1 (en) * 2021-10-22 2023-04-27 Mastercard International Incorporated Method and system of initiating simultaneous start of block formation
JP2024081029A (ja) 2022-12-05 2024-06-17 富士通株式会社 ブロックチェーン管理プログラム、ブロックチェーン管理装置及びブロックチェーン管理方法

Family Cites Families (11)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9436923B1 (en) * 2015-02-26 2016-09-06 Skuchain, Inc. Tracking unitization occurring in a supply chain
JP5858507B1 (ja) 2015-05-18 2016-02-10 株式会社Orb 仮想通貨管理プログラム、及び仮想通貨管理方法
US10848315B2 (en) 2015-07-13 2020-11-24 Nippon Telegraph And Telephone Corporation Contract agreement method, agreement verification method, contract agreement system, agreement verification device, contract agreement device, contract agreement program and agreement verification program
US10366204B2 (en) * 2015-08-03 2019-07-30 Change Healthcare Holdings, Llc System and method for decentralized autonomous healthcare economy platform
US10402792B2 (en) * 2015-08-13 2019-09-03 The Toronto-Dominion Bank Systems and method for tracking enterprise events using hybrid public-private blockchain ledgers
JP6452156B2 (ja) 2015-09-03 2019-01-16 日本電信電話株式会社 許諾情報管理システム、利用者端末、権利者端末、許諾情報管理方法、および、許諾情報管理プログラム
JP2017049967A (ja) 2015-09-06 2017-03-09 プリモ株式会社 情報処理装置及びプログラム
JP6355168B2 (ja) 2015-11-09 2018-07-11 日本電信電話株式会社 ブロックチェーン生成装置、ブロックチェーン生成方法、ブロックチェーン検証装置、ブロックチェーン検証方法およびプログラム
JP6358658B2 (ja) 2015-11-09 2018-07-18 日本電信電話株式会社 ブロックチェーン生成装置、ブロックチェーン生成方法、ブロックチェーン検証装置、ブロックチェーン検証方法およびプログラム
US11074663B2 (en) * 2015-12-31 2021-07-27 Camelot Uk Bidco Limited System and method of facilitating intellectual property transactions
US10862959B2 (en) * 2016-11-28 2020-12-08 Keir Finlow-Bates Consensus system and method for adding data to a blockchain

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
TSCHORSCH, F. and SCHEUERMANN, B.,Bitcoin and Beyond: A Technical Survey on Decentralized Digital Currencies,IEEE COMMUNICAITONS SURVEYS & TUTORIALS,Vol.18 No.3,2016年,p.2084-2123,especially II. THE BITCOIN PROTOCOL
淵田 康之,イノベーションと金融,野村資本市場クォータリー 2015年秋号 第19巻 第2号 Nomura Capital Markets Quarterly,日本,株式会社野村資本市場研究所,2015年11月01日,第19巻,p.11-35,ISSN 2185-4629

Also Published As

Publication number Publication date
US20200356547A1 (en) 2020-11-12
JPWO2019038839A1 (ja) 2020-10-15
WO2019038839A1 (ja) 2019-02-28
US11314727B2 (en) 2022-04-26

Similar Documents

Publication Publication Date Title
JP7003995B2 (ja) ブロックチェーン管理装置、ブロックチェーン管理方法及びプログラム
US10986177B2 (en) Systems and methods of self-forking blockchain protocol
JP6969664B2 (ja) ブロックチェーン管理システム、ブロックチェーン管理装置、情報提供装置及びブロックチェーン管理方法
KR102050129B1 (ko) 블록 검증을 위한 복수의 일방향 함수를 지원하는 블록 체인
WO2018158936A1 (ja) ブロックチェーン管理装置、ブロックチェーン管理方法及びプログラム
Miller et al. The honey badger of BFT protocols
KR101727525B1 (ko) 블록체인 기반 분산 저장 방법 및 이를 이용한 장치
US11461310B2 (en) Distributed ledger technology
US11481375B2 (en) Point-to-point distributed decentralized system
EP3321819B1 (en) Device, method and program for securely reducing an amount of records in a database
KR20210003234A (ko) 분할된 블록체인 네트워크에서 블록체인의 블록을 유지하는 것
CN107480990A (zh) 区块链记账方法及装置
EP3726774A1 (en) Transparent blockchain sidechains to support blockchain processing heterogeneity
JP6495346B2 (ja) 情報処理システム
CN112651724A (zh) 跨链交互方法、装置和系统
JP7508521B2 (ja) ブロックチェーンネットワークを介してデータを通信し、格納し、及び処理するためのブロックチェーンベースのシステム及び方法
CN114039733B (zh) 一种针对联盟链的存证业务转移方法、装置及设备
US11625260B2 (en) Method for enhancing throughput in blockchain network
JP2023547716A (ja) マークル証明エンティティ
CN112995167B (zh) 基于Kafka机制的用电信息采集方法、区块链网络及用户端
US20200202437A1 (en) Blockchain-based settlement method, apparatus, and electronic device
CN109934015B (zh) 区块数据增信方法、区块链节点及存储介质
JP6971127B2 (ja) 端末およびブロックチェーンシステム
KR20210127231A (ko) 동력화된 ID (Energized Identity) 기반 블록체인
CN108880785A (zh) 一种检测C++虚表被hook的方法、装置、终端及可读介质

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20200221

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20210420

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20210604

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

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20211213