JP6692561B2 - ブロックチェーンコンセンサス方法およびデバイス - Google Patents

ブロックチェーンコンセンサス方法およびデバイス Download PDF

Info

Publication number
JP6692561B2
JP6692561B2 JP2019536035A JP2019536035A JP6692561B2 JP 6692561 B2 JP6692561 B2 JP 6692561B2 JP 2019536035 A JP2019536035 A JP 2019536035A JP 2019536035 A JP2019536035 A JP 2019536035A JP 6692561 B2 JP6692561 B2 JP 6692561B2
Authority
JP
Japan
Prior art keywords
consensus
node
blockchain
service data
service
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
JP2019536035A
Other languages
English (en)
Other versions
JP2020510894A (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.)
Alibaba Group Holding Ltd
Original Assignee
Alibaba Group Holding 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
Application filed by Alibaba Group Holding Ltd filed Critical Alibaba Group Holding Ltd
Publication of JP2020510894A publication Critical patent/JP2020510894A/ja
Application granted granted Critical
Publication of JP6692561B2 publication Critical patent/JP6692561B2/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/22Payment schemes or models
    • G06Q20/223Payment schemes or models based on the use of peer-to-peer networks
    • 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/1824Distributed file systems implemented using Network-attached Storage [NAS] architecture
    • G06F16/1827Management specifically adapted to NAS
    • 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/11File system administration, e.g. details of archiving or snapshots
    • G06F16/122File system administration, e.g. details of archiving or snapshots using management policies
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/50Allocation of resources, e.g. of the central processing unit [CPU]
    • G06F9/5005Allocation of resources, e.g. of the central processing unit [CPU] to service a request
    • G06F9/5027Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals
    • G06F9/5033Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals considering data affinity
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/54Interprogram communication
    • G06F9/544Buffers; Shared memory; Pipes
    • 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/405Establishing or using transaction specific rules
    • 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/06Buying, selling or leasing transactions
    • 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
    • G06Q40/00Finance; Insurance; Tax strategies; Processing of corporate or income taxes
    • G06Q40/02Banking, e.g. interest calculation or account maintenance
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/04Network architectures or network communication protocols for network security for providing a confidential data exchange among entities communicating through data packet networks
    • H04L63/0428Network architectures or network communication protocols for network security for providing a confidential data exchange among entities communicating through data packet networks wherein the data content is protected, e.g. by encrypting or encapsulating the payload
    • 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)
  • Theoretical Computer Science (AREA)
  • Software Systems (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Business, Economics & Management (AREA)
  • General Engineering & Computer Science (AREA)
  • Accounting & Taxation (AREA)
  • Finance (AREA)
  • Computer Security & Cryptography (AREA)
  • Strategic Management (AREA)
  • General Business, Economics & Management (AREA)
  • Development Economics (AREA)
  • Economics (AREA)
  • Databases & Information Systems (AREA)
  • Data Mining & Analysis (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Marketing (AREA)
  • Computer Hardware Design (AREA)
  • Computing Systems (AREA)
  • Technology Law (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
  • Financial Or Insurance-Related Operations Such As Payment And Settlement (AREA)
  • Management, Administration, Business Operations System, And Electronic Commerce (AREA)
  • Computer And Data Communications (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)

Description

本出願は、インターネット情報処理技術の分野、およびコンピュータ技術の分野に関し、詳細には、ブロックチェーンコンセンサス方法およびデバイスに関する。
分散型台帳技術とも呼ばれるブロックチェーン技術は、分散型インターネットデータベース技術である。ブロックチェーン技術に基づいて構築されたネットワークは、ブロックチェーンネットワークと呼ばれることが可能である。ブロックチェーンネットワークは、ネットワークノード(ブロックチェーンノードと呼ばれることも可能であり、以下では略してノードと呼ばれる)を含む。各ノードは、少なくとも1つのブロックチェーンに対応し、各ブロックチェーンは、少なくとも1つのブロックを含む。ブロックチェーンネットワーク(またはブロックチェーン技術)には、非集中化、透明性、改ざん耐性、および信用性という特徴がある。これらの特徴に基づいて、ブロックチェーン技術は、ますます多くの分野において利用される。
サービスデータをブロックチェーンに記録する処理(すなわち、サービスデータをブロックチェーンネットワークに格納する処理)は、取扱フェーズ、コンセンサスフェーズ、および格納フェーズという3つのフェーズを含む。取扱フェーズは、ブロックチェーンネットワーク内の一定のブロックチェーンノードが、ブロックチェーンに記録されることになるサービスデータを受け取ること、およびブロックチェーンノードが、サービスデータを取り扱うこととして理解されることが可能である。コンセンサスフェーズは、ブロックチェーンノードがサービスデータを取り扱った後、ブロックチェーンネットワーク内の別のブロックチェーンノードが、サービスデータに対するコンセンサス処理に参加する必要があることとして理解されることが可能である。格納フェーズは、サービスデータに対するコンセンサスが得られた後に始まる。格納フェーズは、コンセンサスが得られたサービスデータをブロックチェーンノードがブロックチェーンに記録することとして理解されることが可能である。
サービスデータをブロックチェーンに記録する処理に含まれる3つのフェーズの中でも、コンセンサスフェーズは、ブロックチェーンネットワーク内の別のブロックチェーンノードの参加を必要とする。コンセンサス処理がサービスデータに対して行われているとき、コンセンサス処理に参加するブロックチェーンノードが多くなると、コンセンサス処理時間が長くなるということが研究で発見された。必然的に、サービスデータに対して行われるコンセンサス処理の効率は低下する。
したがって、本出願の実装形態は、既存技術における低いコンセンサス処理効率の問題を軽減させるためのブロックチェーンコンセンサス方法およびデバイスを提供する。
本出願の実装形態において、以下の技術的解決策が採用される。
本出願の1つの実装形態は、ブロックチェーンコンセンサス方法を提供し、ブロックチェーンノードにより、コンセンサス手順が行われることになるサービスデータを入手するステップと、サービスデータのサービスタイプを決定するステップと、ブロックチェーンノードにより、コンセンサスサービスを提供する少なくとも1つのコンセンサスノードを、サービスタイプに基づいてコンセンサスネットワークから選択するステップと、選択されたコンセンサスノードがサービスデータに対するコンセンサス処理を行うように、ブロックチェーンノードにより、選択されたコンセンサスノードにサービスデータを送るステップと、を含む。
本出願の1つの実装形態は、ブロックチェーンコンセンサスデバイスをさらに提供し、取得ユニット、選択ユニット、および送信ユニットを含み、取得ユニットが、コンセンサス手順が行われることになるサービスデータを入手し、サービスデータのサービスタイプを決定し、選択ユニットが、コンセンサスサービスを提供する少なくとも1つのコンセンサスノードを、サービスタイプに基づいてコンセンサスネットワークから選択し、送信ユニットが、選択されたコンセンサスノードがサービスデータに対するコンセンサス処理を行うように、選択されたコンセンサスノードにサービスデータを送る。
本出願の1つの実装形態は、ブロックチェーンコンセンサスデバイスをさらに提供し、メモリおよび少なくとも1つのプロセッサを含み、メモリが、プログラムを格納し、少なくとも1つのプロセッサが、コンセンサス手順が行われることになるサービスデータを入手し、サービスデータのサービスタイプを決定するステップと、コンセンサスサービスを提供する少なくとも1つのコンセンサスノードを、サービスタイプに基づいてコンセンサスネットワークから選択するステップと、選択されたコンセンサスノードがサービスデータに対するコンセンサス処理を行うように、選択されたコンセンサスノードにサービスデータを送るステップと、を行うように構成される。
本出願の実装形態において採用される前述の技術的解決策のうちの少なくとも1つは、本出願の実装形態において、コンセンサス手順が行われることになるサービスデータのサービスタイプに基づいて、コンセンサスサービスを提供するコンセンサスノードが選択されることが可能であること、およびサービスデータに対するコンセンサス処理を、選択されたコンセンサスノードが行うこと、という有益な効果をもたらすことができる。このようにして、様々なサービスに対するコンセンサス処理を行うために、いくつかのコンセンサスノードがコンセンサスネットワークから選択され、このことにより、コンセンサス処理に参加する大きな数量のコンセンサスノードによって引き起こされる長いコンセンサス処理時間の問題を軽減させる。このことは、コンセンサス処理時間を短縮するだけでなく、コンセンサス処理結果の正当性も保証することができ、このことにより、ブロックチェーンネットワークのサービスデータ処理効率を効果的に改善する。
ここで説明される添付の図面は、本出願についてさらに理解することを意図するものであり、本出願の一部である。本出願の例証的な実装形態およびこれらの説明は、本出願を説明することを意図するものであり、本出願に対する限定ではない。
本出願の1つの実装形態による、ブロックチェーンコンセンサス方法を示す概略流れ図である。 本出願の1つの実装形態による、ブロックチェーンコンセンサス方法を示す概略流れ図である。 本出願の1つの実装形態による、ブロックチェーンコンセンサスデバイスを示す概略構造図である。
本出願の目的、技術的解決策、および長所を明らかにするために、以下は、本出願の特定の実装形態および添付の図面を参照しながら、本出願の技術的解決策を明確かつ包括的に説明する。明らかに、説明される実装形態は、本出願の実装形態のすべてではなく、いくつかにすぎない。創造的な努力なく、本出願の実装形態に基づいて当業者によって得られた他のすべての実装形態は、本出願の保護範囲に含まれる。
本出願の実装形態において提供される技術的解決策が、添付の図面を参照しながら下記で詳細に説明される。
本出願の実装形態において説明されるブロックチェーンネットワークおよびコンセンサスネットワークは、同じネットワークであることが可能である。言い換えると、ネットワーク内のブロックチェーンノードは、コンセンサスノードと呼ばれることも可能である。ネットワーク内でサービスデータを取り扱うノードは、サービス取扱ノードと呼ばれることが可能であり、サービスデータに対するコンセンサス処理を始める。ネットワークは、このノードの他に複数のノードを含む。これらのノードは、これらのノードがサービスデータに対するコンセンサス処理に参加すると、コンセンサスノードと呼ばれることが可能である。さらに、これらのノードは、サービス取扱ノードとして機能することもできる。例えば、ブロックチェーンネットワークは、5つのノード(ノード1、ノード2、ノード3、ノード4、およびノード5)を含み、各ノードは、サービス取扱ノードとコンセンサスノードの両方として機能することができる。ノード1がサービスデータを取り扱う場合、ノード1は、サービス取扱ノードとして機能し、ノード2、ノード3、ノード4、およびノード5は、サービスデータのためのコンセンサスノードとして機能し、サービスデータに対するコンセンサス処理に参加する。
本出願の実装形態において説明されるブロックチェーンネットワークには、コンセンサスネットワークを含むことができる。この場合、コンセンサスネットワークに含まれるコンセンサスノードは、ブロックチェーンネットワーク内のブロックチェーンノードによって始められたコンセンサス要求に対するコンセンサス処理を行うことができる。例えば、ブロックチェーンネットワークは、5つのノード(ノード1、ノード2、ノード3、ノード4、およびノード5)を含み、ここで、ノード2、ノード4、およびノード5は、コンセンサスネットワーク内のコンセンサスノードである。この場合、ノード2、ノード4、およびノード5は、ノード1またはノード3によって始められたコンセンサス要求に対するコンセンサス処理を行うことができる。ノード1およびノード3は、ここでは、サービスデータを取り扱うためのノードとして機能し、取り扱われるサービスデータに対するコンセンサス処理を行うことを、コンセンサスネットワーク内のコンセンサスノードにリクエストすることができる。すなわち、コンセンサスノードは、サービスデータの取扱いに参加しなくてよい。
本出願の実装形態において、コンセンサスノードにコンセンサス結果が格納されるかどうかは限定されず、実際の要求に基づいて判断されてよい。コンセンサスノードにコンセンサス結果が格納される場合と、コンセンサスノードにコンセンサス結果が格納されない場合の両方が、本出願の実装形態の保護範囲に含まれる。
図1は、本出願の1つの実装形態による、ブロックチェーンコンセンサス方法を示す概略流れ図である。方法は、以下のように説明されることが可能である。
ステップ101。ブロックチェーンノードは、コンセンサス手順が行われることになるサービスデータを入手し、サービスデータのサービスタイプを決定する。
本出願の本実装形態において、ブロックチェーンノードは、サービスデータを取り扱うためのノード、コンセンサス処理を始めるためのノード、または本コンセンサス処理のための1次ノードとして機能することができ、このことは、ここでは限定されない。
ブロックチェーンノードが、サービスデータを取り扱うためのノードとして機能する場合、ブロックチェーンノードは、取り扱われてローカルに格納されたサービスデータから、コンセンサス手順が行われることになるサービスデータとしていくつかのサービスデータを取得し、取得されたサービスデータに対してその後始められるコンセンサス処理を容易にすることができる。
ブロックチェーンノードが、サービスデータを取り扱うためのノードではなく、本コンセンサス処理のための1次ノードとして機能する場合、ブロックチェーンノードは、コンセンサス手順が行われることになるサービスデータのリソースプールからいくつかのサービスデータを取得し、コンセンサス手順が行われることになるサービスデータとして取得されたサービスデータを使用して、取得されたサービスデータに対してその後始められるコンセンサス処理を容易にすることができる。
コンセンサス手順が行われることになるサービスデータを入手した後、ブロックチェーンノードは、コンセンサス手順が行われることになるサービスデータを生成するサービスを決定し、コンセンサス手順が行われることになるサービスデータに対応するサービスタイプをさらに決定する。
サービスは、様々なサービス機能に基づいて様々なタイプに分類されることが可能である。例えば、サービスは、順序タイプ(順序生成フェーズにおいて生成されたサービスデータに対応するサービスタイプは順序タイプである)、または支払タイプ(支払情報を含むサービスデータに対応するサービスタイプは支払タイプである)のものであることが可能である。サービスは一方、異なるサービス内容に基づいて分類されることが可能である。例えば、サービスは、カード発行タイプ(カード発行情報を含むサービスデータに対応するサービスタイプはカード発行タイプである)、または取引タイプ(取引情報を含むサービスデータに対応するサービスタイプは取引タイプである)のものであることが可能である。サービスタイプの分類原理は、ここでは限定されない。
ブロックチェーンノードは、コンセンサス手順が行われることになるサービスデータを入手した後に、各サービスデータに対応するサービスタイプを決定する。実際には、サービスタイプの適用範囲の中には重複するものもあるので、各サービスデータに対応するサービスタイプを決定するときに、ブロックチェーンノードは、コンセンサス手順が行われることになる入手されたサービスデータに対応するサービスタイプとして、クラスタ方式で(または、ここでは限定されない別の方式で)、より広い適用範囲を有するサービスタイプを決定することができる。
例えば、コンセンサス手順が行われることになる入手されたサービスデータに対応するサービスタイプは、順序タイプおよび支払タイプを含む。順序タイプのサービスデータ、および支払タイプのサービスデータの両方が、サービス内容に基づく取引タイプに属するので、コンセンサス手順が行われることになるサービスデータに対応するサービスタイプは、取引タイプとして判断される。
1つまたは複数のサービスタイプが、ここで決定されることが可能であるということに留意する価値がある。複数のサービスタイプが決定される場合、その後のステップにおける1つのコンセンサスアルゴリズムに複数のサービスタイプが対応することが可能である。または複数のサービスタイプが複数のコンセンサスアルゴリズムに対応することが可能であるが、複数のサービスタイプに適用可能な1つのコンセンサスアルゴリズムは、複数のコンセンサスアルゴリズムから決定されることが可能である。
ステップ102。ブロックチェーンノードは、コンセンサスサービスを提供する少なくとも1つのコンセンサスノードを、サービスタイプに基づいてコンセンサスネットワークから選択する。
本出願の本実装形態において、ブロックチェーンノードはまず、受け取られたサービスデータのサービスタイプに対応するコンセンサスポリシーを、サービスタイプとコンセンサスポリシーの間の所定のマッピング関係に基づいて決定し、ここでコンセンサスポリシーは、コンセンサスアルゴリズムを含む。
コンセンサスポリシーは、一定のサービスまたはいくつかのサービスによって生成されたサービスデータに対するコンセンサス処理を行う方法である。具体的に言うと、コンセンサスポリシーは、指定のサービスタイプに対応するサービスによって生成されるサービスデータに対するコンセンサス処理を行うために使用されるコンセンサスアルゴリズムを指定する。
コンセンサスポリシーは、ここでは、使用されるコンセンサスアルゴリズムを含むことができ、コンセンサスメカニズムをさらに含むことができる。コンセンサスメカニズムは、ここでは、コンセンサスネットワーク内のコンセンサスノードが、全体的なコンセンサス処理を行う必要があるかどうかを含む。全体的なコンセンサス処理を行う必要がある場合、コンセンサスポリシーに含まれるコンセンサスメカニズムは、全体的なコンセンサスメカニズムである。全体的なコンセンサス処理を行う必要がない場合、コンセンサスポリシーに含まれるコンセンサスメカニズムは、局所的なコンセンサスメカニズムである。
本出願の本実装形態におけるコンセンサスポリシーに含まれるコンセンサスアルゴリズムは、プルーフ・オブ・ワーク(PoW:Proof of Work)アルゴリズム、プルーフ・オブ・ステーク(PoS:Proof of Stake)アルゴリズム、デリゲーテッド・プルーフ・オブ・ステーク(DPoS:Delegated Proof of Stake)アルゴリズム、プラクティカル・ビザンチン・フォールト・トレランス(PBFT:Practical Byzantine Fault Tolerance)アルゴリズム、およびデリゲーテッド・ビザンチン・フォールト・トレランス(DBFT:Delegated Byzantine Fault Tolerance)アルゴリズムを含むがこれらに限定されない。
同じコンセンサスポリシーまたは異なるコンセンサスポリシーに、様々なサービスタイプが対応することが可能であるということに留意する価値がある。本出願の本実装形態において、サービスデータ処理効率を保証するために、様々なコンセンサスアルゴリズムが、様々なサービスタイプのサービスデータに対して使用されることが可能である。様々なサービスタイプおよび動作原理の特徴、ならびに様々なコンセンサスアルゴリズムの長所および短所に基づいて、比較的適用可能で、処理効率を保証できるコンセンサスアルゴリズムが様々なサービスタイプに対して決定されることが可能である。マッピング関係は、サービスタイプとコンセンサスアルゴリズムの間で確立されることが可能である。
例えばPBFTアルゴリズムは、比較的大量のデータを含み、攻撃に対して脆弱ではない順序タイプのサービスデータに対するコンセンサス処理を行うために使用されることが可能であり、PoWアルゴリズムは、攻撃に対して脆弱な支払タイプのサービスデータに対するコンセンサス処理を行うために使用されることが可能である。サービスタイプに対するコンセンサスアルゴリズムは、ここでは限定されない。
さらにブロックチェーンノードは、コンセンサスサービスを提供する少なくとも1つのコンセンサスノードを、コンセンサスアルゴリズムに基づいてコンセンサスネットワークから選択する。
ブロックチェーンノードは、コンセンサス処理に参加することになるコンセンサスノードの数量を、コンセンサスアルゴリズムに基づいて決定し、この数量が、コンセンサスアルゴリズムの所定の数量を満たし、コンセンサスネットワークからコンセンサスノードの数量を選択する。
様々なコンセンサスアルゴリズムが様々な動作原理を有するので、コンセンサス処理に参加することが許されるコンセンサスノードの数量は、コンセンサスアルゴリズムに応じて変化する。例えば、PoWアルゴリズムに対して、ネットワーク内のすべてのノードは、1回のコンセンサス処理に参加するコンセンサスノードとして機能する必要がある。別の例として、PBFTアルゴリズムに対して、最低4つのノードが、1回のコンセンサス処理に参加するコンセンサスノードとして機能する必要がある。
したがって、本出願の本実装形態において、コンセンサス処理に参加することになるコンセンサスノードは、コンセンサスアルゴリズムの最低投票設定によって必要とされるコンセンサスノードの数量に基づいて選択されることが可能である。
一方、本出願の本実装形態において、コンセンサス処理に参加することになるコンセンサスノードの数量は、(ランダム化アルゴリズムなどの)指定のアルゴリズムに基づいて決定されることが可能である。
例えば、コンセンサス処理に参加することになるコンセンサスノードの数量は次のように決定される。
R=ノード番号%ノードの数量。すなわち、Rは、ノード番号がノードの数量で割られるときの余りを計算することによって得られることが可能である。
Rは、コンセンサス処理に参加することになるコンセンサスノードの決定された数量である。ノード番号は、ステップ101において説明された、コンセンサス手順が行われることになるサービスデータを得るブロックチェーンノードの番号である。ノードの数量は、ブロックチェーンネットワークに含まれるブロックチェーンノードの数量(またはコンセンサスネットワークに含まれるコンセンサスノードの数量)である。
ブロックチェーンネットワーク内の各ブロックチェーンノードは、予め番号を付けられることが可能であるということに留意する価値がある。このようにして、ステップ101において説明された、コンセンサス手順が行われることになるサービスデータを得るブロックチェーンノードの番号は、迅速に決定されることが可能である。コンセンサス処理に参加することになるコンセンサスノードの数量が先の方程式を使用することによって決定されると、コンセンサス処理に参加することになるコンセンサスノードの決定された数量は、サービスデータを取り扱うためのノードの番号に応じて、同じサービスタイプのサービスデータに対して変化する。または様々なサービスタイプのサービスデータを取り扱うためのノードが、予め決定されることが可能である。言い換えると、サービスタイプのサービスデータを取り扱うためのノードは、ブロックチェーンネットワーク内の指定されたブロックチェーンノードである。この場合、上記で決定されたような、コンセンサス処理に参加するコンセンサスノードの数量は、同じサービスタイプのサービスデータに対して同じであることが可能である。
さらに、方程式におけるノード番号は一方、サービスタイプ番号であることが可能である。様々なサービスタイプの番号が予め決定されることが可能である。この場合、同じサービスタイプのサービスデータに対して、コンセンサス手順が行われることになるサービスデータに対応するサービスタイプが、ステップ101において決定された後、サービスタイプに対応するサービスタイプ番号がさらに決定されることが可能であり、その後、コンセンサス処理に参加することになるコンセンサスノードの数量は、先の方程式に基づいて決定されることが可能である。
コンセンサス処理に参加することになるコンセンサスノードの数量が決定された後、次のように、コンセンサスノードの数量がコンセンサスネットワークから選択されることが可能である。
ブロックチェーンノードがコンセンサスネットワークからコンセンサスノードの数量をランダムに選択するか、コンセンサスネットワーク内のコンセンサスノードの負荷に基づいて、ブロックチェーンノードがコンセンサスネットワークからコンセンサスノードの数量を選択する。
例えば、コンセンサス処理に参加することになるコンセンサスノードの数量が4と決定される。この場合、4つのコンセンサスノードは、コンセンサスネットワークからランダムに選択されることが可能であり、4つの選択されたコンセンサスノードは、本コンセンサス処理のためのコンセンサスサービスを提供する。一方、サービスデータ処理効率を改善するために、コンセンサスネットワーク内のコンセンサスノードの負荷状況が判断されることが可能であり、コンセンサスネットワーク内のコンセンサスノードが負荷状況に基づいて順番に並べられ、順番の中の最後の4つのコンセンサスノードがコンセンサスネットワークから選択され、4つの選択されたコンセンサスノードが本コンセンサス処理のためのコンセンサスサービスを提供する。
さらに、本出願の本実装形態において、少なくとも1つのコンセンサスアルゴリズムが、コンセンサスネットワーク内の各コンセンサスノードに対して構成されることが可能である。この場合、ブロックチェーンノードは、コンセンサス処理に参加することになるコンセンサスノードの数量を決定した後、コンセンサスネットワーク内の各コンセンサスノードによってサポートされるコンセンサスアルゴリズムを決定する。
ブロックチェーンノードは、コンセンサスポリシーに含まれるコンセンサスアルゴリズムをサポートするコンセンサスノードを、各コンセンサスノードによってサポートされるコンセンサスアルゴリズムに基づいて決定し、決定されたコンセンサスノードからコンセンサスノードの数量を選択する。
好ましくは、本出願の本実装形態において、ブロックチェーンノードがコンセンサスノードを選択した後、特に、決定されたコンセンサスポリシーに含まれるコンセンサスメカニズムが局所的なコンセンサスメカニズムであるとき、本コンセンサス結果の正当性を保証するために、ブロックチェーンノードは、選択されたコンセンサスノードがコンセンサスサービスを提供することに合意すべきかどうかについて他のブロックチェーンノードが投票するように、選択されたコンセンサスノードを他のブロックチェーンノードにブロードキャストする。ブロックチェーンノードが他のブロックチェーンノードからコンセンサス到達メッセージを受け取ると、このことは、選択されたコンセンサスノードがコンセンサス処理に参加することになるということに他のブロックチェーンノードが合意することを示し、コンセンサスノードによって得られたコンセンサス結果が正当であるとみなされることを意味する。そうでなければ、ブロックチェーンノードは、コンセンサスノードを再び選択する動作を行う必要がある。
ステップ103。ブロックチェーンノードは、コンセンサスノードがサービスデータに対するコンセンサス処理を行うように、選択されたコンセンサスノードにサービスデータを送る。
ブロックチェーンノードは、コンセンサスノードがサービスデータに対するコンセンサス処理を行うように、選択されたコンセンサスノードにサービスデータをブロードキャストする。
好ましくは、本出願の本実装形態において、ブロックチェーンノードは、他のブロックチェーンノードによって送られたコンセンサス到達メッセージを受け取ると、選択されたコンセンサスノードにサービスデータを送る。
サービスデータに対するコンセンサス処理が完了すると、ブロックチェーンノードは、選択されたコンセンサスノードによって送られた、サービスデータに対するコンセンサス結果を受け取り、サービスデータに対するコンセンサス結果が全体的に共有される必要があると判断すると、ブロックチェーンノードは、コンセンサス処理に参加していない、コンセンサスネットワーク内のコンセンサスノードに、サービスデータに対するコンセンサス結果を送り、サービスデータに対するコンセンサス結果をブロックチェーンに格納する。
選択されたコンセンサスノードによって送られた、サービスデータに対するコンセンサス結果を受け取ると、ブロックチェーンノードは、サービスデータに対するコンセンサス結果が全体的に共有される必要がないと判断すると、サービスデータに対するコンセンサス結果をブロックチェーンに格納する。
ブロックチェーンノードは、サービスデータに対するコンセンサス結果が全体的に共有される必要があるかどうかについて、ステップ102において決定されたコンセンサスポリシーに含まれるデータ共有メカニズムに基づいて判断することができるということに留意する価値がある。データ共有メカニズムが全体的な共有メカニズムである場合、ブロックチェーンノードは、サービスデータに対するコンセンサス結果が全体的に共有される必要があると判断する。データ共有メカニズムが局所的な共有メカニズムである場合、ブロックチェーンノードは、サービスデータに対するコンセンサス結果が全体的に共有される必要がないと判断する。
すなわち、ステップ102において決定されたコンセンサスポリシーは、コンセンサスアルゴリズムおよびコンセンサスメカニズムの他にデータ共有メカニズムを含む。コンセンサスメカニズムが全体的なコンセンサスメカニズムであるサービスデータに対応するデータ共有メカニズムは、全体的な共有メカニズムである。コンセンサスメカニズムが局所的なコンセンサスメカニズムであるサービスデータに対応するデータ共有メカニズムは、全体的な共有メカニズムまたは局所的な共有メカニズムであることが可能である。詳細は、ここでは省略される。
本出願の本実装形態において提供される技術的解決策によれば、コンセンサスサービスを提供するコンセンサスノードは、コンセンサス手順が行われることになるサービスデータのサービスタイプに基づいて選択されることが可能であり、選択されたコンセンサスノードは、サービスデータに対するコンセンサス処理を行う。このようにして、様々なサービスに対するコンセンサス処理を行うために、いくつかのコンセンサスノードがコンセンサスネットワークから選択され、このことにより、コンセンサス処理に参加する大きな数量のコンセンサスノードによって引き起こされる長いコンセンサス処理時間の問題を軽減させる。このことは、コンセンサス処理時間を短縮するだけでなく、コンセンサス処理結果の正当性も保証することができ、このことにより、ブロックチェーンネットワークのサービスデータ処理効率を効果的に改善する。
図2は、本出願の1つの実装形態による、ブロックチェーンコンセンサス方法を示す概略流れ図である。方法は、以下のように説明されることが可能である。
ステップ201。ブロックチェーンノードは、コンセンサス手順が行われることになるサービスデータを入手し、サービスデータのサービスタイプを決定する。
本ステップの実装形態は、ステップ101の実装形態と同じであるか類似している。詳細は、ここでは省略される。
ステップ202。ブロックチェーンノードは、受け取られたサービスデータのサービスタイプに対応するコンセンサスポリシーを、サービスタイプとコンセンサスポリシーの間の所定のマッピング関係に基づいて決定し、コンセンサスポリシーは、コンセンサスアルゴリズムまたはコンセンサスメカニズムのうちの少なくとも1つを含む。
ステップ203。ブロックチェーンノードは、本コンセンサス処理が全体的に行われる必要があるかどうかを、コンセンサスポリシーに含まれるコンセンサスメカニズムに基づいて判断し、必要ならステップ204を行い、不要ならステップ206を行う。
ステップ204。ブロックチェーンノードは、コンセンサスノードがサービスデータに対する全体的なコンセンサス処理を行うように、コンセンサスネットワーク内のコンセンサスノードにサービスデータをブロードキャストする。
ステップ205。ブロックチェーンノードは、サービスデータに対するコンセンサス結果を受け取ると、サービスデータに対するコンセンサス結果をブロックチェーンに格納し、ここで、コンセンサス結果はコンセンサスノードによって送られる。
ステップ206。ブロックチェーンノードは、コンセンサスサービスを提供する少なくとも1つのコンセンサスノードを、コンセンサスアルゴリズムに基づいてコンセンサスネットワークから選択する。
ステップ207。ブロックチェーンノードは、選択されたコンセンサスノードがコンセンサスサービスを提供することに合意すべきかどうかについて他のブロックチェーンノードが投票するように、選択されたコンセンサスノードを他のブロックチェーンノードにブロードキャストする。
ステップ208。ブロックチェーンノードは、他のブロックチェーンノードによって送られたコンセンサス到達メッセージを受け取ると、選択されたコンセンサスノードにサービスデータを送る。
ステップ209。選択されたコンセンサスノードによって送られた、サービスデータに対するコンセンサス結果を受け取ると、ブロックチェーンノードは、サービスデータに対するコンセンサス結果が全体的に共有される必要があるかどうかを判断し、必要ならステップ210を行い、不要ならをステップ211を行う。
ステップ210。ブロックチェーンノードは、コンセンサス処理に参加していない、コンセンサスネットワーク内のコンセンサスノードに、サービスデータに対するコンセンサス結果を送り、サービスデータに対するコンセンサス結果をブロックチェーンに格納する。
ステップ211。ブロックチェーンノードは、サービスデータに対するコンセンサス結果をブロックチェーンに格納する。
図3は、本出願の1つの実装形態による、ブロックチェーンコンセンサスデバイスを示す概略構造図である。ブロックチェーンコンセンサスデバイスは、取得ユニット301、選択ユニット302、および送信ユニット303を含む。
取得ユニット301は、コンセンサス手順が行われることになるサービスデータを入手し、サービスデータのサービスタイプを決定する。
選択ユニット302は、コンセンサスサービスを提供する少なくとも1つのコンセンサスノードを、サービスタイプに基づいてコンセンサスネットワークから選択する。
送信ユニット303は、選択されたコンセンサスノードがサービスデータに対するコンセンサス処理を行うように、選択されたコンセンサスノードにサービスデータを送る。
本出願の別の実装形態において、選択ユニット302は、コンセンサスサービスを提供する少なくとも1つのコンセンサスノードを、サービスタイプに基づいてコンセンサスネットワークから選択し、受け取られたサービスデータのサービスタイプに対応するコンセンサスポリシーを、サービスタイプとコンセンサスポリシーの間の所定のマッピング関係に基づいて決定することであって、コンセンサスポリシーがコンセンサスアルゴリズムを含む、決定することと、コンセンサスサービスを提供する少なくとも1つのコンセンサスノードを、コンセンサスアルゴリズムに基づいてコンセンサスネットワークから選択することと、を含む。
本出願の別の実装形態において、選択ユニット302は、コンセンサスサービスを提供する少なくとも1つのコンセンサスノードを、コンセンサスアルゴリズムに基づいてコンセンサスネットワークから選択し、コンセンサス処理に参加することになるコンセンサスノードの数量を、コンセンサスアルゴリズムに基づいて決定することであって、数量が、コンセンサスアルゴリズムの所定の数量を満たす、決定することと、コンセンサスネットワークからコンセンサスノードの数量を選択することと、を含む。
本出願の別の実装形態において、選択ユニット302は、コンセンサスネットワークからコンセンサスノードの数量を選択し、以下、すなわち、コンセンサスネットワークからコンセンサスノードの数量をランダムに選択すること、またはコンセンサスネットワーク内のコンセンサスノードの負荷に基づいて、コンセンサスネットワークからコンセンサスノードの数量を選択すること、を含む。
本出願の別の実装形態において、選択ユニット302は、コンセンサスネットワークからコンセンサスノードの数量を選択し、コンセンサスネットワーク内の各コンセンサスノードによってサポートされるコンセンサスアルゴリズムを決定することと、コンセンサスポリシーに含まれるコンセンサスアルゴリズムをサポートするコンセンサスノードを、各コンセンサスノードによってサポートされるコンセンサスアルゴリズムに基づいて決定することと、決定されたコンセンサスノードからコンセンサスノードの数量を選択することと、を含む。
本出願の別の実装形態において、ブロックチェーンコンセンサスデバイスは、処理ユニット304をさらに含む。
処理ユニット304は、選択されたコンセンサスノードがコンセンサスサービスを提供することに合意すべきかどうかについて他のブロックチェーンノードが投票するように、選択されたコンセンサスノードにサービスデータが送られる前に、選択されたコンセンサスノードを他のブロックチェーンノードにブロードキャストする。
送信ユニット303は、選択されたコンセンサスノードにサービスデータを送り、他のブロックチェーンノードによって送られたコンセンサス到達メッセージを受け取ると、選択されたコンセンサスノードにサービスデータを送ることを含む。
本出願の別の実装形態において、ブロックチェーンコンセンサスデバイスは、判断ユニット305をさらに含む。
選択されたコンセンサスノードによって送られた、サービスデータに対するコンセンサス結果が受け取られるとき、サービスデータに対するコンセンサス結果が全体的に共有される必要があると判断すると、判断ユニット305は、コンセンサス処理に参加していない、コンセンサスネットワーク内のコンセンサスノードに、サービスデータに対するコンセンサス結果を送り、サービスデータに対するコンセンサス結果をブロックチェーンに格納する。
本出願の別の実装形態において、ブロックチェーンコンセンサスデバイスは、格納ユニット306をさらに含む。
選択されたコンセンサスノードによって送られた、サービスデータに対するコンセンサス結果が受け取られるとき、格納ユニット306は、サービスデータに対するコンセンサス結果が全体的に共有される必要がないということが判断されると、サービスデータに対するコンセンサス結果をブロックチェーンに格納する。
本出願の本実装形態において提供されるブロックチェーンコンセンサス処理デバイスは、ハードウェアまたはソフトウェアを使用することによって実装されることが可能であるということに留意する価値がある。このことは、ここでは限定されない。ブロックチェーンコンセンサス処理デバイスは、コンセンサス手順が行われることになるサービスデータのサービスタイプに基づいて、コンセンサスサービスを提供するコンセンサスノードを選択することができ、選択されたコンセンサスノードは、サービスデータに対するコンセンサス処理を行う。このようにして、様々なサービスに対するコンセンサス処理を行うために、いくつかのコンセンサスノードがコンセンサスネットワークから選択され、このことにより、コンセンサス処理に参加する大きな数量のコンセンサスノードによって引き起こされる長いコンセンサス処理時間の問題を軽減させる。このことは、コンセンサス処理時間を短縮するだけでなく、コンセンサス処理結果の正当性も保証することができ、このことにより、ブロックチェーンネットワークのサービスデータ処理効率を効果的に改善する。
本出願の1つの実装形態は、ブロックチェーンコンセンサスデバイスをさらに提供し、メモリおよび少なくとも1つのプロセッサを含み、メモリがプログラムを格納し、少なくとも1つのプロセッサが、コンセンサス手順が行われることになるサービスデータを入手し、サービスデータのサービスタイプを決定するステップと、コンセンサスサービスを提供する少なくとも1つのコンセンサスノードを、サービスタイプに基づいてコンセンサスネットワークから選択するステップと、選択されたコンセンサスノードがサービスデータに対するコンセンサス処理を行うように、選択されたコンセンサスノードにサービスデータを送るステップと、を行うように構成される。
プログラムによって実装される他の内容に対して、先の実装形態において説明された内容への参照が行われる。詳細は、ここでは省略される。
1990年代において、技術的な改良が、ハードウェア改良(例えば、ダイオード、トランジスタ、またはスイッチなどの回路構造に対する改良)であるか、ソフトウェア改良(方法手順に対する改良)であるかは、明確に区別されることが可能である。しかし、技術が発展するにつれて、多くの方法手順に対する現在の改良は、ハードウェア回路構造への直接的な改良とみなされることが可能である。設計者は通常、改良された方法手順をハードウェア回路にプログラムし、対応するハードウェア回路構造を得る。したがって方法手順は、ハードウェアエンティティモジュールを使用することによって改良されることが可能である。例えば、プログラマブルロジックデバイス(PLD:programmable logic device)(例えば、フィールドプログラマブルゲートアレイ(FPGA))はこのような集積回路であり、PLDの論理機能は、デバイスプログラミングを通じてユーザによって決定される。設計者はプログラミングを行い、特定用途向け集積回路チップを設計して生み出すことをチップ製造業者にリクエストすることなく、デジタルシステムをPLDに「統合する」。さらに、現在のところ、集積回路チップを手動で製造する代わりに、「ロジックコンパイラ」ソフトウェアを使用することによって、このようなプログラミングが主として実装される。ロジックコンパイラソフトウェアは、プログラムを開発するため、および書くために使用されるソフトウェアコンパイラに類似している。元のコードは、コンパイルのための特定のプログラミング言語で書かれる必要がある。言語は、ハードウェア記述言語(HDL:hardware description language)と呼ばれる。Advanced Boolean Expression Language(ABEL)、Altera Hardware Description Language(AHDL)、Confluence、Cornell University Programming Language(CUPL)、HDCal、Java(登録商標) Hardware Description Language(JHDL)、Lava、Lola、MyHDL、PALASM、およびRuby Hardware Description Language(RHDL)など、多くのHDLがある。超高速集積回路ハードウェア記述言語(VHDL:very-high-speed integrated circuit hardware description language)およびVerilog2が最も一般的に使用される。いくつかの説明されたハードウェア記述言語を使用することによって方法手順が論理的にプログラムされ、集積回路にプログラムされると、論理的な方法手順を実装するハードウェア回路が容易に得られることが可能であるということも当業者は理解するはずである。
コントローラは、任意の妥当な方法を使用することによって実装されることが可能である。例えば、コントローラは、マイクロプロセッサもしくはプロセッサ、あるいはマイクロプロセッサもしくはプロセッサ、論理ゲート、スイッチ、特定用途向け集積回路(ASIC)、プログラマブルロジックコントローラ、またはビルトインマイクロプロセッサによって実行されることが可能な(ソフトウェアもしくはファームウェアなどの)コンピュータ可読プログラムコードを格納するコンピュータ可読媒体であることが可能である。コントローラの例は、ARC 625D、Atmel AT91SAM、Microchip PIC18F26K20、およびSilicone Labs C8051F320などのマイクロプロセッサを含むがこれらに限定されない。メモリコントローラは、メモリの制御ロジックの一部として実装されることも可能である。コンピュータ可読プログラムコードを使用することによってコントローラを実装することの他に、ロジックプログラミングは、論理ゲート、スイッチ、特定用途向け集積回路、プログラマブルロジックコントローラ、およびビルトインマイクロコントローラの形で同じ機能をコントローラが実装できるようにするための方法ステップに対して行われることが可能であるということも当業者は知っている。したがってコントローラは、ハードウェア構成要素とみなされることが可能であり、コントローラに様々な機能を実装するように構成された装置は、ハードウェア構成要素内の構造とみなされることも可能である。または様々な機能を実装するように構成された装置は、方法を実装するソフトウェアモジュールと、ハードウェア構成要素内の構造の両方とみなされることさえ可能である。
先の実装形態において示されたシステム、装置、モジュール、またはユニットは、コンピュータチップまたはエンティティを使用することによって実装されることが可能であり、また一定の機能を有する製品を使用することによって実装されることが可能である。典型的な実行デバイスはコンピュータである。コンピュータは、例えば、パーソナルコンピュータ、ラップトップコンピュータ、セルラー電話、カメラフォン、スマートフォン、パーソナルデジタルアシスタント、メディアプレーヤ、ナビゲーションデバイス、eメールデバイス、ゲーム機、タブレット型コンピュータ、もしくはウェアラブルデバイス、またはこれらのデバイスのいずれかの組合せであることが可能である。
説明の容易性のために、上記の装置は、様々なユニットに機能を分割することによって説明される。間違いなく、本出願が実装されるとき、各ユニットの機能は、1つまたは複数のソフトウェアおよび/またはハードウェアの中に実装されることが可能である。
本開示の実装形態は、方法、システム、またはコンピュータプログラム製品として提供されることが可能であるということを当業者は理解するはずである。したがって本開示は、ハードウェアのみの実装形態、ソフトウェアのみの実装形態、またはソフトウェアとハードウェアの組合せによる実装形態の形式を使用することができる。さらに本開示は、コンピュータ使用可能プログラムコードを含む(ディスクメモリ、CD-ROM、光メモリ、等を含むがこれらに限定されない)1つまたは複数のコンピュータ使用可能ストレージ媒体上に実装されるコンピュータプログラム製品の形式を使用することができる。
本開示は、本開示の実装形態に基づいて、方法、デバイス(システム)、およびコンピュータプログラム製品の流れ図および/またはブロック図を参照しながら説明される。コンピュータプログラム命令は、流れ図および/またはブロック図における各処理および/または各ブロック、ならびに流れ図および/またはブロック図における処理および/またはブロックの組合せを実行するために使用されることが可能であるということに留意する価値がある。これらのコンピュータプログラム命令は、汎用コンピュータ、専用コンピュータ、組込みプロセッサ、または機械を生成するための別のプログラマブルデータ処理デバイスのプロセッサに提供されることが可能であり、その結果、コンピュータ、または別のプログラマブルデータ処理デバイスのプロセッサによって実行される命令は、流れ図における1つもしくは複数の処理における特定の機能、および/またはブロック図における1つもしくは複数のブロックにおける特定の機能を実行するためのデバイスを生成する。
コンピュータまたは別のプログラマブルデータ処理デバイスに、特定の方式で動くように命令することができる、これらのコンピュータプログラム命令は、コンピュータ可読メモリに格納されることが可能であり、その結果、コンピュータ可読メモリに格納された命令は、命令デバイスを含むアーチファクトを生成する。命令デバイスは、流れ図における1つもしくは複数の処理における特定の機能、および/またはブロック図における1つもしくは複数のブロックにおける特定の機能を実行する。
これらのコンピュータプログラム命令は、コンピュータまたは別のプログラマブルデータ処理デバイス上にロードされることが可能であり、その結果、コンピュータまたは別のプログラマブルデバイス上で一連の動作ならびに動作およびステップが行われ、このことにより、コンピュータ実行処理を生成する。したがって、コンピュータまたは別のプログラマブルデバイス上で実行される命令は、流れ図における1つもしくは複数の処理における特定の機能、および/またはブロック図における1つもしくは複数のブロックにおける特定の機能を実行するためのステップを提供する。
典型的な構成において、計算デバイスは、1つまたは複数のプロセッサ(CPU)、1つまたは複数の入出力インターフェース、1つまたは複数のネットワークインターフェース、および1つまたは複数のメモリを含む。
メモリは、非持続的メモリ、ランダムアクセスメモリ(RAM)、不揮発性メモリ、および/または例えばリードオンリメモリ(ROM)もしくはフラッシュメモリ(フラッシュRAM)といった、コンピュータ可読媒体内にある別の形式を含むことができる。メモリは、コンピュータ可読媒体の例である。
コンピュータ可読媒体は、任意の方法または技術を使用することによって情報を格納することができる持続的媒体、非持続的媒体、可動媒体、および非可動媒体を含む。情報は、コンピュータ可読命令、データ構造、プログラムモジュール、または他のデータであることが可能である。コンピュータストレージ媒体の例は、パラメータランダムアクセスメモリ(PRAM)、スタティックランダムアクセスメモリ(SRAM)、ダイナミックランダムアクセスメモリ(DRAM)、別のタイプのランダムアクセスメモリ(RAM)、リードオンリメモリ(ROM)、電気的消去可能プログラマブルリードオンリメモリ(EEPROM)、フラッシュメモリまたは別のメモリ技術、コンパクトディスクリードオンリメモリ(CD-ROM)、デジタル多用途ディスク(DVD)または別の光ストレージ、カセット磁気テープ、磁気テープ/磁気ディスクストレージまたは別の磁気ストレージデバイスを含むがこれらに限定されない。コンピュータストレージ媒体は、計算デバイスによってアクセス可能な情報を格納するために使用されることが可能である。本明細書における定義に基づくと、コンピュータ可読媒体は、変調されたデータ信号および担体などの一時コンピュータ可読媒体(一時媒体)を含まない。
用語「含む(include)」、「備える(comprise)」、またはこれらの他の任意の変形物は、非排他的な包含をカバーすることを意図するものであるので、要素の一覧を含む処理、方法、製品、もしくはデバイスは、これらの要素を含むだけでなく、明確に挙げられていない他の要素も含むということ、またはこのような処理、方法、製品、もしくはデバイスに固有の要素をさらに含むということにさらに留意する価値がある。さらなる制限なく、「〜を含む(includes a ...)」の前にある要素は、要素を含む処理、方法、製品、またはデバイスにおけるさらなる同一要素の存在を排除しない。
本出願は、例えばプログラムモジュールといった、コンピュータによって実行されるコンピュータ実行可能命令の一般的な文脈で説明されることが可能である。一般に、プログラムモジュールは、特定のタスクを実行するか、特定の抽象データ型を実装する、ルーチン、プログラム、オブジェクト、コンポーネント、データ構造、等を含む。本出願は、分散コンピューティング環境において実践されることも可能である。分散コンピューティング環境において、タスクは、通信ネットワークを通じて接続されたリモート処理デバイスによって行われる。分散コンピューティング環境において、プログラムモジュールは、ストレージデバイスを含む、ローカルとリモート両方のコンピュータストレージ媒体に配置されることが可能である。
本明細書における実装形態は漸進的な方式で説明される。実装形態の同じまたは類似の部分に対して、実装形態に対する参照が行われることが可能である。各実装形態は、他の実装形態との相違を重点的に取り扱う。特に、システムの実装形態は、方法の実装形態に基本的に類似しており、したがって簡単に説明される。関連部分に対しては、方法の実装形態における関連説明を参照されたい。
先の実装形態は本出願の実装形態であり、本出願を限定することを意図するものではない。当業者は、本出願に対する様々な修正および変更を行うことができる。本出願の精神および原理から逸脱することなく行われる任意の修正、同等の置換、または改良は、本出願における特許請求の範囲の範囲に含まれる。
301 取得ユニット
302 選択ユニット
303 送信ユニット
304 処理ユニット
305 判断ユニット
306 格納ユニット

Claims (17)

  1. ブロックチェーンコンセンサス方法であって、
    ブロックチェーンノードにより、コンセンサス手順が行われることになるサービスデータを入手するステップと、
    前記サービスデータのサービスタイプを決定するステップと、
    前記ブロックチェーンノードにより、コンセンサスサービスを提供する少なくとも1つのコンセンサスノードを、前記サービスタイプに基づいてコンセンサスネットワークから選択するステップと、
    前記選択されたコンセンサスノードが前記サービスデータに対するコンセンサス処理を行うように、前記ブロックチェーンノードにより、前記選択されたコンセンサスノードに前記サービスデータを送るステップと、
    を含む、ブロックチェーンコンセンサス方法。
  2. 前記ブロックチェーンノードにより、コンセンサスサービスを提供する少なくとも1つのコンセンサスノードを、前記サービスタイプに基づいてコンセンサスネットワークから選択する前記ステップが、
    前記コンセンサスノードにより、受け取られたサービスデータの前記サービスタイプに対応するコンセンサスポリシーを、サービスタイプとコンセンサスポリシーの間の所定のマッピング関係に基づいて決定するステップであって、前記コンセンサスポリシーがコンセンサスアルゴリズムを含む、ステップと、
    前記ブロックチェーンノードにより、前記コンセンサスサービスを提供する前記少なくとも1つのコンセンサスノードを、前記コンセンサスアルゴリズムに基づいて前記コンセンサスネットワークから選択するステップと、
    を含む、請求項1に記載のブロックチェーンコンセンサス方法。
  3. 前記ブロックチェーンノードにより、前記コンセンサスサービスを提供する前記少なくとも1つのコンセンサスノードを、前記コンセンサスアルゴリズムに基づいて前記コンセンサスネットワークから選択する前記ステップが、
    前記ブロックチェーンノードにより、前記コンセンサス処理に参加することになるコンセンサスノードの数量を、前記コンセンサスアルゴリズムに基づいて決定するステップであって、前記数量が、前記コンセンサスアルゴリズムの所定の数量を満たす、ステップと、
    前記ブロックチェーンノードにより、前記コンセンサスネットワークからコンセンサスノードの前記数量を選択するステップと、
    を含む、請求項2に記載のブロックチェーンコンセンサス方法。
  4. 前記ブロックチェーンノードにより、前記コンセンサスネットワークからコンセンサスノードの前記数量を選択する前記ステップが、
    前記ブロックチェーンノードにより、前記コンセンサスネットワークからコンセンサスノードの前記数量をランダムに選択するステップ、または
    前記ブロックチェーンノードにより、前記コンセンサスネットワーク内のコンセンサスノードの負荷に基づいて、前記コンセンサスネットワークからコンセンサスノードの前記数量を選択するステップ
    を含む、請求項3に記載のブロックチェーンコンセンサス方法。
  5. 前記ブロックチェーンノードにより、前記コンセンサスネットワークからコンセンサスノードの前記数量を選択する前記ステップが、
    前記ブロックチェーンノードにより、前記コンセンサスネットワーク内の各コンセンサスノードによってサポートされるコンセンサスアルゴリズムを決定するステップと、
    前記ブロックチェーンノードにより、前記コンセンサスポリシーに含まれる前記コンセンサスアルゴリズムをサポートするコンセンサスノードを、各コンセンサスノードによってサポートされる前記コンセンサスアルゴリズムに基づいて決定するステップと、
    前記決定されたコンセンサスノードからコンセンサスノードの前記数量を選択するステップと、
    を含む、請求項3に記載のブロックチェーンコンセンサス方法。
  6. 前記ブロックチェーンノードにより、前記選択されたコンセンサスノードに前記サービスデータを送る前記ステップの前に、前記方法が、
    前記選択されたコンセンサスノードが前記コンセンサスサービスを提供することに合意すべきかどうかについて他のブロックチェーンノードが投票するように、前記ブロックチェーンノードにより、前記選択されたコンセンサスノードを前記他のブロックチェーンノードにブロードキャストするステップをさらに含み、
    前記ブロックチェーンノードにより、前記選択されたコンセンサスノードに前記サービスデータを送る前記ステップが、
    前記ブロックチェーンノードにより、前記他のブロックチェーンノードによって送られたコンセンサス到達メッセージの受け取りに応答して、前記選択されたコンセンサスノードに前記サービスデータを送るステップを含む、請求項1から5のいずれか一項に記載のブロックチェーンコンセンサス方法。
  7. 前記ブロックチェーンノードにより、前記選択されたコンセンサスノードによって送られた、前記サービスデータに対するコンセンサス結果の受け取りに応答して、および前記サービスデータに対する前記コンセンサス結果が全体的に共有される必要があるという判断に応答して、前記コンセンサス処理に参加していない、前記コンセンサスネットワーク内のコンセンサスノードに前記サービスデータに対する前記コンセンサス結果を送り、前記サービスデータに対する前記コンセンサス結果をブロックチェーンに格納するステップをさらに含む、請求項6に記載のブロックチェーンコンセンサス方法。
  8. 前記ブロックチェーンノードにより、前記選択されたコンセンサスノードによって送られた、前記サービスデータに対するコンセンサス結果の受け取りに応答して、前記サービスデータに対する前記コンセンサス結果が全体的に共有される必要がないという判断に応答して、前記サービスデータに対する前記コンセンサス結果をブロックチェーンに格納するステップをさらに含む、請求項6に記載のブロックチェーンコンセンサス方法。
  9. ブロックチェーンコンセンサスデバイスであって、
    取得ユニット、選択ユニット、および送信ユニットを備え、
    前記取得ユニットが、コンセンサス手順が行われることになるサービスデータを入手し、前記サービスデータのサービスタイプを決定し、
    前記選択ユニットが、コンセンサスサービスを提供する少なくとも1つのコンセンサスノードを、前記サービスタイプに基づいてコンセンサスネットワークから選択し、
    前記送信ユニットが、前記選択されたコンセンサスノードが前記サービスデータに対するコンセンサス処理を行うように、前記選択されたコンセンサスノードに前記サービスデータを送る、ブロックチェーンコンセンサスデバイス。
  10. 前記選択ユニットが、前記コンセンサスサービスを提供する前記少なくとも1つのコンセンサスノードを、前記サービスタイプに基づいて前記コンセンサスネットワークから選択することが、
    受け取られたサービスデータの前記サービスタイプに対応するコンセンサスポリシーを、サービスタイプとコンセンサスポリシーの間の所定のマッピング関係に基づいて決定することであって、前記コンセンサスポリシーがコンセンサスアルゴリズムを含む、前記決定することと、
    前記コンセンサスサービスを提供する前記少なくとも1つのコンセンサスノードを、前記コンセンサスアルゴリズムに基づいて前記コンセンサスネットワークから選択することと、
    を含む、請求項9に記載のブロックチェーンコンセンサスデバイス。
  11. 前記選択ユニットが、前記コンセンサスサービスを提供する前記少なくとも1つのコンセンサスノードを、前記コンセンサスアルゴリズムに基づいて前記コンセンサスネットワークから選択することが、
    前記コンセンサス処理に参加することになるコンセンサスノードの数量を、前記コンセンサスアルゴリズムに基づいて決定することであって、前記数量が、前記コンセンサスアルゴリズムの所定の数量を満たす、前記決定することと、
    前記コンセンサスネットワークからコンセンサスノードの前記数量を選択することと、
    を含む、請求項10に記載のブロックチェーンコンセンサスデバイス。
  12. 前記選択ユニットが、前記コンセンサスネットワークからコンセンサスノードの前記数量を選択することが、
    前記コンセンサスネットワークからコンセンサスノードの前記数量をランダムに選択すること、または
    前記コンセンサスネットワーク内のコンセンサスノードの負荷に基づいて、前記コンセンサスネットワークからコンセンサスノードの前記数量を選択すること、
    を含む、請求項11に記載のブロックチェーンコンセンサスデバイス。
  13. 前記選択ユニットが、前記コンセンサスネットワークからコンセンサスノードの前記数量を選択することが、
    前記コンセンサスネットワーク内の各コンセンサスノードによってサポートされるコンセンサスアルゴリズムを決定することと、
    前記コンセンサスポリシーに含まれる前記コンセンサスアルゴリズムをサポートするコンセンサスノードを、各コンセンサスノードによってサポートされる前記コンセンサスアルゴリズムに基づいて決定することと、
    前記決定されたコンセンサスノードから前記コンセンサスノードの数量を選択することと、
    を含む、請求項11に記載のブロックチェーンコンセンサスデバイス。
  14. 処理ユニットをさらに含み、
    前記処理ユニットが、前記選択されたコンセンサスノードが前記コンセンサスサービスを提供することに合意すべきかどうかについて他のブロックチェーンノードが投票するように、前記選択されたコンセンサスノードに前記サービスデータが送られる前に、前記選択されたコンセンサスノードを前記他のブロックチェーンノードにブロードキャストすることを含み、
    前記送信ユニットが、前記選択されたコンセンサスノードに前記サービスデータを送ることが、
    前記他のブロックチェーンノードによって送られたコンセンサス到達メッセージの受け取りに応答して、前記選択されたコンセンサスノードに前記サービスデータを送ることを含む、請求項9から13のいずれか一項に記載のブロックチェーンコンセンサスデバイス。
  15. 判断ユニットをさらに備え、
    前記選択されたコンセンサスノードによって送られた、前記サービスデータに対するコンセンサス結果が受け取られたという判断に応答して、および前記サービスデータに対する前記コンセンサス結果が全体的に共有される必要があるという判断に応答して、前記判断ユニットが、前記コンセンサス処理に参加していない、前記コンセンサスネットワーク内のコンセンサスノードに、前記サービスデータに対する前記コンセンサス結果を送り、前記サービスデータに対する前記コンセンサス結果をブロックチェーンに格納する、請求項14に記載のブロックチェーンコンセンサスデバイス。
  16. 格納ユニットをさらに備え、
    前記選択されたコンセンサスノードによって送られた、前記サービスデータに対するコンセンサス結果が受け取られたという判断に応答して、前記格納ユニットが、前記サービスデータに対する前記コンセンサス結果が全体的に共有される必要がないという判断に応答して、前記サービスデータに対する前記コンセンサス結果をブロックチェーンに格納する、請求項14に記載のブロックチェーンコンセンサスデバイス。
  17. ブロックチェーンコンセンサスデバイスであって、
    メモリおよび少なくとも1つのプロセッサを備え、前記メモリが、プログラムを格納し、前記少なくとも1つのプロセッサが、
    コンセンサス手順が行われることになるサービスデータを入手し、前記サービスデータのサービスタイプを決定するステップと、
    コンセンサスサービスを提供する少なくとも1つのコンセンサスノードを、前記サービスタイプに基づいてコンセンサスネットワークから選択するステップと、
    前記選択されたコンセンサスノードが前記サービスデータに対するコンセンサス処理を行うように、前記選択されたコンセンサスノードに前記サービスデータを送るステップと、
    を行うように構成された、ブロックチェーンコンセンサスデバイス。
JP2019536035A 2017-05-31 2018-05-30 ブロックチェーンコンセンサス方法およびデバイス Active JP6692561B2 (ja)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
CN201710405191.3 2017-05-31
CN201710405191.3A CN107450981B (zh) 2017-05-31 2017-05-31 一种区块链共识方法及设备
PCT/CN2018/088947 WO2018219283A1 (zh) 2017-05-31 2018-05-30 一种区块链共识方法及设备

Publications (2)

Publication Number Publication Date
JP2020510894A JP2020510894A (ja) 2020-04-09
JP6692561B2 true JP6692561B2 (ja) 2020-05-13

Family

ID=60486962

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2019536035A Active JP6692561B2 (ja) 2017-05-31 2018-05-30 ブロックチェーンコンセンサス方法およびデバイス

Country Status (10)

Country Link
US (2) US10706023B2 (ja)
EP (1) EP3547242A4 (ja)
JP (1) JP6692561B2 (ja)
KR (2) KR102140414B1 (ja)
CN (1) CN107450981B (ja)
MY (1) MY190617A (ja)
PH (1) PH12019501548A1 (ja)
SG (1) SG10202100167UA (ja)
TW (1) TWI660617B (ja)
WO (1) WO2018219283A1 (ja)

Families Citing this family (92)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111756550B (zh) * 2017-03-28 2023-08-22 创新先进技术有限公司 一种区块链共识方法及装置
CN107450981B (zh) * 2017-05-31 2020-04-24 创新先进技术有限公司 一种区块链共识方法及设备
CN107360248B (zh) * 2017-07-31 2020-08-25 众安信息技术服务有限公司 用于配置局部共识的方法和装置及计算机可读存储介质
US10848549B1 (en) * 2017-11-29 2020-11-24 Syed Muhammad Sajjad Rizvi Leaderless, parallel, and topology-aware protocol for achieving consensus
US11271800B1 (en) * 2017-11-29 2022-03-08 Syed Muhammad Sajjad Rizvi Leaderless, parallel, and topology-aware protocol for achieving consensus with recovery from failure of all nodes in a group
CN108564468A (zh) * 2018-04-04 2018-09-21 上海金丘信息科技股份有限公司 一种基于信任成员的动态权益的共识方法
CN108810077A (zh) * 2018-04-19 2018-11-13 深圳市网心科技有限公司 区块链共识处理方法、电子装置及计算机可读存储介质
CN108599969A (zh) * 2018-05-02 2018-09-28 北京链链信息技术有限公司 一种区块链中数据共享的方法和装置
CN108681809A (zh) * 2018-05-07 2018-10-19 前海梧桐(深圳)数据有限公司 用于计算企业数据价值标注共识度的方法及系统
WO2019213867A1 (zh) * 2018-05-09 2019-11-14 合肥达朴汇联科技有限公司 区块链共识达成方法和装置
CN108665363B (zh) * 2018-05-09 2021-08-03 合肥达朴汇联科技有限公司 一种区块链共识达成装置
CN108647967B (zh) * 2018-05-10 2021-09-14 北京京东尚科信息技术有限公司 选择区块链共识机制的方法、装置以及共识节点
CN108712486B (zh) * 2018-05-11 2021-10-08 北京奇虎科技有限公司 工作量证明方法及装置
CN108717629A (zh) * 2018-05-14 2018-10-30 现在(北京)支付股份有限公司 一种智能支付方法、系统及电子设备
CN108777704A (zh) * 2018-05-16 2018-11-09 横琴密达科技有限责任公司 一种区块链共识方法及系统
CN108881387A (zh) * 2018-05-16 2018-11-23 横琴密达科技有限责任公司 一种区块链共识系统
CN113672938B (zh) * 2018-06-06 2023-08-29 北京八分量信息科技有限公司 一种区块链节点可信状态确定方法
CN108985758B (zh) * 2018-06-07 2020-10-30 深圳海派创客教育学院有限公司 数据处理方法、数据处理系统及终端设备
CN109101835A (zh) * 2018-08-08 2018-12-28 苏州酷外文化传媒有限公司 基于区块链的相亲交友平台的信息安全管理方法及装置
CN110825515A (zh) * 2018-08-13 2020-02-21 上海诺亚投资管理有限公司 基于区块链的去中心化金融数据处理方法及系统
CN109359973A (zh) * 2018-08-24 2019-02-19 阿里巴巴集团控股有限公司 基于区块链的数据存证方法和装置
CN110896389B (zh) * 2018-09-12 2022-03-15 普天信息技术有限公司 一种区块链的共识方法、电子设备和计算机可读存储介质
CN109347917A (zh) * 2018-09-14 2019-02-15 北京沃杰知识产权有限公司 区块链数据共识处理方法、系统、存储介质和电子设备
CN109257427B (zh) * 2018-09-26 2021-04-02 网宿科技股份有限公司 一种基于区块链的业务处理方法及系统
CN111080287B (zh) * 2018-10-18 2023-06-16 华为技术有限公司 一种业务数据的处理方法、相关设备和系统
CN109522728A (zh) * 2018-10-30 2019-03-26 卢淳杰 一种涉密文件管理方法及系统
CN111181797B (zh) * 2018-11-09 2022-05-27 北京天德科技有限公司 一种基于拦截器的区块链共识机制验证方法
SG11201906835VA (en) 2018-12-13 2019-08-27 Alibaba Group Holding Ltd Event-driven blockchain workflow processing
US11601787B2 (en) 2018-12-31 2023-03-07 T-Mobile Usa, Inc. Using a blockchain to determine trustworthiness of messages between vehicles over a telecommunications network
WO2020142325A1 (en) * 2018-12-31 2020-07-09 T-Mobile Usa, Inc. Using a blockchain to determine trustworthiness of messages within a telecommunications network for a smart city
CN109803004B (zh) * 2019-01-03 2021-06-01 深圳壹账通智能科技有限公司 区块链智能合约管理方法与装置、电子设备、存储介质
CN109886817A (zh) * 2019-01-10 2019-06-14 平安科技(深圳)有限公司 基于区块链的医保处理方法、装置、系统和计算机设备
CN111443998B (zh) * 2019-01-17 2023-03-21 杨税令 一种应用于区块链的多层段式共识方法及系统
CN111614707A (zh) * 2019-02-26 2020-09-01 傲为信息技术(江苏)有限公司 一种基于区块链的交易系统及交易方法
US11063747B2 (en) 2019-03-25 2021-07-13 Micron Technology, Inc. Secure monitoring using block chain
US11269858B2 (en) 2019-03-26 2022-03-08 International Business Machines Corporation Information management in a decentralized database including a fast path service
US11398895B2 (en) 2019-03-26 2022-07-26 International Business Machines Corporation Information management in a decentralized database including a fast path service
US11418322B2 (en) * 2019-03-26 2022-08-16 International Business Machines Corporation Information management in a decentralized database including a fast path service
CN110049029B (zh) * 2019-04-04 2021-07-20 矩阵元技术(深圳)有限公司 共识节点确定方法、装置、计算机设备和存储介质
CN110188563B (zh) * 2019-06-02 2021-04-13 四川虹微技术有限公司 一种信任数据更新方法及装置
SG11202004685RA (en) * 2019-06-05 2020-06-29 Alibaba Group Holding Ltd Consensus system and method
CN110225044B (zh) * 2019-06-17 2020-11-27 北京瑞策科技有限公司 在区块链上的验证方法及装置
CN110460634B (zh) * 2019-07-02 2020-10-27 特斯联(北京)科技有限公司 边缘计算共识请求管理方法和系统
CN110365695A (zh) * 2019-07-24 2019-10-22 中国工商银行股份有限公司 可切换共识算法的区块链数据交互方法及装置
CN110474901B (zh) * 2019-08-13 2021-12-07 西安纸贵互联网科技有限公司 公有区块链网络系统
KR102304953B1 (ko) * 2019-08-30 2021-09-27 주식회사 미디움 피어 노드와 그 정보 처리 방법 및 블록체인 플랫폼 시스템
CN110555079B (zh) * 2019-09-04 2023-09-26 腾讯科技(深圳)有限公司 数据处理方法、装置、设备以及存储介质
CN110661867B (zh) * 2019-09-25 2021-07-23 东北大学 一种基于改进工作量证明与权益证明的区块链共识方法
CN112671689B (zh) * 2019-10-15 2022-10-14 北京新唐思创教育科技有限公司 数据上链方法、装置、电子设备及计算机存储介质
CN110855475B (zh) * 2019-10-25 2022-03-11 昆明理工大学 一种基于区块链的共识资源切片方法
CN110908801B (zh) * 2019-11-12 2022-07-12 金蝶软件(中国)有限公司 基于区块链的数据处理方法、装置、计算机设备和存储介质
KR102285882B1 (ko) * 2019-11-19 2021-08-05 한양대학교 산학협력단 가변 정족수 기반의 블록체인 합의 방법, 이를 이용하는 블록체인 노드 및 프로그램
CN111125131B (zh) * 2019-12-16 2023-06-06 武汉大学 一种具备状态缓冲能力的两级共识区块链系统及部署方法
CN111130875B (zh) * 2019-12-20 2022-09-30 度小满科技(北京)有限公司 一种区块链的共识方法、装置、设备及存储介质
KR102396433B1 (ko) 2019-12-23 2022-05-10 서강대학교 산학협력단 에이전트 기반의 블록체인 네트워크 및 상기 네트워크의 전처리 방법
KR102302325B1 (ko) 2020-01-15 2021-09-14 인제대학교 산학협력단 협력적 의료 의사 결정을 위한 프라이버시 보호 블록체인 시스템 및 그의 동작 방법
US12099997B1 (en) 2020-01-31 2024-09-24 Steven Mark Hoffberg Tokenized fungible liabilities
US11184436B2 (en) * 2020-03-02 2021-11-23 International Business Machines Corporation Automated storage selection with blockchain and NLP
CN111353717A (zh) * 2020-03-05 2020-06-30 中国工商银行股份有限公司 区块链共识节点推选系统及方法
CN111368004A (zh) * 2020-03-16 2020-07-03 深圳市望岳安全技术有限公司 一种区块链金融数据处理系统
CN111464633B (zh) * 2020-03-31 2023-03-21 成都质数斯达克科技有限公司 用于区块链的交易信息的共识方法及系统
CN111522563B (zh) * 2020-04-20 2023-09-19 中国工商银行股份有限公司 基于区块链的终端升级保护系统及方法
CN111708833B (zh) * 2020-05-18 2023-06-06 杜晓楠 Dbft共识网络中数据同步的方法、计算机可读存储介质和dbft共识网络
CN111402058B (zh) * 2020-05-29 2021-05-04 支付宝(杭州)信息技术有限公司 一种数据处理方法、装置、设备及介质
CN111738853A (zh) * 2020-06-19 2020-10-02 清华大学 一种基于区块链分布式系统的交易优化方法及装置
KR102253361B1 (ko) * 2020-06-23 2021-05-18 주식회사 아이콘루프 합의 참여 노드를 결정하는 블록체인 네트워크 시스템 및 방법
CN111522822A (zh) 2020-07-03 2020-08-11 支付宝(杭州)信息技术有限公司 一种区块链共识方法、装置及电子设备
CN111541783B (zh) 2020-07-08 2020-10-20 支付宝(杭州)信息技术有限公司 一种基于区块链一体机的交易转发方法及装置
CN111541789A (zh) 2020-07-08 2020-08-14 支付宝(杭州)信息技术有限公司 一种基于区块链一体机的数据同步方法及装置
CN113726875B (zh) * 2020-07-08 2024-06-21 支付宝(杭州)信息技术有限公司 一种基于区块链一体机的交易处理方法及装置
CN111539829B (zh) 2020-07-08 2020-12-29 支付宝(杭州)信息技术有限公司 一种基于区块链一体机的待过滤交易识别方法及装置
CN111541726B (zh) 2020-07-08 2021-05-18 支付宝(杭州)信息技术有限公司 一种基于区块链一体机的重放交易识别方法及装置
CN112202868B (zh) * 2020-09-27 2021-11-30 上海交通大学 基于无线空中计算的区块链共识协议的实现方法
US11514444B2 (en) * 2020-11-03 2022-11-29 Capital One Services, Llc Leveraging blockchain based machine learning modeling for expense categorization
CN114650289B (zh) * 2020-12-02 2023-04-14 王志诚 用于区块链共识的方法及装置
CN112532733B (zh) * 2020-12-02 2024-02-02 东软集团股份有限公司 智能合约调用外部数据的方法、装置、存储介质及电子设备
CN112564902A (zh) * 2020-12-09 2021-03-26 苏州市星际云通区块链科技有限公司 一种区块链上可验证随机函数的共识方法及其系统
CN112738178B (zh) * 2020-12-23 2023-04-07 北京米弘科技有限公司 区块链共识方法和装置
CN112866399B (zh) * 2021-01-28 2023-01-31 深圳大学 一种改进的pbft共识方法、装置、智能终端及存储介质
CN112995317B (zh) * 2021-02-26 2023-04-07 中国工商银行股份有限公司 区块链共识方法及区块链节点
CN113076375B (zh) * 2021-03-29 2023-07-25 湖北央中巨石信息技术有限公司 基于区块链的多方同步抽样共识方法及系统及装置及介质
CN113114761B (zh) * 2021-04-12 2022-09-20 中共陕西省委党校 基于分布式服务的数据共享交换激励系统及方法
GB2606712A (en) * 2021-05-13 2022-11-23 Univ Glasgow Court Information consensus in distributed critical systems
CN113472750B (zh) * 2021-06-03 2023-03-24 中国联合网络通信集团有限公司 区块生成方法、节点和区块生成系统
CN113486118B (zh) * 2021-07-21 2023-09-22 银清科技有限公司 共识节点选取方法及装置
CN113596174B (zh) * 2021-08-06 2022-02-18 环球数科集团有限公司 一种区块链节点部署与选举的装置
FR3129801B1 (fr) * 2021-11-30 2024-06-21 Banks And Acquirers Int Holding procédé de traitement de preuve numérique, système et programme correspondant
CN114296831A (zh) * 2021-12-30 2022-04-08 迅鳐成都科技有限公司 区块链共识算法动态加载方法、装置、系统及存储介质
CN114760198B (zh) * 2022-01-17 2023-03-24 清华大学 一种基于区块链网络的共识方法、装置及系统
KR102439351B1 (ko) * 2022-02-10 2022-09-01 주식회사 스카이플레이 Esg를 위한 비채굴 블록체인 네트워크 시스템 및 그 시스템에 참여하는 서버 노드의 동작 방법
CN114710512B (zh) * 2022-03-30 2023-09-29 蚂蚁区块链科技(上海)有限公司 共识结果的分发方法、节点和区块链系统
CN116128489B (zh) * 2023-04-18 2023-07-04 河北中废通网络技术有限公司 基于区块链的物品回收交易处理方法、装置、终端及介质

Family Cites Families (34)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2002074207A (ja) 2000-09-04 2002-03-15 Fujitsu Ltd サーバー
US9424272B2 (en) * 2005-01-12 2016-08-23 Wandisco, Inc. Distributed file system using consensus nodes
WO2007010455A2 (en) * 2005-07-21 2007-01-25 Koninklijke Philips Electronics N.V. Sensor chip for a biosensor
JP2007074207A (ja) 2005-09-06 2007-03-22 Sony Corp 情報処理装置および方法、並びにプログラム
US8656448B2 (en) * 2006-10-26 2014-02-18 International Business Machines Corporation Providing policy-based application services to an application running on a computing system
US9639589B1 (en) * 2013-12-20 2017-05-02 Amazon Technologies, Inc. Chained replication techniques for large-scale data streams
US11189368B2 (en) * 2014-12-24 2021-11-30 Stephan HEATH Systems, computer media, and methods for using electromagnetic frequency (EMF) identification (ID) devices for monitoring, collection, analysis, use and tracking of personal data, biometric data, medical data, transaction data, electronic payment data, and location data for one or more end user, pet, livestock, dairy cows, cattle or other animals, including use of unmanned surveillance vehicles, satellites or hand-held devices
US11386404B2 (en) * 2015-02-04 2022-07-12 Ripple Luxembourg S.A. Temporary consensus subnetwork in a distributed network for payment processing
SG11201708295XA (en) * 2015-04-06 2017-11-29 Bitmark Inc System and method for decentralized title recordation and authentication
WO2016161496A1 (en) 2015-04-08 2016-10-13 Synaptive Medical (Barbados) Inc. Systems, devices and methods for tissue removal and analysis
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
US10447722B2 (en) * 2015-11-24 2019-10-15 Bank Of America Corporation Proactive intrusion protection system
US10230756B2 (en) * 2015-11-25 2019-03-12 International Business Machines Corporation Resisting replay attacks efficiently in a permissioned and privacy-preserving blockchain network
CN106157142A (zh) * 2016-06-30 2016-11-23 惠众商务顾问(北京)有限公司 一种区块链共识及同步方法、系统和装置
CN106296191A (zh) * 2016-08-13 2017-01-04 深圳市樊溪电子有限公司 一种区块链功耗感知的PoW共识机制
CN106445711B (zh) * 2016-08-28 2019-04-30 杭州云象网络技术有限公司 一种应用于区块链的拜占庭容错共识方法
KR101727525B1 (ko) * 2016-09-05 2017-04-17 주식회사 스케일체인 블록체인 기반 분산 저장 방법 및 이를 이용한 장치
US10360191B2 (en) * 2016-10-07 2019-07-23 International Business Machines Corporation Establishing overlay trust consensus for blockchain trust validation system
CN106656974B (zh) * 2016-10-17 2019-07-16 江苏通付盾科技有限公司 区块链的分组共识方法及系统
CN106534085B (zh) * 2016-10-25 2019-09-06 杭州云象网络技术有限公司 一种基于区块链技术的隐私保护方法
US10158527B2 (en) * 2016-10-28 2018-12-18 International Business Machines Corporation Changing an existing blockchain trust configuration
GB2557329A (en) * 2016-12-07 2018-06-20 Virtuosys Ltd Router node, network and method to allow service discovery in a network
CN106682907A (zh) * 2016-12-10 2017-05-17 江苏恒为信息科技有限公司 区块链数据对比及共识方法
CN106603698A (zh) * 2016-12-28 2017-04-26 北京果仁宝科技有限公司 基于dpos的区块链共识方法和节点
TWM542178U (zh) * 2017-02-15 2017-05-21 Quick Retrieval Corp 隱藏及還原區塊鏈交易中交易方資訊之裝置
US10356102B2 (en) * 2017-02-24 2019-07-16 Verizon Patent And Licensing Inc. Permissions using blockchain
US10375105B2 (en) * 2017-03-03 2019-08-06 International Business Machines Corporation Blockchain web browser interface
CN110945549A (zh) * 2017-03-15 2020-03-31 努Id公司 用于对用于跨机构数字认证的用户拥有的凭证的通用存储和访问的方法和系统
CN107395557B (zh) * 2017-03-28 2020-05-15 创新先进技术有限公司 一种业务请求的处理方法及装置
WO2018176406A1 (zh) * 2017-03-31 2018-10-04 北京大学深圳研究生院 一种基于联盟链的顶级域名管理方法及系统
US10176308B2 (en) * 2017-04-28 2019-01-08 Accenture Global Solutions Limited Entitlement management system
CN107450981B (zh) * 2017-05-31 2020-04-24 创新先进技术有限公司 一种区块链共识方法及设备
US11132660B2 (en) * 2017-12-12 2021-09-28 Mastercard International Incorporated Systems and methods for distributed peer to peer analytics
CN108717460A (zh) * 2018-05-25 2018-10-30 济南浪潮高新科技投资发展有限公司 一种在区块链中达成共识的方法及装置

Also Published As

Publication number Publication date
SG10202100167UA (en) 2021-02-25
TW201904251A (zh) 2019-01-16
WO2018219283A1 (zh) 2018-12-06
KR20190088530A (ko) 2019-07-26
JP2020510894A (ja) 2020-04-09
CN107450981B (zh) 2020-04-24
EP3547242A1 (en) 2019-10-02
US11126596B2 (en) 2021-09-21
KR102340223B1 (ko) 2021-12-16
KR102140414B1 (ko) 2020-08-03
PH12019501548A1 (en) 2020-02-24
US10706023B2 (en) 2020-07-07
EP3547242A4 (en) 2020-01-08
US20190332586A1 (en) 2019-10-31
KR20200086381A (ko) 2020-07-16
TWI660617B (zh) 2019-05-21
US20200334214A1 (en) 2020-10-22
MY190617A (en) 2022-04-27
CN107450981A (zh) 2017-12-08

Similar Documents

Publication Publication Date Title
JP6692561B2 (ja) ブロックチェーンコンセンサス方法およびデバイス
JP6876806B2 (ja) ブロックチェーンコンセンサス形成の方法およびデバイス
EP3547170B1 (en) Blockchain-based consensus method and device
RU2728820C1 (ru) Способ и устройство обработки данных на основе блокчейна
JP6804668B2 (ja) ブロックデータ検証方法および装置
JP6716149B2 (ja) ブロックチェーンベースのデータ処理方法および装置
EP3565219B1 (en) Service execution method and device
KR20190118630A (ko) 합의 검증을 위한 방법 및 장치
JP2020508594A (ja) サービス処理およびコンセンサスの方法およびデバイス
CA3046838A1 (en) Method and device for processing service request
CN109345081B (zh) 一种数据采集方法、装置及电子设备
CN116894670A (zh) 数据处理方法、装置及设备

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20190827

A871 Explanation of circumstances concerning accelerated examination

Free format text: JAPANESE INTERMEDIATE CODE: A871

Effective date: 20190827

A975 Report on accelerated examination

Free format text: JAPANESE INTERMEDIATE CODE: A971005

Effective date: 20191223

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

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20200406

R150 Certificate of patent or registration of utility model

Ref document number: 6692561

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

S111 Request for change of ownership or part of ownership

Free format text: JAPANESE INTERMEDIATE CODE: R313113

R350 Written notification of registration of transfer

Free format text: JAPANESE INTERMEDIATE CODE: R350

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250