US20200150999A1 - Method and apparatus for writing service data into block chain and method for determining service subset - Google Patents

Method and apparatus for writing service data into block chain and method for determining service subset Download PDF

Info

Publication number
US20200150999A1
US20200150999A1 US16/745,519 US202016745519A US2020150999A1 US 20200150999 A1 US20200150999 A1 US 20200150999A1 US 202016745519 A US202016745519 A US 202016745519A US 2020150999 A1 US2020150999 A1 US 2020150999A1
Authority
US
United States
Prior art keywords
transaction
data
level
subset
subsets
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.)
Granted
Application number
US16/745,519
Other versions
US10664305B1 (en
Inventor
Honglin Qiu
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.)
Advanced New Technologies Co 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
Priority to US16/745,519 priority Critical patent/US10664305B1/en
Publication of US20200150999A1 publication Critical patent/US20200150999A1/en
Application granted granted Critical
Publication of US10664305B1 publication Critical patent/US10664305B1/en
Assigned to ADVANTAGEOUS NEW TECHNOLOGIES CO., LTD. reassignment ADVANTAGEOUS NEW TECHNOLOGIES CO., LTD. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: ALIBABA GROUP HOLDING LIMITED
Assigned to Advanced New Technologies Co., Ltd. reassignment Advanced New Technologies Co., Ltd. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: ADVANTAGEOUS NEW TECHNOLOGIES CO., LTD.
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • 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/466Transaction processing
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/24Querying
    • G06F16/245Query processing
    • G06F16/2455Query execution
    • G06F16/24568Data stream processing; Continuous queries
    • 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
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F17/00Digital computing or data processing equipment or methods, specially adapted for specific functions
    • 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/22Microcontrol or microprogram arrangements
    • G06F9/28Enhancement of operational speed, e.g. by using several microcontrol devices operating in parallel
    • 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/48Program initiating; Program switching, e.g. by interrupt
    • G06F9/4806Task transfer initiation or dispatching
    • G06F9/4812Task transfer initiation or dispatching by interrupt, e.g. masked
    • G06F9/4831Task transfer initiation or dispatching by interrupt, e.g. masked with variable priority
    • G06F9/4837Task transfer initiation or dispatching by interrupt, e.g. masked with variable priority time dependent
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/06Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols the encryption apparatus using shift registers or memories for block-wise or stream coding, e.g. DES systems or RC4; Hash functions; Pseudorandom sequence generators
    • H04L9/0618Block ciphers, i.e. encrypting groups of characters of a plain text message using fixed encryption transformation
    • H04L9/0637Modes of operation, e.g. cipher block chaining [CBC], electronic codebook [ECB] or Galois/counter mode [GCM]

Definitions

  • the present application relates to the field of computer technologies, and in particular, to a method and apparatus for writing transaction data into a blockchain and a method for determining a transaction subset of blockchain transaction data.
  • blockchain technologies also referred to as distributed ledger network
  • smart contracts also referred to as distributed ledger network
  • social communications document storage
  • existence proof also referred to as identity verification
  • equity crowd-funding due to advantages such as decentralization, openness and transparency, immutability, and trustworthiness.
  • the blockchain technologies are a type of decentralized and distributed database technologies. Each piece of data in a blockchain will be broadcast to all blockchain nodes of the entire network, and each node keeps the full amount of data that is consistent with each other.
  • the blockchain technologies require that all nodes keep the same state, including the database state and the like. To ensure the consistency in the database state, it is required that blockchain transactions are in an ordered sequence that is consistent for all nodes, and all nodes execute transactions in such sequence to complete transaction verification, implementation, inclusion of data in the chain, etc.
  • a timestamp is created when each transaction is received, the transactions are written into a transaction pool, and the transactions are sorted according to the timestamps; during mining, the transactions are executed according to the sequence of transaction timestamps, and the account information after the execution of each transaction is updated into a database, thereby achieving the update of the database account state.
  • Embodiments of the present specification provide a method and apparatus for writing transaction data into a blockchain, which may reduce the cost required for improving the execution efficiency of data processing and improve expandability.
  • the embodiments of the present specification further provide a method for determining a transaction subset of blockchain transaction data, which may reasonably allocate transaction data, thereby reducing the cost required for improving the execution efficiency of data processing and improving expandability.
  • a method for adding transaction data into a blockchain comprises: obtaining transaction data to be added into the blockchain, assigning the transaction data into transaction subsets, and executing the transaction subsets in parallel, and storing results of the execution into the blockchain.
  • Pieces of the transaction data having at least one of: a same transaction type or an overlapping scope of data change are assigned into a same transaction subset, and pieces of the transaction data with different transaction types and with no overlapping scope of data change are assigned into different transaction subsets.
  • the executing the transaction subsets in parallel comprises: executing the transaction data in the different transaction subsets in parallel using multithreading or a machine cluster.
  • each piece of transaction data corresponds to a timestamp; and the executing the transaction data in parallel comprises: executing the pieces of transaction data comprised in the same transaction subset in series according to a temporal order corresponding to the timestamps.
  • the assigning the transaction data into transaction subsets comprises: determining one or more level I transaction subsets for the transaction data according to the transaction data's transaction type.
  • the determining one or more level I transaction subsets for the transaction data according to the transaction data's transaction type comprises: assigning pieces of the transaction data with the same transaction type in a same level I transaction subset; and assigning pieces of the transaction data with different transaction types into different level I transaction subsets.
  • the assigning the transaction data into transaction subsets further comprises: determining one or more level II transaction subsets for each of the one or more level I transaction subsets according to the transaction data's scope of data change, each of the one or more level II transaction subsets being a subset under one of the one or more level I transaction subsets.
  • Executing the transaction subsets in parallel comprises: executing a plurality of level II transaction subsets corresponding to the one or more level I transaction subsets in parallel.
  • the determining one or more level II transaction subsets for each of the one or more level I transaction subsets according to the transaction data's scope of data change comprises: assigning pieces of transaction data in each of the one or more level I subsets with the overlapping scope of data change in a same level II transaction subset; and assigning pieces of the transaction data in the each level I subset with no overlapping scope of data change into different level II transaction subsets.
  • the determining one or more level II transaction subsets for each of the one or more level I transaction subsets according to the transaction data's scope of data change comprises: traversing a scope of data change of each piece of transaction data in a first level I transaction subset; in response to that a scope of data change of a second piece of transaction data overlaps with a scope of data change of a first level II transaction subset, adding the second piece of transaction data into the first level II transaction subset; and in response to that the scope of data change of the second piece of transaction data does not overlap with the scope of data change of the first level II transaction subset, creating a second level II transaction subset and adding the second piece of transaction data into the second level II transaction sub set.
  • the assigning the transaction data into transaction subsets comprises: determining one or more level I transaction subsets for the transaction data according to the transaction data's scope of data change.
  • the determining one or more level I transaction subsets for the transaction data according to the transaction data's scope of data change comprises: assigning pieces of the transaction data with the overlapping scope of data change in a same level I transaction subset; and assigning pieces of the transaction data with no overlapping scope of data change into different level I transaction subsets.
  • the assigning the transaction data into transaction subsets further comprises: determining one or more level II transaction subsets for each of the one or more level I transaction subsets according to the transaction data's transaction type, each of the one or more level II transaction subsets being a subset under one of the one or more level I transaction subsets.
  • Executing the transaction subsets in parallel comprises: executing a plurality of level II transaction subsets corresponding to the one or more level I transaction subsets in parallel.
  • the determining one or more level II transaction subsets for each of the one or more level I transaction subsets according to the transaction data's transaction type comprises: assigning pieces of transaction data in each of the one or more level I subsets with the same transaction type in a same level II transaction subset; and assigning pieces of the transaction data in the each level I subset with different transaction types into different level II transaction subsets.
  • the determining one or more level II transaction subsets for each of the one or more level I transaction subsets according to the transaction data's transaction type comprises: traversing a transaction type of each piece of transaction data in a first level I transaction subset; in response to that a transaction type of a second piece of transaction data is the same as a transaction type of one or more pieces of transaction data of a first level II transaction subset, adding the second piece of transaction data into the first level II transaction subset; and in response to that the transaction type of the second piece of transaction data is different from the transaction type of all pieces of transaction data of the first level II transaction subset, creating a second level II transaction subset and adding the second piece of transaction data into the second level II transaction subset.
  • a system for adding transaction data into a blockchain comprising one or more processors and one or more non-transitory computer-readable memories coupled to the one or more processors and configured with instructions executable by the one or more processors to cause the system to perform operations comprising: obtaining transaction data to be added into the blockchain, assigning the transaction data into transaction subsets, and executing the transaction subsets in parallel, and storing results of the execution into the blockchain.
  • Pieces of the transaction data having at least one of: a same transaction type or an overlapping scope of data change are assigned into a same transaction subset, and pieces of the transaction data with different transaction types and with no overlapping scope of data change are assigned into different transaction subsets.
  • a non-transitory computer-readable storage medium configured with instructions executable by one or more processors to cause the one or more processors to perform operations comprising: obtaining transaction data to be added into the blockchain, assigning the transaction data into transaction subsets, and executing the transaction subsets in parallel, and storing results of the execution into the blockchain.
  • Pieces of the transaction data having at least one of: a same transaction type or an overlapping scope of data change are assigned into a same transaction subset, and pieces of the transaction data with different transaction types and with no overlapping scope of data change are assigned into different transaction subsets.
  • the method for writing transaction data into a blockchain comprises: obtaining a plurality of pieces of transaction data to be written into the blockchain; assigning the transaction data into transaction subsets based on at least one of: a transaction type or a scope of data change of the transaction data, wherein: assigning the transaction data into the transaction subsets comprises: assigning multiple pieces of transaction data with a transaction dependency in a same transaction subset and assigning multiple pieces of transaction data without the transaction dependency into different transaction subsets; and executing the transaction subsets in parallel, and writing results of the execution into the blockchain.
  • assigning the transaction data into transaction subsets based on at least one of: a transaction type or a scope of data change of the transaction data comprises: determining a transaction subset to which a piece of transaction data belongs according to a data attribute of the piece of transaction data, wherein the data attribute has a corresponding relationship with at least one of: a transaction type or a scope of data change of the piece of transaction data, and the data attribute indicates whether the transaction dependency exists between the piece of transaction data and other pieces of transaction data.
  • the executing the transaction subsets in parallel comprises: executing the transaction data in the different transaction subsets in parallel using multithreading or a machine cluster.
  • each piece of transaction data corresponds to a timestamp
  • executing the transaction data in the transaction subsets in parallel comprises: executing pieces of transaction data comprised in a same transaction subset in series according to a temporal order corresponding to the timestamps.
  • assigning the transaction data into transaction subsets based on at least one of: a transaction type or a scope of data change of the transaction data comprises: according to the transaction types of pieces of transaction data, putting pieces of transaction data of a same transaction type into a same transaction subset, and dividing pieces of transaction data of different transaction types into the different transaction subsets.
  • assigning the transaction data into transaction subsets based on at least one of: a transaction type or a scope of data change of the transaction data comprises: according to a scope of data change in each piece of transaction data, putting pieces of transaction data having overlapping scopes of data change into a same transaction subset, and dividing pieces of transaction data having scopes of data change that do not overlap into the different transaction subsets.
  • the scope of data change in each piece of transaction data may include a set of objects involved in the data change in the each piece of transaction data.
  • putting pieces of transaction data having overlapping scopes of data change into a same transaction subset, and dividing pieces of transaction data having scopes of data change that do not overlap into the different transaction subsets comprises: traversing the scope of date change of each piece of transaction data; in response to that the scope of data change of a first piece of transaction data overlaps with a scope of data change of a first transaction subset, adding the first piece of transaction data into the first transaction subset; and in response to that the scope of data change of the first piece of transaction data does not overlap with the scope of data change of the first transaction subset, creating a second transaction subset and adding the first piece of transaction data into the second transaction subset.
  • the first pieces of transaction data may be any of the pieces of transaction data
  • the first transaction subset may be any of the transaction subsets
  • the second transaction subset may be different from the first transaction subset.
  • the scope of data change of the first transaction subset is a union of scopes of data change of pieces of transaction data comprised in the transaction subset.
  • each piece of transaction data corresponds to a timestamp
  • traversing the scope of data change of each piece of transaction data comprises: traversing in a temporal order corresponding to the timestamps of the transaction data.
  • assigning the transaction data into transaction subsets based on at least one of: a transaction type or a scope of data change of the transaction data comprises: determining a level I subset to which pieces of transaction data belong according to transaction types of the pieces of transaction data; and determining level II subsets to which the pieces of transaction data in the level I subset belong according to a scope of data change of each piece of transaction data, and using the level II subsets as the transaction subsets, wherein a level II subset is a subset of the level I subset.
  • determining a level I subset to which pieces of transaction data belong comprises: according to transaction types of the pieces of transaction data, putting pieces of transaction data of a same transaction type into a same level I subset, and dividing pieces of transaction data of different transaction types into different level I subsets.
  • determining level II subsets to which the pieces of transaction data in the level I subset belong comprises: according to the scope of data change of each piece of transaction data in the level I subset, putting pieces of transaction data having overlapping scopes of data change into a same level II subset, and dividing pieces of transaction data having scopes of data change that do not overlap into different level II subsets.
  • putting pieces of transaction data having overlapping scopes of data change into a same level II subset, and dividing pieces of transaction data having scopes of data change that do not overlap into different level II subsets comprises: traversing the scope of data change of each piece of transaction data in a first level I subset; in response to that the scope of data change of a second piece of transaction data overlaps with a scope of data change of a first level II subset, adding the second piece of transaction data into the first level II subset; and in response to that the scope of data change of the second piece of transaction data does not overlap with the scope of data change of the first level II subset, creating a second level II subset and adding the second piece of transaction data into the second level II subset; wherein the first level I subset is any of the level I subsets, the second piece of transaction data is any of the pieces of the transaction data in the first level I subset, the first level II subset is any of the
  • the plurality of pieces of transaction data to be executed are obtained based on at least one of: a preset amount or a preset period of time.
  • another method for writing transaction data into a blockchain comprises: obtaining a plurality of pieces of transaction data to be written into a blockchain; determining first transaction data without a transaction dependency relationship according to a scope of data change of the transaction data, wherein there is no transaction dependency relationship among the first transaction data; and executing the first transaction data in parallel, and writing an execution result into the blockchain.
  • the determining first transaction data without a transaction dependency relationship according to the scope of data change of the transaction data comprises: according to scope of data change of the transaction data, determining transaction data with a scope of data change not overlapping a scope of data change of any other piece of transaction data as the first transaction data having no transaction dependency relationship.
  • an apparatus for writing transaction data into a blockchain comprises: an obtaining module configured to obtain a plurality of pieces of transaction data to be written into a blockchain; a transaction subset determining module configured to determine a transaction subset to which the transaction data belongs according to at least one of: a transaction type or a scope of data change of the transaction data, wherein there is no transaction dependency relationship among transaction data belonging to different transaction subsets; and a data executing module configured to execute the transaction subsets in parallel, and write an execution result into the blockchain.
  • a method for determining a transaction subset of blockchain transaction data comprises: after a plurality of pieces of transaction data to be written into a blockchain are obtained, determining transaction subsets to which the transaction data belongs according to at least one of: a transaction type or a scope of data change of the transaction data, for executing the transaction subsets in parallel and writing an execution result into the blockchain, wherein there is no transaction dependency relationship among transaction data belonging to different transaction subsets.
  • the determining transaction subsets to which the transaction data belongs according to at least one of: a transaction type or a scope of data change of the transaction data comprises: determining the transaction subsets to which the transaction data belongs according to data attributes of the transaction data, wherein a data attribute has a corresponding relationship with at least one of: a transaction type or a scope of data change of the transaction data, and the data attribute represents a transaction dependency relationship of the transaction data.
  • the determining transaction subsets to which the transaction data belongs according to transaction types of the transaction data comprises: according to the transaction types of the transaction data, putting transaction data of a same transaction type into the same transaction subset, and dividing transaction data of different transaction types into the different transaction subsets; or the determining transaction subsets to which the transaction data belongs according to scopes of data change of the transaction data comprises: according to the scopes of data change of the transaction data, putting transaction data having overlapping scopes of data change into the same transaction subset, and dividing transaction data having scopes of data change that do not overlap into the different transaction subsets.
  • the determining transaction subsets to which the transaction data belongs according to transaction types and scopes of data change of the transaction data comprises: determining a level I subset to which the transaction data belongs according to the transaction types of the transaction data; and determining a level II subset to which the transaction data belongs according to the scopes of data change of the transaction data in the level I subset, and using the level II subset as one of the transaction subsets, wherein the level II subset is a subset of the level I subset.
  • a system for writing transaction data into a blockchain comprises one or more processors and one or more non-transitory computer-readable memories coupled to the one or more processors and configured with instructions executable by the one or more processors to cause the system to perform operations comprising: obtaining a plurality of pieces of transaction data to be written into the blockchain; assigning the transaction data into transaction subsets based on at least one of: a transaction type or a scope of data change of the transaction data, wherein: assigning the transaction data into the transaction subsets comprises: assigning multiple pieces of transaction data with a transaction dependency in a same transaction subset and assigning multiple pieces of transaction data without the transaction dependency into different transaction subsets; and executing the transaction subsets in parallel, and writing results of the execution into the blockchain.
  • a non-transitory computer-readable storage medium is configured with instructions executable by one or more processors to cause the one or more processors to perform operations comprising: obtaining a plurality of pieces of transaction data to be written into the blockchain; assigning the transaction data into transaction subsets based on at least one of: a transaction type or a scope of data change of the transaction data, wherein: assigning the transaction data into the transaction subsets comprises: assigning multiple pieces of transaction data with a transaction dependency in a same transaction subset and assigning multiple pieces of transaction data without the transaction dependency into different transaction subsets; and executing the transaction subsets in parallel, and writing results of the execution into the blockchain.
  • the above-described at least one technical solution employed by the embodiments of the present specification can achieve the following advantageous effects.
  • whether there is a transaction dependency relationship among the transaction data may be determined according to transaction types or scopes of data change of the transaction data, and then the transaction data may be divided into different transaction subsets according to the situation of transaction dependency among the transaction data. Since there is no transaction dependency relationship among transaction data belonging to different transaction subsets, different transaction subsets may be executed in parallel without affecting the consistency in the database state.
  • executing transaction data without a transaction dependency relationship in parallel not only ensures the consistency in the database state, but also improves the execution efficiency of data processing without relying on improvements of the performance of individual machines. Therefore, the performance requirements for individual machines may be lowered, which favors cost saving and leads to a better expandability.
  • FIG. 1 is a flow chart of a method for writing transaction data into a blockchain according to some embodiments of the present specification
  • FIG. 2 is a flow chart of a second method for writing transaction data into a blockchain according to some embodiments of the present specification
  • FIG. 3 is a flow chart of a third method for writing transaction data into a blockchain according to some embodiments of the present specification
  • FIG. 4 is a schematic diagram of an exemplary specification scenario of the method for writing transaction data into a blockchain according to some embodiments of the present specification
  • FIG. 5 is a schematic structural diagram of an apparatus for writing transaction data into a blockchain according to some embodiments of the present specification.
  • FIG. 1 illustrates a method for writing transaction data into a blockchain according to some embodiments of the present specification, comprising S 101 to S 103 .
  • S 101 includes obtaining transaction data to be added into the blockchain;
  • S 102 includes assigning the transaction data into transaction subsets, wherein pieces of the transaction data having at least one of: a same transaction type or an overlapping scope of data change are assigned into a same transaction subset, and pieces of the transaction data with different transaction types and with no overlapping scope of data change are assigned into different transaction subsets; and
  • S 103 includes executing the transaction subsets in parallel, and storing results of the execution into the blockchain.
  • step S 101 after the step S 101 is executed to obtain transaction data to be written into a blockchain, whether there is a transaction dependency relationship among the transaction data may be determined according to transaction types or scopes of data change of the transaction data, and then the transaction data may be divided into different transaction subsets according to the situation of transaction dependency among the transaction data. Since there is no transaction dependency relationship among transaction data belonging to different transaction subsets, different transaction subsets may be executed in parallel without affecting the consistency in the database state. According to the solutions provided by the embodiments of the present specification, the manner in which transaction data in a transaction subset is executed in parallel may improve the execution efficiency of data processing without relying on improvements of the performance of individual machines. Therefore, the performance requirements for individual machines may be lowered, which favors cost saving and leads to a better expandability.
  • a transaction set to be executed comprising the transaction data to be executed may be formed, and the transaction set may be determined by a preset data processing amount and/or a preset transaction data time.
  • transaction data to be executed in the same batch may be determined by presetting a data processing amount, and an exemplary value of the preset data processing amount may be determined according to an amount of data allowed to be written into a blockchain. For example, an amount of transaction data allowed to be written into a blockchain is 1,000, and then the preset data processing amount may be set to be less than 1,000, e.g., 800, so as to meet the requirement.
  • every time when a server receives 800 pieces of transaction data the server may form a transaction set to be executed for subsequent processing.
  • transaction data to be executed in the same batch may also be determined by presetting a transaction data time. For example, the preset transaction data time is set to be 1 s, and then the transaction data to be executed in the same batch is transaction data generated in parallel within 1 s.
  • the transaction subsets may be executed in parallel using multithreading or a machine cluster, which not only meets the requirement for consistency in the database state, but also achieves the goal of improving the data execution efficiency.
  • the data execution efficiency may be improved without relying on improvements of the performance of individual machines. Therefore, the performance requirements for individual machines may be lowered, which favors cost saving and leads to a better expandability by using the manner of machine cluster.
  • transaction subsets comprising the transaction data are executed, there is no transaction dependency relationship among the transaction data divided into different transaction subsets, while there is a transaction dependency relationship among the transaction data put into the same transaction subset. Therefore, different transaction subsets may be executed in parallel to improve the data execution efficiency, while transaction data in the same transaction subset may be executed in series to ensure the consistency in the database state.
  • there is a corresponding relationship between the transaction data and timestamps and then when a transaction subset is executed, transaction data comprised in the transaction subset is executed in series according to a temporal order corresponding to the timestamps. Furthermore, the execution of each piece of transaction data is performed in an order of transaction verification, transaction implementation, and inclusion of data in the chain to finally write an execution result into the blockchain.
  • the transaction subsets may be determined in a variety of different manners, as long as transaction data with a transaction dependency relationship is separated from transaction data without a transaction dependency relationship.
  • a transaction subset to which the transaction data belongs may be determined according to a data attribute of the transaction data, wherein the data attribute has a corresponding relationship with a transaction type and/or a scope of data change of the transaction data, and the data attribute indicates whether there is a transaction dependency relationship of the transaction data. Then, transaction data with a transaction dependency relationship may be put into the same transaction subset, and transaction data without a transaction dependency relationship may be divided into different transaction subsets according to the data attribute extracted from the transaction data, thereby achieving parallel execution of different transaction subsets.
  • the data attribute may be embodied in the form of an identifier field comprised in the transaction data or may be embodied in the form of characteristic information carried by the transaction data. Whether a designated identifier field is comprised may be determined, or characteristic information of the transaction data may be extracted and then whether the characteristic information meets a preset condition may be determined, thereby determining a transaction dependency relationship of the transaction data according to the data attribute.
  • the transaction dependency relationship among the transaction data set forth in the embodiments of the present specification may be embodied by transaction association that is present when different transaction data is executed, for example, the association in aspects such as temporal order, transaction object, or execution result. For example, if an execution of transaction data with a later execution time is dependent on the result of execution of transaction data with an earlier execution time, or executions of different transaction data impact the same data state, then it is regarded that these two pieces of transaction data have a transaction dependency relationship. Conversely, it may be regarded that these two pieces of transaction data do not have a transaction dependency relationship.
  • a transaction subset may be determined according to transaction types of the transaction data.
  • transaction data of the same transaction type is put into the same transaction subset, and transaction data of different transaction types are divided into different transaction subsets. Since there is no transaction dependency relationship among the transaction data of different transaction types, the result of data execution will not be affected regardless of an order in which transaction data of different transaction types is executed. Determining whether transaction data belongs to the same transaction subset according to transaction types of the transaction data can ensure that there is no transaction dependency relationship among the transaction data belonging to different transaction subsets, thereby enabling parallel processing of transaction data in different transaction subsets and favoring the improvement of the execution efficiency of data processing.
  • a contract-type transaction (which may also be referred to as a transaction)
  • a transfer-type transaction (which may also be referred to as a transaction)
  • the account balance data of both parties of the transfer is changed.
  • the order in which these two types of transactions are executed does not have an impact on the execution result. Therefore, dividing two different types of transactions into different transaction subsets can ensure that transaction data belonging to different transaction subsets do not have a transaction dependency relationship, and thus the transaction subsets can be processed in parallel without affecting the consistency in the database state.
  • the scope of data change in the present specification refers to a set of one or more objects for execution of transaction data.
  • transaction data having overlapping scopes of data change may be put into the same transaction subset, and transaction data having scopes of data change that do not overlap may be divided into different transaction subsets.
  • a transaction subset is determined according to scopes of data change of the transaction data, different pieces of transaction data may be executed in an order that these pieces of transaction data are generated, if the data ranges affected by the execution of these pieces of transaction data overlap, otherwise the result of data execution will be affected.
  • determining a transaction subset according to scopes of data change of the transaction data may meet the need for parallel processing of different transaction subsets, thereby favoring the improvement of the execution efficiency of data processing.
  • the putting transaction data having overlapping scopes of data change into the same transaction subset, and dividing transaction data having scopes of data change that do not overlap into the different transaction subsets may comprise: traversing scopes of data change of the transaction data; if the scope of data change of a first transaction data overlaps with the scope of data change of a first transaction subset, adding the first transaction data into the first transaction subset; and if the scope of data change of the first transaction data does not overlap with the scope of data change of the first transaction subset, creating a second transaction subset that comprises the first transaction data; wherein the first transaction data is any piece of transaction data, the first transaction subset is any transaction subset in the transaction subsets, and the second transaction subset is different from the first transaction sub set.
  • step S 1021 determining if all pieces of transaction data in the transaction set have been traversed, the process ends if yes, otherwise the process proceeds to execute step S 1022 ;
  • the transaction data TX may be extracted and generated from transaction data that has not been put into a transaction subset; however, if the extracted transaction data TX has already been put into a transaction subset, the transaction data TX will be put into the same transaction subset after subsequent steps are executed without affecting the achievement of the technical object;
  • step S 1025 if a determination result in the step S 1024 is yes, adding the transaction data TX into the transaction subset TXB;
  • step S 1026 if the determination result in the step S 1024 is no, creating a new transaction subset TXN, and adding the transaction data TX into the transaction subset TXN.
  • the scope of data change of a transaction subset is to be recalculated when transaction data comprised in the transaction subset changes, and a union of scopes of data change of transaction data comprised in the transaction subset may be used as the scope of data change of the transaction subset.
  • the execution object of a contract-type transaction is a contract ID
  • contract data corresponding to the contract ID will be changed after the execution.
  • the contract ID may be, for example, the scope of data change of the transaction data. If two pieces of transaction data are executed for the same contract ID, it may be deemed that the scopes of data change of these two pieces of transaction data overlap, and then these two pieces of transaction data may be included in the same transaction subset and executed in an order determined according to timestamps corresponding to the transaction data. If two pieces of transaction data are executed for different contract IDs, it may be deemed that the scopes of data change of these two pieces of transaction data do not overlap, and contract data corresponding to the different contract IDs will be changed when these two pieces of transaction data are executed. Therefore, the order of execution does not have impact on the execution result. These two pieces of transaction data may be included in different transaction subsets and executed in parallel.
  • the execution objects of a transfer-type transaction are accounts of both parties of the transfer, and after the transfer-type transaction is executed, the account balance data of both parties of the transfer will be changed. Therefore, accounts of both parties of the transfer may be, for example, the scope of data change of the transfer-type transaction data.
  • transaction data 1 transferring from account A to account B
  • transaction data 2 transferring from the account B to the account A
  • the scope of data change of the transaction data 2 may be expressed as (B, A)
  • transaction data 3 transferring from account C to account E
  • transaction data 4 transferring from account F to account X
  • transaction data 4 may be expressed as (F, X)
  • transaction data 5 transferring from the account X to the account E, then the scope of data change of the transaction data 5 may be expressed as (X, E).
  • the scopes of data change of the transaction data 1 and the transaction data 2 overlap, the scopes of data change of the transaction data 3 and the transaction data 5 overlap, and the scopes of data change of the transaction data 4 and the transaction data 5 overlap. Therefore, the transaction set comprising the transaction data 1 to the transaction data 5 may be divided into the following transaction subsets: transaction subset 1 : comprising the transaction data 1 and the transaction data 2 , and the scope of data change being (A, B); and transaction subset 2 : comprising the transaction data 3 , the transaction data 4 , and the transaction data 5 , and the scope of data change being (C, E, F, X).
  • the scopes of data change of the transaction subset 1 and the transaction subset 2 do not overlap, and a parallel execution of the transaction subset 1 and the transaction subset 2 will not affect an execution result. Therefore, the transaction subset 1 and the transaction subset 2 may be executed in parallel to improve the execution efficiency.
  • the scopes of data change of the transaction data 1 and the transaction data 2 overlap (which are even completely identical), and the execution of these two pieces of transaction data may depend on transaction data prior to the execution of these two pieces of transaction data. Therefore, an order of execution may be determined according to timestamps corresponding to these two pieces of transaction data, and these two pieces of transaction data will be executed in series in the temporal order. It is the same for the transaction subset 2 .
  • the transaction data 4 of transferring from the account F to the account X is executed first, and then the transaction data 5 of transferring from the account X to the account E is executed.
  • This execution order may be neither parallel nor reversed, since it is possible that the fund required by the transfer from the account X to the account E when the transaction data 5 is executed depends on the execution of the transaction data 4 of transferring from the account F to the account X.
  • the traversing scopes of data change of the transaction data in the transaction set may be implemented in the manner of S 1022 : obtaining any piece of transaction data as shown in the example in FIG. 2 .
  • the traversing may be implemented according to the temporal order of generation of the transaction data in the transaction set according to the timestamps of the transaction data.
  • transaction type and scope of data change may be combined for determining a transaction subset in phases and levels.
  • division may be performed first according to scopes of data change, based on which a second division may be performed according to transaction types, and vice versa.
  • the subset assignment may be performed according to transaction type at a primary level, and then according to scope of data change at a secondary level.
  • the assigning the transaction data into transaction subsets comprises: determining one or more level I transaction subsets for the transaction data according to the transaction data's transaction type.
  • the determining one or more level I transaction subsets for the transaction data according to the transaction data's transaction type comprises: assigning pieces of the transaction data with the same transaction type in a same level I transaction subset; and assigning pieces of the transaction data with different transaction types into different level I transaction subsets.
  • the assigning the transaction data into transaction subsets further comprises: determining one or more level II transaction subsets for each of the one or more level I transaction subsets according to the transaction data's scope of data change, each of the one or more level II transaction subsets being a subset under one of the one or more level I transaction subsets.
  • Executing the transaction subsets in parallel comprises: executing a plurality of level II transaction subsets corresponding to the one or more level I transaction subsets in parallel.
  • the transaction data may be assigned into level I transaction subsets A and B, of which transaction data in subset A is assigned into two level II transaction subset A 1 and A 2 , and transaction data in subset B is assigned into one level II transaction subset B 1 (here level I transaction subset B is the same as the level II transaction subset B 1 ). Then, level II transaction subsets A 1 , A 2 , and B 1 can be executed in parallel.
  • the determining one or more level II transaction subsets for each of the one or more level I transaction subsets according to the transaction data's scope of data change comprises: assigning pieces of transaction data in each of the one or more level I subsets with the overlapping scope of data change in a same level II transaction subset; and assigning pieces of the transaction data in the each level I subset with no overlapping scope of data change into different level II transaction subsets.
  • the determining one or more level II transaction subsets for each of the one or more level I transaction subsets according to the transaction data's scope of data change comprises: traversing a scope of data change of each piece of transaction data in a first level I transaction subset; in response to that a scope of data change of a second piece of transaction data overlaps with a scope of data change of a first level II transaction subset, adding the second piece of transaction data into the first level II transaction subset; and in response to that the scope of data change of the second piece of transaction data does not overlap with the scope of data change of the first level II transaction subset, creating a second level II transaction subset and adding the second piece of transaction data into the second level II transaction sub set.
  • the implementation process of determining a transaction subset according to transaction types and scopes of data change of the transaction data may comprise: Step S 1027 determining a level I subset to which the transaction data belongs according to the transaction types of the transaction data; then determining a level II subset to which the transaction data belongs according to the scopes of data change of the transaction data in the level I subset, and using the level II subset as the transaction subset, wherein the level II subset is a subset of the level I subset.
  • the performing a first level division on the transaction set according to the transaction type and determining a level I subset to which the transaction data belongs may further comprise: according to the transaction types of the transaction data in the transaction set, putting transaction data of the same transaction type into the same level I subset, and dividing transaction data of different transaction types into different level I subsets.
  • the determining transaction subsets that can be executed in parallel only according to transaction types may improve the execution efficiency to a degree, but may not achieve a satisfactory effect in cases where a large amount such as a high concurrent amount of transaction data is generated. Therefore, on the basis of the above-described division, the level I subsets determined according to transaction types are subject to second level division according to scopes of data change, and level II subsets obtained through the second level division are used as transaction subsets for parallel processing, so as to further improve the execution efficiency.
  • the determining a level II subset to which the transaction data belongs according to the scopes of data change of the transaction data in the level I subset comprises: according to the scopes of data change of the transaction data in the level I subset, putting transaction data having overlapping scopes of data change into the same level II subset, and dividing transaction data having scopes of data change that do not overlap into different level II sub sets.
  • the according to the scopes of data change of the transaction data in the level I subset, putting transaction data having overlapping scopes of data change into the same level II subset, and dividing transaction data having scopes of data change that do not overlap into different level II subsets may comprise, as shown in FIG. 3 :
  • S 1031 if the scope of data change of the second transaction data does not overlap with the scope of data change of the first level II subset, creating a second level II subset that comprises the second transaction data; wherein the first level I subset is any level I subset in the level I subsets, the second transaction data is any piece of transaction data in the first level I subset, the first level II subset is any level II subset in the first level I subset, and the second level II subset is different from the first level II subset.
  • level II subsets from the level I subsets is similar to the process and principle of dividing transaction subsets from a transaction set as described in No. (II), which will not be elaborated here.
  • the subset assignment may be performed according to scope of data change at a primary level, and then according to transaction type at a secondary level. Various detailed steps described above can be similarly applied here.
  • the assigning the transaction data into transaction subsets comprises: determining one or more level I transaction subsets for the transaction data according to the transaction data's scope of data change.
  • the determining one or more level I transaction subsets for the transaction data according to the transaction data's scope of data change comprises: assigning pieces of the transaction data with the overlapping scope of data change in a same level I transaction subset; and assigning pieces of the transaction data with no overlapping scope of data change into different level I transaction subsets.
  • the assigning the transaction data into transaction subsets further comprises: determining one or more level II transaction subsets for each of the one or more level I transaction subsets according to the transaction data's transaction type, each of the one or more level II transaction subsets being a subset under one of the one or more level I transaction subsets.
  • Executing the transaction subsets in parallel comprises: executing a plurality of level II transaction subsets corresponding to the one or more level I transaction subsets in parallel.
  • the transaction data may be assigned into level I transaction subsets M and M, of which transaction data in subset M is assigned into two level II transaction subset M 1 and M 2 , and transaction data in subset N is assigned into one level II transaction subset N 1 (here level I transaction subset N is the same as the level II transaction subset N 1 ). Then, level II transaction subsets M 1 , M 2 , and N 1 can be executed in parallel.
  • the determining one or more level II transaction subsets for each of the one or more level I transaction subsets according to the transaction data's transaction type comprises: assigning pieces of transaction data in each of the one or more level I subsets with the same transaction type in a same level II transaction subset; and assigning pieces of the transaction data in the each level I subset with different transaction types into different level II transaction subsets.
  • the determining one or more level II transaction subsets for each of the one or more level I transaction subsets according to the transaction data's transaction type comprises: traversing a transaction type of each piece of transaction data in a first level I transaction subset; in response to that a transaction type of a second piece of transaction data is the same as a transaction type of one or more pieces of transaction data of a first level II transaction subset, adding the second piece of transaction data into the first level II transaction subset; and in response to that the transaction type of the second piece of transaction data is different from the transaction type of all pieces of transaction data of the first level II transaction subset, creating a second level II transaction subset and adding the second piece of transaction data into the second level II transaction subset.
  • a transaction data arranging module is configured to achieve division of transaction subsets.
  • a transaction data execution cluster executes transaction data in different transaction subsets in parallel, executes transaction data inside a transaction subset in series according to timestamps corresponding to the transaction data, and then writes the execution result into the blockchain, thereby ensuring the consistency in the blockchain database state, reducing the cost required for improving the execution efficiency of data processing, and improving expandability.
  • the execution result is written into a block of the blockchain
  • the results of execution of transaction data by the transaction data execution cluster may be summarized and then written into the blockchain.
  • one designated computer in the cluster may complete the summarization of execution results.
  • transaction data is sorted according to received timestamps of the transaction data when the transaction data is executed, and then the execution is performed in series in the temporal order to update account information after each piece of transaction data is executed.
  • the transaction data is classified first according to transaction types and/or scopes of data change to form transaction subsets, causing transaction data without a transaction dependency relationship to be divided into different transaction subsets and transaction data with a transaction dependency relationship to be put into the same transaction subset.
  • the division of transaction data and determination of transaction subsets may be implemented by the transaction data arranging module shown in FIG. 4 .
  • the transaction data arranging module may distribute the transaction subsets to computers in the transaction data execution cluster for data processing.
  • Each computer in the transaction data execution cluster only executes transaction data in an allocated transaction subset, follows the process of verification-implementation-recording in a blockchain to write an execution result into the blockchain.
  • the transaction data arranging module and the transaction data execution cluster may also be, for example, jointly a transaction execution cluster to implement functions of reception, classification, distribution, and execution of transaction data, summarize execution results of transaction data, and to write the summarized execution results into the blockchain.
  • the embodiments of the present specification further provide another method for writing transaction data into a blockchain, comprising: obtaining a plurality of pieces of transaction data to be executed; determining first transaction data without a transaction dependency relationship according to scopes of data change of the transaction data, wherein there is no transaction dependency relationship among the first transaction data; and executing the first transaction data in parallel, and writing an execution result into the blockchain.
  • transaction data with a scope of data change not overlapping another scope of data change of any other piece of transaction data may be determined as the first transaction data having no transaction dependency relationship according to scopes of data change of the transaction data.
  • the scopes of data change of the transaction data 3 , 4 , 6 , and 8 do not overlap with a scope of data change of any other transaction data. Therefore, the order of execution of these pieces of transaction data does not affect the consistency in the database state. As a result, the parallel execution of these pieces of transaction data favors improving the execution efficiency of data processing, thereby reducing the cost required for improving the execution efficiency of data processing and improving expandability.
  • an apparatus for writing transaction data into a blockchain may comprise: an obtaining module 101 configured to obtain transaction data to be added into the blockchain; a transaction subset determining module 102 configured to assign the transaction data into transaction subsets, wherein pieces of the transaction data having at least one of: a same transaction type or an overlapping scope of data change are assigned into a same transaction subset, and pieces of the transaction data with different transaction types and with no overlapping scope of data change are assigned into different transaction subsets; and a data executing module 103 configured to execute the transaction subsets in parallel and store results of the execution into the blockchain.
  • the various modules and units of the apparatus for writing transaction data into a blockchain may be implemented as software instructions (or a combination of software and hardware). That is, the apparatus for writing transaction data into a blockchain described with reference to FIG. 5 may comprise a processor (e.g., the CPU) and a non-transitory computer-readable storage medium (e.g., the memory) storing instructions that, when executed by the processor, cause one or more components (e.g., the processor) of the apparatus to perform various steps and methods of the modules and units described above.
  • the apparatus for writing transaction data into a blockchain may also be referred to as a system for writing transaction data into a blockchain.
  • the apparatus for writing transaction data into a blockchain may include a mobile phone, a tablet computer, a PC, a laptop computer, or another computing device.
  • an apparatus corresponding to the method for writing transaction data into a blockchain in the above embodiments is disclosed. All descriptions of the above embodiments are applicable here, which will not be elaborated here.
  • the present specification further provides a method for determining a transaction subset of blockchain transaction data.
  • Transaction data may be divided using this method, causing transaction data without a transaction dependency relationship to be executed in parallel, thereby reducing the cost required for improving the execution efficiency of data processing and improving expandability.
  • the method comprises: after a plurality of pieces of transaction data to be executed are obtained, transaction subsets to which the transaction data belongs are determined according to transaction types and/or scopes of data change of the transaction data, for executing the transaction subsets in parallel, wherein there is no transaction dependency relationship among transaction data belonging to different transaction subsets.
  • the determining transaction subsets to which the transaction data belongs according to transaction types and/or scopes of data change of the transaction data may comprise: determining the transaction subsets to which the transaction data belongs according to a data attribute of the transaction data, wherein the data attribute has a corresponding relationship with a transaction type and/or a scope of data change of the transaction data, and the data attribute represents a transaction dependency relationship of the transaction data.
  • the determining transaction subsets to which the transaction data belongs according to transaction types of the transaction data may comprise: according to the transaction types of the transaction data, putting transaction data of the same transaction type into the same transaction subset, and dividing transaction data of different transaction types into different transaction subsets.
  • the determining transaction subsets to which the transaction data belongs according to scopes of data change of the transaction data may comprise: according to the scopes of data change of the transaction data, putting transaction data having overlapping scopes of data change into the same transaction subset, and dividing transaction data having scopes of data change that do not overlap into the different transaction subsets.
  • the determining transaction subsets to which the transaction data belongs according to transaction types and scopes of data change of the transaction data may further comprise: determining a level I subset to which the transaction data belongs according to the transaction types of the transaction data; and determining a level II subset to which the transaction data belongs according to the scopes of data change of the transaction data in the level I subset, and using the level II subset as the transaction subset, wherein the level II subset is a subset of the level I subset.
  • the embodiments of the present specification may be provided as a method, a system, or a computer program product. Therefore, the present specification may be implemented as a complete hardware embodiment, a complete software embodiment, or an embodiment combining software and hardware. Moreover, the present embodiments may be in the form of a computer program product implemented on one or more computer usable storage media (including, but not limited to, a magnetic disk memory, CD-ROM, an optical memory, etc.) comprising computer usable program codes.
  • a computer usable storage media including, but not limited to, a magnetic disk memory, CD-ROM, an optical memory, etc.
  • These computer program instructions may be provided for a general-purpose computer, a special-purpose computer, an embedded processor, or a processor of other programmable data processing devices to generate a machine, causing the instructions executed by a computer or a processor of other programmable data processing devices to generate an apparatus for implementing a function specified in one or more processes in the flowcharts and/or in one or more blocks in the block diagrams.
  • These computer program instructions may also be stored in a computer readable memory that can instruct a computer or other programmable data processing devices to work in a particular manner, causing the instructions stored in the computer readable memory to generate a manufactured article that includes an instruction apparatus.
  • the instruction apparatus implements a function specified in one or more processes in the flowcharts and/or in one or more blocks in the block diagrams.
  • These computer program instructions may also be loaded onto a computer or other programmable data processing devices, causing a series of operational steps to be performed on the computer or other programmable devices, thereby generating computer-implemented processing. Therefore, the instructions executed on the computer or other programmable devices provide steps for implementing a function specified in one or more processes in the flowcharts and/or in one or more blocks in the block diagrams.
  • the computation device includes one or more processors (CPUs), input/output interfaces, network interfaces, and a memory.
  • the memory may include computer readable media, such as a volatile memory, a Random Access Memory (RAM), and/or a non-volatile memory, e.g., a Read-Only Memory (ROM) or a flash memory (flash RAM).
  • RAM Random Access Memory
  • ROM Read-Only Memory
  • flash RAM flash memory
  • Computer readable media include permanent, volatile, mobile, and immobile media, which can implement information storage through any method or technology.
  • the information may be computer readable instructions, data structures, program modules, or other data.
  • Examples of storage media of computers include, but are not limited to, Phase-change Random Access Memories (PRAMs), Static Random Access Memories (SRAMs), Dynamic Random Access Memories (DRA Ms), other types of Random Access Memories (RA Ms), Read-Only Memories (ROMs), Electrically Erasable Programmable Read-Only Memories (EEPROMs), flash memories or other memory technologies, Compact Disk Read-Only Memories (CD-ROMs), Digital Versatile Discs (DVDs) or other optical memories, cassettes, cassette and disk memories or other magnetic memory devices, or any other non-transmission media, which can be used for storing information accessible to a computation device.
  • the computer readable media do not include transitory media (transitory media), such as modulated data signals and carriers.
  • the embodiments of the present specification may be provided as a method, a system, or a computer program product. Therefore, the present specification may be implemented as a complete hardware embodiment, a complete software embodiment, or an embodiment combining software and hardware. Moreover, the present specification may be in the form of a computer program product implemented on one or more computer usable storage media (including, but not limited to, a magnetic disk memory, CD-ROM, an optical memory, etc.) comprising computer usable program codes.
  • a computer usable storage media including, but not limited to, a magnetic disk memory, CD-ROM, an optical memory, etc.

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Databases & Information Systems (AREA)
  • Software Systems (AREA)
  • Data Mining & Analysis (AREA)
  • Computing Systems (AREA)
  • Computational Linguistics (AREA)
  • Computer Security & Cryptography (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Mathematical Physics (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
  • Financial Or Insurance-Related Operations Such As Payment And Settlement (AREA)

Abstract

Methods, systems, and apparatus, including computer programs encoded on computer storage media, for adding transaction data into a blockchain are provided. One of the methods includes: obtaining transaction data to be added into the blockchain, assigning the transaction data into transaction subsets, and executing the transaction subsets in parallel, and storing results of the execution into the blockchain. Pieces of the transaction data having at least one of: a same transaction type or an overlapping scope of data change are assigned into a same transaction subset, and pieces of the transaction data with different transaction types and with no overlapping scope of data change are assigned into different transaction subsets.

Description

    CROSS REFERENCE TO RELATED APPLICATIONS
  • The present application is a continuation application of U.S. application Ser. No. 16/535,035, filed on Aug. 7, 2019, and titled “Method and Apparatus for Writing Service Data into Block Chain and Method for Determining Service Subset,” which is a continuation application of International Patent Application No. PCT/CN2018/077286, filed on Feb. 26, 2018, and titled “Method and Apparatus for Writing Service Data into Blockchain and Method for Determining Service Subset,” which claims priority to Chinese Patent Application No. 201710116539.7, filed on Feb. 28, 2017. The entire contents of all of the above applications are incorporated herein by reference in their entirety.
  • TECHNICAL FIELD
  • The present application relates to the field of computer technologies, and in particular, to a method and apparatus for writing transaction data into a blockchain and a method for determining a transaction subset of blockchain transaction data.
  • BACKGROUND
  • With the development of computer technologies, blockchain technologies (also referred to as distributed ledger network) have been extensively used in numerous fields, such as smart contracts, securities transactions, e-commerce, Internet of Things, social communications, document storage, existence proof, identity verification, and equity crowd-funding due to advantages such as decentralization, openness and transparency, immutability, and trustworthiness.
  • In one example, the blockchain technologies are a type of decentralized and distributed database technologies. Each piece of data in a blockchain will be broadcast to all blockchain nodes of the entire network, and each node keeps the full amount of data that is consistent with each other. The blockchain technologies require that all nodes keep the same state, including the database state and the like. To ensure the consistency in the database state, it is required that blockchain transactions are in an ordered sequence that is consistent for all nodes, and all nodes execute transactions in such sequence to complete transaction verification, implementation, inclusion of data in the chain, etc. Take the blockchain application of Ethereum as an example, a timestamp is created when each transaction is received, the transactions are written into a transaction pool, and the transactions are sorted according to the timestamps; during mining, the transactions are executed according to the sequence of transaction timestamps, and the account information after the execution of each transaction is updated into a database, thereby achieving the update of the database account state.
  • In the current technologies, to ensure consistency in the database state, data is to be processed according to a string of timestamps of transaction (e.g., transaction data to be written into a blockchain) reception. Therefore, only one single machine may perform the execution, causing the write performance and efficiency of a database to be limited by the performance of a single machine. To improve the write performance and efficiency, physical properties, such as CPU, of a single machine have to be improved, such as increasing the core number of CPU, which not only leads to high cost, but also limits expandability.
  • SUMMARY
  • Embodiments of the present specification provide a method and apparatus for writing transaction data into a blockchain, which may reduce the cost required for improving the execution efficiency of data processing and improve expandability.
  • The embodiments of the present specification further provide a method for determining a transaction subset of blockchain transaction data, which may reasonably allocate transaction data, thereby reducing the cost required for improving the execution efficiency of data processing and improving expandability.
  • In some embodiments, a method for adding transaction data into a blockchain comprises: obtaining transaction data to be added into the blockchain, assigning the transaction data into transaction subsets, and executing the transaction subsets in parallel, and storing results of the execution into the blockchain. Pieces of the transaction data having at least one of: a same transaction type or an overlapping scope of data change are assigned into a same transaction subset, and pieces of the transaction data with different transaction types and with no overlapping scope of data change are assigned into different transaction subsets.
  • In some embodiments, the executing the transaction subsets in parallel comprises: executing the transaction data in the different transaction subsets in parallel using multithreading or a machine cluster.
  • In some embodiments, each piece of transaction data corresponds to a timestamp; and the executing the transaction data in parallel comprises: executing the pieces of transaction data comprised in the same transaction subset in series according to a temporal order corresponding to the timestamps.
  • In some embodiments, the assigning the transaction data into transaction subsets comprises: determining one or more level I transaction subsets for the transaction data according to the transaction data's transaction type.
  • In one embodiment, the determining one or more level I transaction subsets for the transaction data according to the transaction data's transaction type comprises: assigning pieces of the transaction data with the same transaction type in a same level I transaction subset; and assigning pieces of the transaction data with different transaction types into different level I transaction subsets.
  • In one embodiment, the assigning the transaction data into transaction subsets further comprises: determining one or more level II transaction subsets for each of the one or more level I transaction subsets according to the transaction data's scope of data change, each of the one or more level II transaction subsets being a subset under one of the one or more level I transaction subsets. Executing the transaction subsets in parallel comprises: executing a plurality of level II transaction subsets corresponding to the one or more level I transaction subsets in parallel.
  • In one embodiment, the determining one or more level II transaction subsets for each of the one or more level I transaction subsets according to the transaction data's scope of data change comprises: assigning pieces of transaction data in each of the one or more level I subsets with the overlapping scope of data change in a same level II transaction subset; and assigning pieces of the transaction data in the each level I subset with no overlapping scope of data change into different level II transaction subsets.
  • In one embodiment, the determining one or more level II transaction subsets for each of the one or more level I transaction subsets according to the transaction data's scope of data change comprises: traversing a scope of data change of each piece of transaction data in a first level I transaction subset; in response to that a scope of data change of a second piece of transaction data overlaps with a scope of data change of a first level II transaction subset, adding the second piece of transaction data into the first level II transaction subset; and in response to that the scope of data change of the second piece of transaction data does not overlap with the scope of data change of the first level II transaction subset, creating a second level II transaction subset and adding the second piece of transaction data into the second level II transaction sub set.
  • In some embodiments, the assigning the transaction data into transaction subsets comprises: determining one or more level I transaction subsets for the transaction data according to the transaction data's scope of data change.
  • In one embodiment, the determining one or more level I transaction subsets for the transaction data according to the transaction data's scope of data change comprises: assigning pieces of the transaction data with the overlapping scope of data change in a same level I transaction subset; and assigning pieces of the transaction data with no overlapping scope of data change into different level I transaction subsets.
  • In one embodiment, the assigning the transaction data into transaction subsets further comprises: determining one or more level II transaction subsets for each of the one or more level I transaction subsets according to the transaction data's transaction type, each of the one or more level II transaction subsets being a subset under one of the one or more level I transaction subsets. Executing the transaction subsets in parallel comprises: executing a plurality of level II transaction subsets corresponding to the one or more level I transaction subsets in parallel.
  • In one embodiment, the determining one or more level II transaction subsets for each of the one or more level I transaction subsets according to the transaction data's transaction type comprises: assigning pieces of transaction data in each of the one or more level I subsets with the same transaction type in a same level II transaction subset; and assigning pieces of the transaction data in the each level I subset with different transaction types into different level II transaction subsets.
  • In one embodiment, the determining one or more level II transaction subsets for each of the one or more level I transaction subsets according to the transaction data's transaction type comprises: traversing a transaction type of each piece of transaction data in a first level I transaction subset; in response to that a transaction type of a second piece of transaction data is the same as a transaction type of one or more pieces of transaction data of a first level II transaction subset, adding the second piece of transaction data into the first level II transaction subset; and in response to that the transaction type of the second piece of transaction data is different from the transaction type of all pieces of transaction data of the first level II transaction subset, creating a second level II transaction subset and adding the second piece of transaction data into the second level II transaction subset.
  • In some embodiments, a system for adding transaction data into a blockchain, comprising one or more processors and one or more non-transitory computer-readable memories coupled to the one or more processors and configured with instructions executable by the one or more processors to cause the system to perform operations comprising: obtaining transaction data to be added into the blockchain, assigning the transaction data into transaction subsets, and executing the transaction subsets in parallel, and storing results of the execution into the blockchain. Pieces of the transaction data having at least one of: a same transaction type or an overlapping scope of data change are assigned into a same transaction subset, and pieces of the transaction data with different transaction types and with no overlapping scope of data change are assigned into different transaction subsets.
  • In some embodiments, a non-transitory computer-readable storage medium configured with instructions executable by one or more processors to cause the one or more processors to perform operations comprising: obtaining transaction data to be added into the blockchain, assigning the transaction data into transaction subsets, and executing the transaction subsets in parallel, and storing results of the execution into the blockchain. Pieces of the transaction data having at least one of: a same transaction type or an overlapping scope of data change are assigned into a same transaction subset, and pieces of the transaction data with different transaction types and with no overlapping scope of data change are assigned into different transaction subsets.
  • In some embodiments, the method for writing transaction data into a blockchain provided by the embodiments of the present specification comprises: obtaining a plurality of pieces of transaction data to be written into the blockchain; assigning the transaction data into transaction subsets based on at least one of: a transaction type or a scope of data change of the transaction data, wherein: assigning the transaction data into the transaction subsets comprises: assigning multiple pieces of transaction data with a transaction dependency in a same transaction subset and assigning multiple pieces of transaction data without the transaction dependency into different transaction subsets; and executing the transaction subsets in parallel, and writing results of the execution into the blockchain.
  • In some embodiments, assigning the transaction data into transaction subsets based on at least one of: a transaction type or a scope of data change of the transaction data comprises: determining a transaction subset to which a piece of transaction data belongs according to a data attribute of the piece of transaction data, wherein the data attribute has a corresponding relationship with at least one of: a transaction type or a scope of data change of the piece of transaction data, and the data attribute indicates whether the transaction dependency exists between the piece of transaction data and other pieces of transaction data.
  • In some embodiments, the executing the transaction subsets in parallel comprises: executing the transaction data in the different transaction subsets in parallel using multithreading or a machine cluster.
  • In some embodiments, each piece of transaction data corresponds to a timestamp, and executing the transaction data in the transaction subsets in parallel comprises: executing pieces of transaction data comprised in a same transaction subset in series according to a temporal order corresponding to the timestamps.
  • In some embodiments, assigning the transaction data into transaction subsets based on at least one of: a transaction type or a scope of data change of the transaction data comprises: according to the transaction types of pieces of transaction data, putting pieces of transaction data of a same transaction type into a same transaction subset, and dividing pieces of transaction data of different transaction types into the different transaction subsets.
  • In some embodiments, assigning the transaction data into transaction subsets based on at least one of: a transaction type or a scope of data change of the transaction data comprises: according to a scope of data change in each piece of transaction data, putting pieces of transaction data having overlapping scopes of data change into a same transaction subset, and dividing pieces of transaction data having scopes of data change that do not overlap into the different transaction subsets. The scope of data change in each piece of transaction data may include a set of objects involved in the data change in the each piece of transaction data.
  • In some embodiments, according to a scope of data change in each piece of transaction data, putting pieces of transaction data having overlapping scopes of data change into a same transaction subset, and dividing pieces of transaction data having scopes of data change that do not overlap into the different transaction subsets comprises: traversing the scope of date change of each piece of transaction data; in response to that the scope of data change of a first piece of transaction data overlaps with a scope of data change of a first transaction subset, adding the first piece of transaction data into the first transaction subset; and in response to that the scope of data change of the first piece of transaction data does not overlap with the scope of data change of the first transaction subset, creating a second transaction subset and adding the first piece of transaction data into the second transaction subset. The first pieces of transaction data may be any of the pieces of transaction data, the first transaction subset may be any of the transaction subsets, and the second transaction subset may be different from the first transaction subset.
  • In some embodiments, the scope of data change of the first transaction subset is a union of scopes of data change of pieces of transaction data comprised in the transaction subset.
  • In some embodiments, each piece of transaction data corresponds to a timestamp, and traversing the scope of data change of each piece of transaction data comprises: traversing in a temporal order corresponding to the timestamps of the transaction data.
  • In some embodiments, assigning the transaction data into transaction subsets based on at least one of: a transaction type or a scope of data change of the transaction data comprises: determining a level I subset to which pieces of transaction data belong according to transaction types of the pieces of transaction data; and determining level II subsets to which the pieces of transaction data in the level I subset belong according to a scope of data change of each piece of transaction data, and using the level II subsets as the transaction subsets, wherein a level II subset is a subset of the level I subset.
  • In some embodiments, determining a level I subset to which pieces of transaction data belong comprises: according to transaction types of the pieces of transaction data, putting pieces of transaction data of a same transaction type into a same level I subset, and dividing pieces of transaction data of different transaction types into different level I subsets.
  • In some embodiments, determining level II subsets to which the pieces of transaction data in the level I subset belong comprises: according to the scope of data change of each piece of transaction data in the level I subset, putting pieces of transaction data having overlapping scopes of data change into a same level II subset, and dividing pieces of transaction data having scopes of data change that do not overlap into different level II subsets.
  • In some embodiments, according to the scope of data change of each piece of transaction data in the level I subset, putting pieces of transaction data having overlapping scopes of data change into a same level II subset, and dividing pieces of transaction data having scopes of data change that do not overlap into different level II subsets comprises: traversing the scope of data change of each piece of transaction data in a first level I subset; in response to that the scope of data change of a second piece of transaction data overlaps with a scope of data change of a first level II subset, adding the second piece of transaction data into the first level II subset; and in response to that the scope of data change of the second piece of transaction data does not overlap with the scope of data change of the first level II subset, creating a second level II subset and adding the second piece of transaction data into the second level II subset; wherein the first level I subset is any of the level I subsets, the second piece of transaction data is any of the pieces of the transaction data in the first level I subset, the first level II subset is any of the level II subsets in the first level I subset, and the second level II subset is different from the first level II subset.
  • In some embodiments, the plurality of pieces of transaction data to be executed are obtained based on at least one of: a preset amount or a preset period of time.
  • In some embodiments, another method for writing transaction data into a blockchain comprises: obtaining a plurality of pieces of transaction data to be written into a blockchain; determining first transaction data without a transaction dependency relationship according to a scope of data change of the transaction data, wherein there is no transaction dependency relationship among the first transaction data; and executing the first transaction data in parallel, and writing an execution result into the blockchain.
  • In some embodiments, the determining first transaction data without a transaction dependency relationship according to the scope of data change of the transaction data comprises: according to scope of data change of the transaction data, determining transaction data with a scope of data change not overlapping a scope of data change of any other piece of transaction data as the first transaction data having no transaction dependency relationship.
  • In some embodiments, an apparatus for writing transaction data into a blockchain comprises: an obtaining module configured to obtain a plurality of pieces of transaction data to be written into a blockchain; a transaction subset determining module configured to determine a transaction subset to which the transaction data belongs according to at least one of: a transaction type or a scope of data change of the transaction data, wherein there is no transaction dependency relationship among transaction data belonging to different transaction subsets; and a data executing module configured to execute the transaction subsets in parallel, and write an execution result into the blockchain.
  • In some embodiments, a method for determining a transaction subset of blockchain transaction data comprises: after a plurality of pieces of transaction data to be written into a blockchain are obtained, determining transaction subsets to which the transaction data belongs according to at least one of: a transaction type or a scope of data change of the transaction data, for executing the transaction subsets in parallel and writing an execution result into the blockchain, wherein there is no transaction dependency relationship among transaction data belonging to different transaction subsets.
  • In some embodiments, the determining transaction subsets to which the transaction data belongs according to at least one of: a transaction type or a scope of data change of the transaction data comprises: determining the transaction subsets to which the transaction data belongs according to data attributes of the transaction data, wherein a data attribute has a corresponding relationship with at least one of: a transaction type or a scope of data change of the transaction data, and the data attribute represents a transaction dependency relationship of the transaction data.
  • In some embodiments, the determining transaction subsets to which the transaction data belongs according to transaction types of the transaction data comprises: according to the transaction types of the transaction data, putting transaction data of a same transaction type into the same transaction subset, and dividing transaction data of different transaction types into the different transaction subsets; or the determining transaction subsets to which the transaction data belongs according to scopes of data change of the transaction data comprises: according to the scopes of data change of the transaction data, putting transaction data having overlapping scopes of data change into the same transaction subset, and dividing transaction data having scopes of data change that do not overlap into the different transaction subsets.
  • In some embodiments, the determining transaction subsets to which the transaction data belongs according to transaction types and scopes of data change of the transaction data comprises: determining a level I subset to which the transaction data belongs according to the transaction types of the transaction data; and determining a level II subset to which the transaction data belongs according to the scopes of data change of the transaction data in the level I subset, and using the level II subset as one of the transaction subsets, wherein the level II subset is a subset of the level I subset.
  • In some embodiments, a system for writing transaction data into a blockchain comprises one or more processors and one or more non-transitory computer-readable memories coupled to the one or more processors and configured with instructions executable by the one or more processors to cause the system to perform operations comprising: obtaining a plurality of pieces of transaction data to be written into the blockchain; assigning the transaction data into transaction subsets based on at least one of: a transaction type or a scope of data change of the transaction data, wherein: assigning the transaction data into the transaction subsets comprises: assigning multiple pieces of transaction data with a transaction dependency in a same transaction subset and assigning multiple pieces of transaction data without the transaction dependency into different transaction subsets; and executing the transaction subsets in parallel, and writing results of the execution into the blockchain.
  • In some embodiments, a non-transitory computer-readable storage medium is configured with instructions executable by one or more processors to cause the one or more processors to perform operations comprising: obtaining a plurality of pieces of transaction data to be written into the blockchain; assigning the transaction data into transaction subsets based on at least one of: a transaction type or a scope of data change of the transaction data, wherein: assigning the transaction data into the transaction subsets comprises: assigning multiple pieces of transaction data with a transaction dependency in a same transaction subset and assigning multiple pieces of transaction data without the transaction dependency into different transaction subsets; and executing the transaction subsets in parallel, and writing results of the execution into the blockchain.
  • The above-described at least one technical solution employed by the embodiments of the present specification can achieve the following advantageous effects. In the embodiments of the present specification, after transaction data to be written into a blockchain is obtained, whether there is a transaction dependency relationship among the transaction data may be determined according to transaction types or scopes of data change of the transaction data, and then the transaction data may be divided into different transaction subsets according to the situation of transaction dependency among the transaction data. Since there is no transaction dependency relationship among transaction data belonging to different transaction subsets, different transaction subsets may be executed in parallel without affecting the consistency in the database state. According to the solutions provided by the embodiments of the present specification, executing transaction data without a transaction dependency relationship in parallel not only ensures the consistency in the database state, but also improves the execution efficiency of data processing without relying on improvements of the performance of individual machines. Therefore, the performance requirements for individual machines may be lowered, which favors cost saving and leads to a better expandability.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • The accompanying drawings to be described here are used to provide a better understanding of the present specification and constitute a part of the present specification. The exemplary embodiments of the present specification and the description of the exemplary embodiments are used to describe the present specification and do not constitute improper limitations to the present specification. In the accompanying drawings:
  • FIG. 1 is a flow chart of a method for writing transaction data into a blockchain according to some embodiments of the present specification;
  • FIG. 2 is a flow chart of a second method for writing transaction data into a blockchain according to some embodiments of the present specification;
  • FIG. 3 is a flow chart of a third method for writing transaction data into a blockchain according to some embodiments of the present specification;
  • FIG. 4 is a schematic diagram of an exemplary specification scenario of the method for writing transaction data into a blockchain according to some embodiments of the present specification;
  • FIG. 5 is a schematic structural diagram of an apparatus for writing transaction data into a blockchain according to some embodiments of the present specification.
  • DETAILED DESCRIPTION
  • The technical solutions of the present specification will be clearly and completely described below with reference to the embodiments and the accompanying drawings of the present specification. The described embodiments are merely some, but not all, embodiments of the present specification. On the basis of the embodiments of the present specification, all other embodiments obtainable by one of ordinary skill in the art without creative effort shall fall within the scope of the present specification.
  • The technical solutions provided in the embodiments of the present specification will be described in detail below with reference to the accompanying drawings.
  • FIG. 1 illustrates a method for writing transaction data into a blockchain according to some embodiments of the present specification, comprising S101 to S103.
  • S101: obtaining a plurality of pieces of transaction data to be written into a blockchain;
  • S102: determining transaction subsets to which the transaction data belongs according to transaction types and/or scopes of data change of the transaction data, wherein there is no transaction dependency relationship among transaction data belonging to different transaction subsets; and
  • S103: executing the transaction subsets in parallel, and writing an execution result into the blockchain.
  • In some embodiments, S101 includes obtaining transaction data to be added into the blockchain; S102 includes assigning the transaction data into transaction subsets, wherein pieces of the transaction data having at least one of: a same transaction type or an overlapping scope of data change are assigned into a same transaction subset, and pieces of the transaction data with different transaction types and with no overlapping scope of data change are assigned into different transaction subsets; and S103 includes executing the transaction subsets in parallel, and storing results of the execution into the blockchain.
  • In the above-described embodiment, after the step S101 is executed to obtain transaction data to be written into a blockchain, whether there is a transaction dependency relationship among the transaction data may be determined according to transaction types or scopes of data change of the transaction data, and then the transaction data may be divided into different transaction subsets according to the situation of transaction dependency among the transaction data. Since there is no transaction dependency relationship among transaction data belonging to different transaction subsets, different transaction subsets may be executed in parallel without affecting the consistency in the database state. According to the solutions provided by the embodiments of the present specification, the manner in which transaction data in a transaction subset is executed in parallel may improve the execution efficiency of data processing without relying on improvements of the performance of individual machines. Therefore, the performance requirements for individual machines may be lowered, which favors cost saving and leads to a better expandability.
  • In some embodiments, after a plurality of pieces of transaction data are obtained after the step S101 is executed, a transaction set to be executed comprising the transaction data to be executed may be formed, and the transaction set may be determined by a preset data processing amount and/or a preset transaction data time. In one example, transaction data to be executed in the same batch may be determined by presetting a data processing amount, and an exemplary value of the preset data processing amount may be determined according to an amount of data allowed to be written into a blockchain. For example, an amount of transaction data allowed to be written into a blockchain is 1,000, and then the preset data processing amount may be set to be less than 1,000, e.g., 800, so as to meet the requirement. In an exemplary implementation, every time when a server receives 800 pieces of transaction data, the server may form a transaction set to be executed for subsequent processing. When the transaction set to be executed is determined, transaction data to be executed in the same batch may also be determined by presetting a transaction data time. For example, the preset transaction data time is set to be 1 s, and then the transaction data to be executed in the same batch is transaction data generated in parallel within 1 s.
  • When the step S103 is executed, since the transaction data has been divided into a plurality of transaction subsets without a transaction dependency relationship, the transaction subsets may be executed in parallel using multithreading or a machine cluster, which not only meets the requirement for consistency in the database state, but also achieves the goal of improving the data execution efficiency. In this manner, the data execution efficiency may be improved without relying on improvements of the performance of individual machines. Therefore, the performance requirements for individual machines may be lowered, which favors cost saving and leads to a better expandability by using the manner of machine cluster.
  • In another example, when transaction subsets comprising the transaction data are executed, there is no transaction dependency relationship among the transaction data divided into different transaction subsets, while there is a transaction dependency relationship among the transaction data put into the same transaction subset. Therefore, different transaction subsets may be executed in parallel to improve the data execution efficiency, while transaction data in the same transaction subset may be executed in series to ensure the consistency in the database state. In one example, there is a corresponding relationship between the transaction data and timestamps, and then when a transaction subset is executed, transaction data comprised in the transaction subset is executed in series according to a temporal order corresponding to the timestamps. Furthermore, the execution of each piece of transaction data is performed in an order of transaction verification, transaction implementation, and inclusion of data in the chain to finally write an execution result into the blockchain.
  • When the step S102 is executed, the transaction subsets may be determined in a variety of different manners, as long as transaction data with a transaction dependency relationship is separated from transaction data without a transaction dependency relationship. In one example, a transaction subset to which the transaction data belongs may be determined according to a data attribute of the transaction data, wherein the data attribute has a corresponding relationship with a transaction type and/or a scope of data change of the transaction data, and the data attribute indicates whether there is a transaction dependency relationship of the transaction data. Then, transaction data with a transaction dependency relationship may be put into the same transaction subset, and transaction data without a transaction dependency relationship may be divided into different transaction subsets according to the data attribute extracted from the transaction data, thereby achieving parallel execution of different transaction subsets. In a further example, the data attribute may be embodied in the form of an identifier field comprised in the transaction data or may be embodied in the form of characteristic information carried by the transaction data. Whether a designated identifier field is comprised may be determined, or characteristic information of the transaction data may be extracted and then whether the characteristic information meets a preset condition may be determined, thereby determining a transaction dependency relationship of the transaction data according to the data attribute.
  • The transaction dependency relationship among the transaction data set forth in the embodiments of the present specification may be embodied by transaction association that is present when different transaction data is executed, for example, the association in aspects such as temporal order, transaction object, or execution result. For example, if an execution of transaction data with a later execution time is dependent on the result of execution of transaction data with an earlier execution time, or executions of different transaction data impact the same data state, then it is regarded that these two pieces of transaction data have a transaction dependency relationship. Conversely, it may be regarded that these two pieces of transaction data do not have a transaction dependency relationship.
  • A process of determining a transaction subset will be described in detail through examples.
  • (I) Determining a Transaction Subset According to Transaction Types of the Transaction Data
  • In the embodiments of the present specification, a transaction subset may be determined according to transaction types of the transaction data. In one example, transaction data of the same transaction type is put into the same transaction subset, and transaction data of different transaction types are divided into different transaction subsets. Since there is no transaction dependency relationship among the transaction data of different transaction types, the result of data execution will not be affected regardless of an order in which transaction data of different transaction types is executed. Determining whether transaction data belongs to the same transaction subset according to transaction types of the transaction data can ensure that there is no transaction dependency relationship among the transaction data belonging to different transaction subsets, thereby enabling parallel processing of transaction data in different transaction subsets and favoring the improvement of the execution efficiency of data processing.
  • For example, after a contract-type transaction (which may also be referred to as a transaction) is executed, only corresponding contract data is changed, while after a transfer-type transaction (which may also be referred to as a transaction) is executed, the account balance data of both parties of the transfer is changed. In some embodiments, the order in which these two types of transactions are executed does not have an impact on the execution result. Therefore, dividing two different types of transactions into different transaction subsets can ensure that transaction data belonging to different transaction subsets do not have a transaction dependency relationship, and thus the transaction subsets can be processed in parallel without affecting the consistency in the database state.
  • (II) Determining a Transaction Subset According to Scopes of Data Change of the Transaction Data
  • The scope of data change in the present specification refers to a set of one or more objects for execution of transaction data. In the embodiments of the present specification, according to the scopes of data change of the transaction data, transaction data having overlapping scopes of data change may be put into the same transaction subset, and transaction data having scopes of data change that do not overlap may be divided into different transaction subsets. When a transaction subset is determined according to scopes of data change of the transaction data, different pieces of transaction data may be executed in an order that these pieces of transaction data are generated, if the data ranges affected by the execution of these pieces of transaction data overlap, otherwise the result of data execution will be affected. On the other hand, if the data ranges affected by the execution of different pieces of transaction data do not overlap, an order of execution of these pieces of transaction data will not affect the data processing result. Therefore, determining a transaction subset according to scopes of data change of the transaction data may meet the need for parallel processing of different transaction subsets, thereby favoring the improvement of the execution efficiency of data processing.
  • In one example, the putting transaction data having overlapping scopes of data change into the same transaction subset, and dividing transaction data having scopes of data change that do not overlap into the different transaction subsets may comprise: traversing scopes of data change of the transaction data; if the scope of data change of a first transaction data overlaps with the scope of data change of a first transaction subset, adding the first transaction data into the first transaction subset; and if the scope of data change of the first transaction data does not overlap with the scope of data change of the first transaction subset, creating a second transaction subset that comprises the first transaction data; wherein the first transaction data is any piece of transaction data, the first transaction subset is any transaction subset in the transaction subsets, and the second transaction subset is different from the first transaction sub set.
  • The above-described process will be described below with reference to the flow chart shown in FIG. 2.
  • S1021: determining if all pieces of transaction data in the transaction set have been traversed, the process ends if yes, otherwise the process proceeds to execute step S1022;
  • S1022: obtaining any piece of transaction data TX from the transaction set. In some embodiments, the transaction data TX may be extracted and generated from transaction data that has not been put into a transaction subset; however, if the extracted transaction data TX has already been put into a transaction subset, the transaction data TX will be put into the same transaction subset after subsequent steps are executed without affecting the achievement of the technical object;
  • S1023: computing a scope of data change of the transaction data TX;
  • S1024: determining whether the scope of data change of the transaction data TX overlaps with the scope of data change of an existing transaction subset TXB;
  • S1025: if a determination result in the step S1024 is yes, adding the transaction data TX into the transaction subset TXB;
  • S1026: if the determination result in the step S1024 is no, creating a new transaction subset TXN, and adding the transaction data TX into the transaction subset TXN.
  • In some embodiments, the scope of data change of a transaction subset is to be recalculated when transaction data comprised in the transaction subset changes, and a union of scopes of data change of transaction data comprised in the transaction subset may be used as the scope of data change of the transaction subset.
  • For example, the execution object of a contract-type transaction is a contract ID, and contract data corresponding to the contract ID will be changed after the execution. The contract ID may be, for example, the scope of data change of the transaction data. If two pieces of transaction data are executed for the same contract ID, it may be deemed that the scopes of data change of these two pieces of transaction data overlap, and then these two pieces of transaction data may be included in the same transaction subset and executed in an order determined according to timestamps corresponding to the transaction data. If two pieces of transaction data are executed for different contract IDs, it may be deemed that the scopes of data change of these two pieces of transaction data do not overlap, and contract data corresponding to the different contract IDs will be changed when these two pieces of transaction data are executed. Therefore, the order of execution does not have impact on the execution result. These two pieces of transaction data may be included in different transaction subsets and executed in parallel.
  • In another example, the execution objects of a transfer-type transaction are accounts of both parties of the transfer, and after the transfer-type transaction is executed, the account balance data of both parties of the transfer will be changed. Therefore, accounts of both parties of the transfer may be, for example, the scope of data change of the transfer-type transaction data. Assuming that the transaction set comprises the following five pieces of transaction data: transaction data 1: transferring from account A to account B, then the scope of data change of the transaction data 1 may be expressed as (A, B); transaction data 2: transferring from the account B to the account A, then the scope of data change of the transaction data 2 may be expressed as (B, A); transaction data 3: transferring from account C to account E, then the scope of data change of the transaction data 3 may be expressed as (C, E); transaction data 4: transferring from account F to account X, then the scope of data change of the transaction data 4 may be expressed as (F, X); and transaction data 5: transferring from the account X to the account E, then the scope of data change of the transaction data 5 may be expressed as (X, E).
  • In some embodiments, the scopes of data change of the transaction data 1 and the transaction data 2 overlap, the scopes of data change of the transaction data 3 and the transaction data 5 overlap, and the scopes of data change of the transaction data 4 and the transaction data 5 overlap. Therefore, the transaction set comprising the transaction data 1 to the transaction data 5 may be divided into the following transaction subsets: transaction subset 1: comprising the transaction data 1 and the transaction data 2, and the scope of data change being (A, B); and transaction subset 2: comprising the transaction data 3, the transaction data 4, and the transaction data 5, and the scope of data change being (C, E, F, X).
  • In some embodiments, the scopes of data change of the transaction subset 1 and the transaction subset 2 do not overlap, and a parallel execution of the transaction subset 1 and the transaction subset 2 will not affect an execution result. Therefore, the transaction subset 1 and the transaction subset 2 may be executed in parallel to improve the execution efficiency. For the transaction subset 1, the scopes of data change of the transaction data 1 and the transaction data 2 overlap (which are even completely identical), and the execution of these two pieces of transaction data may depend on transaction data prior to the execution of these two pieces of transaction data. Therefore, an order of execution may be determined according to timestamps corresponding to these two pieces of transaction data, and these two pieces of transaction data will be executed in series in the temporal order. It is the same for the transaction subset 2. For example, it can be determined according to timestamps that the transaction data 4 of transferring from the account F to the account X is executed first, and then the transaction data 5 of transferring from the account X to the account E is executed. This execution order may be neither parallel nor reversed, since it is possible that the fund required by the transfer from the account X to the account E when the transaction data 5 is executed depends on the execution of the transaction data 4 of transferring from the account F to the account X.
  • In some embodiments, the traversing scopes of data change of the transaction data in the transaction set may be implemented in the manner of S1022: obtaining any piece of transaction data as shown in the example in FIG. 2. Alternatively, the traversing may be implemented according to the temporal order of generation of the transaction data in the transaction set according to the timestamps of the transaction data.
  • (III) Determining a Transaction Subset According to Transaction Types and Scopes of Data Change of the Transaction Data
  • In the embodiments of the present specification, transaction type and scope of data change may be combined for determining a transaction subset in phases and levels. In an exemplary implementation, division may be performed first according to scopes of data change, based on which a second division may be performed according to transaction types, and vice versa.
  • In some embodiments, the subset assignment may be performed according to transaction type at a primary level, and then according to scope of data change at a secondary level. The assigning the transaction data into transaction subsets comprises: determining one or more level I transaction subsets for the transaction data according to the transaction data's transaction type.
  • In one embodiment, the determining one or more level I transaction subsets for the transaction data according to the transaction data's transaction type comprises: assigning pieces of the transaction data with the same transaction type in a same level I transaction subset; and assigning pieces of the transaction data with different transaction types into different level I transaction subsets.
  • In one embodiment, the assigning the transaction data into transaction subsets further comprises: determining one or more level II transaction subsets for each of the one or more level I transaction subsets according to the transaction data's scope of data change, each of the one or more level II transaction subsets being a subset under one of the one or more level I transaction subsets. Executing the transaction subsets in parallel comprises: executing a plurality of level II transaction subsets corresponding to the one or more level I transaction subsets in parallel. For example, the transaction data may be assigned into level I transaction subsets A and B, of which transaction data in subset A is assigned into two level II transaction subset A1 and A2, and transaction data in subset B is assigned into one level II transaction subset B1 (here level I transaction subset B is the same as the level II transaction subset B1). Then, level II transaction subsets A1, A2, and B1 can be executed in parallel.
  • In one embodiment, the determining one or more level II transaction subsets for each of the one or more level I transaction subsets according to the transaction data's scope of data change comprises: assigning pieces of transaction data in each of the one or more level I subsets with the overlapping scope of data change in a same level II transaction subset; and assigning pieces of the transaction data in the each level I subset with no overlapping scope of data change into different level II transaction subsets.
  • In one embodiment, the determining one or more level II transaction subsets for each of the one or more level I transaction subsets according to the transaction data's scope of data change comprises: traversing a scope of data change of each piece of transaction data in a first level I transaction subset; in response to that a scope of data change of a second piece of transaction data overlaps with a scope of data change of a first level II transaction subset, adding the second piece of transaction data into the first level II transaction subset; and in response to that the scope of data change of the second piece of transaction data does not overlap with the scope of data change of the first level II transaction subset, creating a second level II transaction subset and adding the second piece of transaction data into the second level II transaction sub set.
  • That is, taking the first division according to transaction types and then the second division according to scopes of data change as an example, the implementation process of determining a transaction subset according to transaction types and scopes of data change of the transaction data may comprise: Step S1027 determining a level I subset to which the transaction data belongs according to the transaction types of the transaction data; then determining a level II subset to which the transaction data belongs according to the scopes of data change of the transaction data in the level I subset, and using the level II subset as the transaction subset, wherein the level II subset is a subset of the level I subset.
  • Here, the performing a first level division on the transaction set according to the transaction type and determining a level I subset to which the transaction data belongs may further comprise: according to the transaction types of the transaction data in the transaction set, putting transaction data of the same transaction type into the same level I subset, and dividing transaction data of different transaction types into different level I subsets.
  • Since there is a limited number of transaction types of transaction data, the determining transaction subsets that can be executed in parallel only according to transaction types may improve the execution efficiency to a degree, but may not achieve a satisfactory effect in cases where a large amount such as a high concurrent amount of transaction data is generated. Therefore, on the basis of the above-described division, the level I subsets determined according to transaction types are subject to second level division according to scopes of data change, and level II subsets obtained through the second level division are used as transaction subsets for parallel processing, so as to further improve the execution efficiency.
  • In one example, the determining a level II subset to which the transaction data belongs according to the scopes of data change of the transaction data in the level I subset comprises: according to the scopes of data change of the transaction data in the level I subset, putting transaction data having overlapping scopes of data change into the same level II subset, and dividing transaction data having scopes of data change that do not overlap into different level II sub sets.
  • Furthermore, the according to the scopes of data change of the transaction data in the level I subset, putting transaction data having overlapping scopes of data change into the same level II subset, and dividing transaction data having scopes of data change that do not overlap into different level II subsets may comprise, as shown in FIG. 3:
  • S1028: traversing scopes of data change of transaction data in a first level I subset;
  • S1029: determining whether the scope of data change of a second transaction data overlaps with the scope of data change of a first level II subset;
  • S1030: if the scope of data change of the second transaction data overlaps with the scope of data change of the first level II subset, adding the second transaction data into the first level II subset; and
  • S1031: if the scope of data change of the second transaction data does not overlap with the scope of data change of the first level II subset, creating a second level II subset that comprises the second transaction data; wherein the first level I subset is any level I subset in the level I subsets, the second transaction data is any piece of transaction data in the first level I subset, the first level II subset is any level II subset in the first level I subset, and the second level II subset is different from the first level II subset.
  • The process of dividing level II subsets from the level I subsets is similar to the process and principle of dividing transaction subsets from a transaction set as described in No. (II), which will not be elaborated here.
  • Alternatively, the subset assignment may be performed according to scope of data change at a primary level, and then according to transaction type at a secondary level. Various detailed steps described above can be similarly applied here. In some embodiments, the assigning the transaction data into transaction subsets comprises: determining one or more level I transaction subsets for the transaction data according to the transaction data's scope of data change.
  • In one embodiment, the determining one or more level I transaction subsets for the transaction data according to the transaction data's scope of data change comprises: assigning pieces of the transaction data with the overlapping scope of data change in a same level I transaction subset; and assigning pieces of the transaction data with no overlapping scope of data change into different level I transaction subsets.
  • In one embodiment, the assigning the transaction data into transaction subsets further comprises: determining one or more level II transaction subsets for each of the one or more level I transaction subsets according to the transaction data's transaction type, each of the one or more level II transaction subsets being a subset under one of the one or more level I transaction subsets. Executing the transaction subsets in parallel comprises: executing a plurality of level II transaction subsets corresponding to the one or more level I transaction subsets in parallel. For example, the transaction data may be assigned into level I transaction subsets M and M, of which transaction data in subset M is assigned into two level II transaction subset M1 and M2, and transaction data in subset N is assigned into one level II transaction subset N1 (here level I transaction subset N is the same as the level II transaction subset N1). Then, level II transaction subsets M1, M2, and N1 can be executed in parallel.
  • In one embodiment, the determining one or more level II transaction subsets for each of the one or more level I transaction subsets according to the transaction data's transaction type comprises: assigning pieces of transaction data in each of the one or more level I subsets with the same transaction type in a same level II transaction subset; and assigning pieces of the transaction data in the each level I subset with different transaction types into different level II transaction subsets.
  • In one embodiment, the determining one or more level II transaction subsets for each of the one or more level I transaction subsets according to the transaction data's transaction type comprises: traversing a transaction type of each piece of transaction data in a first level I transaction subset; in response to that a transaction type of a second piece of transaction data is the same as a transaction type of one or more pieces of transaction data of a first level II transaction subset, adding the second piece of transaction data into the first level II transaction subset; and in response to that the transaction type of the second piece of transaction data is different from the transaction type of all pieces of transaction data of the first level II transaction subset, creating a second level II transaction subset and adding the second piece of transaction data into the second level II transaction subset.
  • After the above-described implementation process is used for division of transaction subsets, the transaction subsets may be executed in parallel to complete the execution process of blockchain transaction data to write the execution result into the blockchain. As shown in FIG. 4, a transaction data arranging module is configured to achieve division of transaction subsets. A transaction data execution cluster executes transaction data in different transaction subsets in parallel, executes transaction data inside a transaction subset in series according to timestamps corresponding to the transaction data, and then writes the execution result into the blockchain, thereby ensuring the consistency in the blockchain database state, reducing the cost required for improving the execution efficiency of data processing, and improving expandability. When the execution result is written into a block of the blockchain, the results of execution of transaction data by the transaction data execution cluster may be summarized and then written into the blockchain. In one example, one designated computer in the cluster may complete the summarization of execution results.
  • In the current technologies, take the Ethereum application as an example, transaction data is sorted according to received timestamps of the transaction data when the transaction data is executed, and then the execution is performed in series in the temporal order to update account information after each piece of transaction data is executed. In the embodiments of the present specification, after transaction data to be written into a blockchain (i.e., the transaction data received by the blockchain) is obtained, the transaction data is classified first according to transaction types and/or scopes of data change to form transaction subsets, causing transaction data without a transaction dependency relationship to be divided into different transaction subsets and transaction data with a transaction dependency relationship to be put into the same transaction subset. The division of transaction data and determination of transaction subsets may be implemented by the transaction data arranging module shown in FIG. 4. After the transaction data arranging module completes the division of transaction data, the transaction data arranging module may distribute the transaction subsets to computers in the transaction data execution cluster for data processing. Each computer in the transaction data execution cluster only executes transaction data in an allocated transaction subset, follows the process of verification-implementation-recording in a blockchain to write an execution result into the blockchain. In an exemplary implementation, the transaction data arranging module and the transaction data execution cluster may also be, for example, jointly a transaction execution cluster to implement functions of reception, classification, distribution, and execution of transaction data, summarize execution results of transaction data, and to write the summarized execution results into the blockchain.
  • The embodiments of the present specification further provide another method for writing transaction data into a blockchain, comprising: obtaining a plurality of pieces of transaction data to be executed; determining first transaction data without a transaction dependency relationship according to scopes of data change of the transaction data, wherein there is no transaction dependency relationship among the first transaction data; and executing the first transaction data in parallel, and writing an execution result into the blockchain.
  • In one example, when the first transaction data is determined, transaction data with a scope of data change not overlapping another scope of data change of any other piece of transaction data may be determined as the first transaction data having no transaction dependency relationship according to scopes of data change of the transaction data.
  • Assuming that the obtained plurality of pieces of transaction data are as follows:
  • Data Transaction Scope of
    No. type data change Remarks
    1 Contract ID A The execution will change data of
    ID A
    2 Contract ID A The execution will change data of
    ID A
    3 Contract ID B The execution will change data of
    ID B
    4 Contract ID C The execution will change data of
    ID C
    5 Transfer Account X, The execution will change data of
    Account Y Account X and Account Y
    6 Transfer Account Z, The execution will change data of
    Account D Account Z and Account D
    7 Transfer Account X, The execution will change data of
    Account M Account X and Account M
    8 Transfer Account N, The execution will change data of
    Account L Account N and Account L
  • According to scopes of data change of the transaction data, in some embodiments, the scopes of data change of the transaction data 3, 4, 6, and 8 do not overlap with a scope of data change of any other transaction data. Therefore, the order of execution of these pieces of transaction data does not affect the consistency in the database state. As a result, the parallel execution of these pieces of transaction data favors improving the execution efficiency of data processing, thereby reducing the cost required for improving the execution efficiency of data processing and improving expandability.
  • As shown in FIG. 5, an apparatus for writing transaction data into a blockchain according to the present specification may comprise: an obtaining module 101 configured to obtain transaction data to be added into the blockchain; a transaction subset determining module 102 configured to assign the transaction data into transaction subsets, wherein pieces of the transaction data having at least one of: a same transaction type or an overlapping scope of data change are assigned into a same transaction subset, and pieces of the transaction data with different transaction types and with no overlapping scope of data change are assigned into different transaction subsets; and a data executing module 103 configured to execute the transaction subsets in parallel and store results of the execution into the blockchain.
  • In some embodiments, the various modules and units of the apparatus for writing transaction data into a blockchain may be implemented as software instructions (or a combination of software and hardware). That is, the apparatus for writing transaction data into a blockchain described with reference to FIG. 5 may comprise a processor (e.g., the CPU) and a non-transitory computer-readable storage medium (e.g., the memory) storing instructions that, when executed by the processor, cause one or more components (e.g., the processor) of the apparatus to perform various steps and methods of the modules and units described above. The apparatus for writing transaction data into a blockchain may also be referred to as a system for writing transaction data into a blockchain. In some embodiments, the apparatus for writing transaction data into a blockchain may include a mobile phone, a tablet computer, a PC, a laptop computer, or another computing device.
  • In some embodiments, an apparatus corresponding to the method for writing transaction data into a blockchain in the above embodiments is disclosed. All descriptions of the above embodiments are applicable here, which will not be elaborated here.
  • The present specification further provides a method for determining a transaction subset of blockchain transaction data. Transaction data may be divided using this method, causing transaction data without a transaction dependency relationship to be executed in parallel, thereby reducing the cost required for improving the execution efficiency of data processing and improving expandability. The method comprises: after a plurality of pieces of transaction data to be executed are obtained, transaction subsets to which the transaction data belongs are determined according to transaction types and/or scopes of data change of the transaction data, for executing the transaction subsets in parallel, wherein there is no transaction dependency relationship among transaction data belonging to different transaction subsets.
  • In one example, the determining transaction subsets to which the transaction data belongs according to transaction types and/or scopes of data change of the transaction data may comprise: determining the transaction subsets to which the transaction data belongs according to a data attribute of the transaction data, wherein the data attribute has a corresponding relationship with a transaction type and/or a scope of data change of the transaction data, and the data attribute represents a transaction dependency relationship of the transaction data.
  • Furthermore, the determining transaction subsets to which the transaction data belongs according to transaction types of the transaction data may comprise: according to the transaction types of the transaction data, putting transaction data of the same transaction type into the same transaction subset, and dividing transaction data of different transaction types into different transaction subsets.
  • The determining transaction subsets to which the transaction data belongs according to scopes of data change of the transaction data may comprise: according to the scopes of data change of the transaction data, putting transaction data having overlapping scopes of data change into the same transaction subset, and dividing transaction data having scopes of data change that do not overlap into the different transaction subsets.
  • The determining transaction subsets to which the transaction data belongs according to transaction types and scopes of data change of the transaction data may further comprise: determining a level I subset to which the transaction data belongs according to the transaction types of the transaction data; and determining a level II subset to which the transaction data belongs according to the scopes of data change of the transaction data in the level I subset, and using the level II subset as the transaction subset, wherein the level II subset is a subset of the level I subset.
  • Detailed implementation corresponds to the step S102 in the above embodiments, and all relevant descriptions the above embodiments are applicable here, which will not be elaborated here.
  • One of ordinary skill in the art should understand that the embodiments of the present specification may be provided as a method, a system, or a computer program product. Therefore, the present specification may be implemented as a complete hardware embodiment, a complete software embodiment, or an embodiment combining software and hardware. Moreover, the present embodiments may be in the form of a computer program product implemented on one or more computer usable storage media (including, but not limited to, a magnetic disk memory, CD-ROM, an optical memory, etc.) comprising computer usable program codes.
  • The present specification is described with reference to flowcharts and/or block diagrams of the method, device (system), and computer program product according to the embodiments of the present specification. It should be understood that a computer program instruction may be used to implement each process and/or block in the flowcharts and/or block diagrams and a combination of processes and/or blocks in the flowcharts and/or block diagrams. These computer program instructions may be provided for a general-purpose computer, a special-purpose computer, an embedded processor, or a processor of other programmable data processing devices to generate a machine, causing the instructions executed by a computer or a processor of other programmable data processing devices to generate an apparatus for implementing a function specified in one or more processes in the flowcharts and/or in one or more blocks in the block diagrams.
  • These computer program instructions may also be stored in a computer readable memory that can instruct a computer or other programmable data processing devices to work in a particular manner, causing the instructions stored in the computer readable memory to generate a manufactured article that includes an instruction apparatus. The instruction apparatus implements a function specified in one or more processes in the flowcharts and/or in one or more blocks in the block diagrams.
  • These computer program instructions may also be loaded onto a computer or other programmable data processing devices, causing a series of operational steps to be performed on the computer or other programmable devices, thereby generating computer-implemented processing. Therefore, the instructions executed on the computer or other programmable devices provide steps for implementing a function specified in one or more processes in the flowcharts and/or in one or more blocks in the block diagrams.
  • In a typical configuration, the computation device includes one or more processors (CPUs), input/output interfaces, network interfaces, and a memory.
  • The memory may include computer readable media, such as a volatile memory, a Random Access Memory (RAM), and/or a non-volatile memory, e.g., a Read-Only Memory (ROM) or a flash memory (flash RAM). The memory is an example of a computer readable medium.
  • Computer readable media include permanent, volatile, mobile, and immobile media, which can implement information storage through any method or technology. The information may be computer readable instructions, data structures, program modules, or other data. Examples of storage media of computers include, but are not limited to, Phase-change Random Access Memories (PRAMs), Static Random Access Memories (SRAMs), Dynamic Random Access Memories (DRA Ms), other types of Random Access Memories (RA Ms), Read-Only Memories (ROMs), Electrically Erasable Programmable Read-Only Memories (EEPROMs), flash memories or other memory technologies, Compact Disk Read-Only Memories (CD-ROMs), Digital Versatile Discs (DVDs) or other optical memories, cassettes, cassette and disk memories or other magnetic memory devices, or any other non-transmission media, which can be used for storing information accessible to a computation device. According to the definitions in the specification, the computer readable media do not include transitory media (transitory media), such as modulated data signals and carriers.
  • The terms of “including,” “comprising,” or any other variants of the terms are intended to encompass a non-exclusive inclusion, causing a process, method, commodity, or device comprising a series of elements to not only comprise these elements, but also comprise other elements that are not listed, or further comprise elements that are inherent to the process, method, commodity, or device. When there is no further restriction, elements defined by the statement “comprising one . . . ” does not exclude a process, method, commodity, or device comprising the above elements from further comprising additional identical elements.
  • One of ordinary skill in the art should understand that the embodiments of the present specification may be provided as a method, a system, or a computer program product. Therefore, the present specification may be implemented as a complete hardware embodiment, a complete software embodiment, or an embodiment combining software and hardware. Moreover, the present specification may be in the form of a computer program product implemented on one or more computer usable storage media (including, but not limited to, a magnetic disk memory, CD-ROM, an optical memory, etc.) comprising computer usable program codes.
  • The above-described are mere embodiments of the present specification, which are not used to limit the present specification. To one of ordinary skill in the art, the present specification may have various modifications and changes. Any modification, equivalent substitution, or improvement made within the spirit and principle of the present specification shall be encompassed by the claims of the present specification.

Claims (20)

What is claimed is:
1. A method for adding transaction data into a blockchain, comprising:
obtaining a plurality of pieces of transaction data to be added into the blockchain;
assigning the plurality of pieces of transaction data with a same first data attribute into a level I transaction subset;
assigning transaction data that is assigned under the level I transaction subset into one or more level II transaction subsets according to a second data attribute, wherein pieces of transaction data with a matching second data attributes are assigned in a same level II transaction subset, and pieces of the transaction data without matching second data attributes are assigned into different level II transaction subsets; and
executing the one or more level II transaction subsets in parallel, and storing results of the execution into the blockchain.
2. The method according to claim 1, wherein the executing the one or more one or more level II transaction subsets in parallel comprises:
executing at least a portion of the plurality of pieces of transaction data assigned in the different level II transaction subsets in parallel using multithreading or a machine cluster.
3. The method according to claim 1, wherein:
each piece of the plurality of pieces of transaction data corresponds to a timestamp; and
the executing the one or more level II transaction subsets in parallel comprises: executing at least a portion of the plurality of pieces of transaction data assigned in the same level II transaction subset in series according to a temporal order corresponding to the timestamps.
4. The method according to claim 1, wherein the first data attribute is a transaction type and the second data attribute is a range of data change.
5. The method according to claim 4, wherein assigning the transaction data that is assigned under the level I transaction subset into one or more level II transaction subsets according to a second data attribute comprises:
assigning pieces of transaction data in the level I subset with the overlapping range of data change in a same level II transaction subset; and
assigning pieces of the transaction data in the level I subset with no overlapping range of data change into different level II transaction subsets.
6. The method according to claim 4, wherein assigning the transaction data that is assigned under the level I transaction subset into one or more level II transaction subsets according to a second data attribute comprises:
traversing the range of data change of each piece of transaction data in the level I transaction sub set;
in response to that a range of data change of a second piece of transaction data overlaps with a range of data change of a first level II transaction subset, adding the second piece of transaction data into the first level II transaction subset; and
in response to that the range of data change of the second piece of transaction data does not overlap with the range of data change of the first level II transaction subset, creating a second level II transaction subset and adding the second piece of transaction data into the second level II transaction subset.
7. The method according to claim 1, wherein the first data attribute is a range of data change and the second data attribute is a transaction type.
8. The method according to claim 7, wherein assigning the transaction data that is assigned under the level I transaction subset into one or more level II transaction subsets according to a second data attribute comprises:
assigning pieces of transaction data in the level I subset with the same transaction type in a same level II transaction subset; and
assigning pieces of the transaction data in the level I subset with different transaction types into different level II transaction subsets.
9. The method according to claim 7, wherein assigning the transaction data that is assigned under the level I transaction subset into one or more level II transaction subsets according to a second data attribute comprises:
traversing a transaction type of each piece of transaction data in a the level I transaction sub set;
in response to that a transaction type of a second piece of transaction data is the same as a transaction type of one or more pieces of transaction data of a first level II transaction subset, adding the second piece of transaction data into the first level II transaction subset; and
in response to that the transaction type of the second piece of transaction data is different from the transaction type of all pieces of transaction data of the first level II transaction subset, creating a second level II transaction subset and adding the second piece of transaction data into the second level II transaction subset.
10. A system for adding transaction data into a blockchain, comprising one or more processors and one or more non-transitory computer-readable memories coupled to the one or more processors and configured with instructions executable by the one or more processors to cause the system to perform operations comprising:
obtaining a plurality of pieces of transaction data to be added into the blockchain;
assigning the plurality of pieces of transaction data with a same first data attribute into a level I transaction subset;
assigning transaction data that is assigned under the level I transaction subset into one or more level II transaction subsets according to a second data attribute, wherein pieces of transaction data with a matching second data attributes are assigned in a same level II transaction subset, and pieces of the transaction data without matching second data attributes are assigned into different level II transaction subsets; and
executing the one or more level II transaction subsets in parallel, and storing results of the execution into the blockchain.
11. The system according to claim 10, wherein the executing the one or more one or more level II transaction subsets in parallel comprises:
executing at least a portion of the plurality of pieces of transaction data assigned in the different level II transaction subsets in parallel using multithreading or a machine cluster.
12. The system according to claim 10, wherein:
each piece of the plurality of pieces of transaction data corresponds to a timestamp; and
the executing the one or more level II transaction subsets in parallel comprises: executing at least a portion of the plurality of pieces of transaction data assigned in the same level II transaction subset in series according to a temporal order corresponding to the timestamps.
13. The system according to claim 10, wherein the first data attribute is a transaction type and the second data attribute is a range of data change.
14. The system according to claim 13, wherein assigning the transaction data that is assigned under the level I transaction subset into one or more level II transaction subsets according to a second data attribute comprises:
assigning pieces of transaction data in the level I subset with the overlapping range of data change in a same level II transaction subset; and
assigning pieces of the transaction data in the level I subset with no overlapping range of data change into different level II transaction subsets.
15. The system according to claim 13, wherein assigning the transaction data that is assigned under the level I transaction subset into one or more level II transaction subsets according to a second data attribute comprises:
traversing the range of data change of each piece of transaction data in the level I transaction sub set;
in response to that a range of data change of a second piece of transaction data overlaps with a range of data change of a first level II transaction subset, adding the second piece of transaction data into the first level II transaction subset; and
in response to that the range of data change of the second piece of transaction data does not overlap with the range of data change of the first level II transaction subset, creating a second level II transaction subset and adding the second piece of transaction data into the second level II transaction subset.
16. The system according to claim 10, wherein the first data attribute is a range of data change and the second data attribute is a transaction type.
17. A non-transitory computer-readable storage medium configured with instructions executable by one or more processors to cause the one or more processors to perform operations comprising:
obtaining a plurality of pieces of transaction data to be added into the blockchain;
assigning the plurality of pieces of transaction data with a same first data attribute into a level I transaction subset;
assigning transaction data that is assigned under the level I transaction subset into one or more level II transaction subsets according to a second data attribute, wherein pieces of transaction data with a matching second data attributes are assigned in a same level II transaction subset, and pieces of the transaction data without matching second data attributes are assigned into different level II transaction subsets; and
executing the one or more level II transaction subsets in parallel, and storing results of the execution into the blockchain.
18. The non-transitory computer-readable storage medium according to claim 17, wherein the executing the one or more one or more level II transaction subsets in parallel comprises:
executing at least a portion of the plurality of pieces of transaction data assigned in the different level II transaction subsets in parallel using multithreading or a machine cluster.
19. The non-transitory computer-readable storage medium according to claim 17, wherein:
each piece of the plurality of pieces of transaction data corresponds to a timestamp; and
the executing the one or more level II transaction subsets in parallel comprises: executing at least a portion of the plurality of pieces of transaction data assigned in the same level II transaction subset in series according to a temporal order corresponding to the timestamps.
20. The non-transitory computer-readable storage medium according to claim 17, wherein the first data attribute is a transaction type and the second data attribute is a range of data change.
US16/745,519 2017-02-28 2020-01-17 Method and apparatus for writing service data into block chain and method for determining service subset Active US10664305B1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US16/745,519 US10664305B1 (en) 2017-02-28 2020-01-17 Method and apparatus for writing service data into block chain and method for determining service subset

Applications Claiming Priority (6)

Application Number Priority Date Filing Date Title
CN201710116539 2017-02-28
CN201710116539.7 2017-02-28
CN201710116539.7A CN106980649B (en) 2017-02-28 2017-02-28 Method and device for writing block chain service data and service subset determining method
PCT/CN2018/077286 WO2018157778A1 (en) 2017-02-28 2018-02-26 Method and apparatus for writing service data into block chain and method for determining service subset
US16/535,035 US10642643B2 (en) 2017-02-28 2019-08-07 Method and apparatus for writing service data into block chain and method for determining service subset
US16/745,519 US10664305B1 (en) 2017-02-28 2020-01-17 Method and apparatus for writing service data into block chain and method for determining service subset

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US16/535,035 Continuation US10642643B2 (en) 2017-02-28 2019-08-07 Method and apparatus for writing service data into block chain and method for determining service subset

Publications (2)

Publication Number Publication Date
US20200150999A1 true US20200150999A1 (en) 2020-05-14
US10664305B1 US10664305B1 (en) 2020-05-26

Family

ID=59339366

Family Applications (2)

Application Number Title Priority Date Filing Date
US16/535,035 Active US10642643B2 (en) 2017-02-28 2019-08-07 Method and apparatus for writing service data into block chain and method for determining service subset
US16/745,519 Active US10664305B1 (en) 2017-02-28 2020-01-17 Method and apparatus for writing service data into block chain and method for determining service subset

Family Applications Before (1)

Application Number Title Priority Date Filing Date
US16/535,035 Active US10642643B2 (en) 2017-02-28 2019-08-07 Method and apparatus for writing service data into block chain and method for determining service subset

Country Status (16)

Country Link
US (2) US10642643B2 (en)
EP (1) EP3561700A4 (en)
JP (1) JP6928104B2 (en)
KR (1) KR102103130B1 (en)
CN (1) CN106980649B (en)
AU (2) AU2018228540B2 (en)
BR (1) BR112019017863A2 (en)
CA (1) CA3054813C (en)
MX (1) MX2019009728A (en)
MY (1) MY197445A (en)
PH (1) PH12019501795A1 (en)
RU (1) RU2744585C2 (en)
SG (1) SG11201907212SA (en)
TW (1) TWI660281B (en)
WO (1) WO2018157778A1 (en)
ZA (1) ZA201904916B (en)

Families Citing this family (55)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN106980649B (en) 2017-02-28 2020-07-10 创新先进技术有限公司 Method and device for writing block chain service data and service subset determining method
GB201707296D0 (en) * 2017-05-08 2017-06-21 Nchain Holdings Ltd Computer-implemented system and method
CN107423124A (en) * 2017-07-27 2017-12-01 中链科技有限公司 A kind of method for being used to carry out transaction data parallel processing
CN107729137B (en) * 2017-09-04 2021-06-22 深圳壹账通智能科技有限公司 Server, block chain signature verification decryption method and storage medium
CN107678865A (en) * 2017-09-20 2018-02-09 中国银行股份有限公司 The verification method and system of block chain based on transaction packet
CN107786642B (en) * 2017-09-30 2020-04-17 上海数据交易中心有限公司 Block chain construction method and device for data circulation, storage medium and server
CN107734021B (en) 2017-09-30 2020-04-07 深圳壹账通智能科技有限公司 Block chain data uploading method and system, computer system and storage medium
CN107833060B (en) * 2017-11-13 2020-12-25 中国银行股份有限公司 Verification method and system for intelligent contract transaction in block chain
CN108322309B (en) * 2017-12-27 2019-10-11 北京欧链科技有限公司 Transaction processing method and device based on block chain
CN108513669A (en) * 2017-12-29 2018-09-07 深圳前海达闼云端智能科技有限公司 Crowd funding information processing method and device based on block chain, storage medium and electronic equipment
CN110083437A (en) * 2018-01-25 2019-08-02 北京欧链科技有限公司 Handle the method and device of block chain affairs
CN108471510A (en) * 2018-01-29 2018-08-31 东莞理工学院 A kind of vision operation record protection method and system based on block chain
CN108564470B (en) * 2018-04-17 2021-09-28 北京天德科技有限公司 Transaction distribution method for parallel building blocks in block chain
CN108958925B (en) * 2018-04-26 2023-06-20 武汉龙津科技有限公司 Energy-saving workload proving method and system
CN108768994B (en) * 2018-05-22 2021-07-27 北京小米移动软件有限公司 Data matching method and device and computer readable storage medium
JP7063142B2 (en) * 2018-06-25 2022-05-09 日本電信電話株式会社 Number management system, number management method and number management device
CN109087097B (en) * 2018-07-26 2020-11-03 京东数字科技控股有限公司 Method and device for updating same identifier of chain code
CN109191295A (en) * 2018-08-15 2019-01-11 深圳市元征科技股份有限公司 A kind of information processing method and its equipment
CN109325366B (en) * 2018-08-22 2022-08-12 深圳前海微众银行股份有限公司 Service processing method and device based on alliance chain and computer readable storage medium
US10860659B1 (en) * 2018-09-06 2020-12-08 Amazon Technologies, Inc. Distributed verification of digital work product
TWI698100B (en) * 2018-09-18 2020-07-01 柯賓漢數位金融科技有限公司 Method for generating and integrating multiple blockchains and blockchain system
CN109493211A (en) * 2018-09-27 2019-03-19 深圳壹账通智能科技有限公司 Credit date storage method, device, equipment and storage medium based on block chain
CN109088722B (en) * 2018-10-08 2021-10-19 深圳投时科技有限公司 Block chain node evolution method and block chain node
CN109299195A (en) * 2018-10-23 2019-02-01 杭州能链科技有限公司 Data processing method, device and storage medium
CN109598598B (en) * 2018-10-25 2020-05-12 阿里巴巴集团控股有限公司 Transaction processing method and device based on block chain and electronic equipment
WO2019072283A2 (en) * 2018-11-27 2019-04-18 Alibaba Group Holding Limited System and method for improving security of smart contract on blockchain
US11138597B2 (en) 2018-11-27 2021-10-05 Advanced New Technologies Co., Ltd. System and method for improving security of smart contract on blockchain
CN111291018B (en) * 2018-12-07 2023-06-23 北京沃东天骏信息技术有限公司 Data management method, device, equipment and storage medium
CN109766727B (en) * 2018-12-25 2021-04-06 苏州朗润创新知识产权运营有限公司 Intelligent block network construction method and system
PL3566391T3 (en) * 2018-12-28 2021-10-18 Advanced New Technologies Co., Ltd. Parallel execution of transactions in a blockchain network based on smart contract whitelists
WO2019072303A2 (en) * 2018-12-28 2019-04-18 Alibaba Group Holding Limited Parallel execution of transactions in a blockchain network
KR102151903B1 (en) * 2018-12-29 2020-09-03 알리바바 그룹 홀딩 리미티드 Blockchain-based crowdsourcing of map applications
SG11201908556UA (en) 2019-03-04 2019-10-30 Alibaba Group Holding Ltd Methods and devices for providing transaction data to blockchain system for processing
EP3610450A4 (en) * 2019-03-28 2020-06-10 Alibaba Group Holding Limited System and method for parallel-processing blockchain transactions
EP3619668B1 (en) 2019-04-12 2023-12-20 Advanced New Technologies Co., Ltd. Performing parallel execution of transactions in a distributed ledger system
EP3619667A4 (en) 2019-04-12 2020-05-06 Alibaba Group Holding Limited Performing parallel execution of transactions in a distributed ledger system
EP3625746A4 (en) * 2019-04-12 2020-05-06 Alibaba Group Holding Limited Performing parallel execution of transactions in a distributed ledger system
KR102118178B1 (en) * 2019-04-24 2020-06-02 주식회사 데이터젠 Multiple transaction parallel processing method and system for blockchain
CN110209671A (en) * 2019-05-17 2019-09-06 无锡朝阳供应链科技股份有限公司 A kind of the access system and its application of distribution account book data
CN112001713B (en) * 2019-05-27 2024-03-29 深圳市红砖坊技术有限公司 Block chain system and request processing method and device
US11249985B2 (en) * 2019-06-15 2022-02-15 Facebook, Inc. Scalable, secure, efficient, and adaptable distributed digital ledger transaction network
US11126593B2 (en) 2019-06-15 2021-09-21 Facebook, Inc. Scalable, secure, efficient, and adaptable distributed digital ledger transaction network
US11249947B2 (en) 2019-06-15 2022-02-15 Facebook, Inc. Distributed digital ledger transaction network for flexible, lazy deletion of data stored within an authenticated data structure
US11405204B2 (en) 2019-06-15 2022-08-02 Meta Platforms, Inc Scalable, secure, efficient, and adaptable distributed digital ledger transaction network
EP4071649A1 (en) * 2019-06-15 2022-10-12 Meta Platforms, Inc. Scalable, secure, efficient, and adaptable distributed digital ledger transaction network
CN110570311B (en) * 2019-09-17 2021-05-25 北京海益同展信息科技有限公司 Block chain consensus method, device and equipment
CN110659308B (en) * 2019-09-24 2020-12-22 华润网络(深圳)有限公司 Data clearing processing method and device
CN110728578A (en) * 2019-09-29 2020-01-24 南京金宁汇科技有限公司 Parallel execution method, system and storage medium for block chain transaction
CN110806923B (en) * 2019-10-29 2023-02-24 百度在线网络技术(北京)有限公司 Parallel processing method and device for block chain tasks, electronic equipment and medium
CN111126978B (en) * 2019-12-28 2023-03-14 飞天诚信科技股份有限公司 Method and device for realizing rapid transaction processing on block chain
US11682095B2 (en) 2020-02-25 2023-06-20 Mark Coast Methods and apparatus for performing agricultural transactions
KR102461553B1 (en) * 2020-02-28 2022-11-01 주식회사 시큐어링크 Layer Blockchain System for Large Information Sharing
CN111405037A (en) * 2020-03-13 2020-07-10 杭州复杂美科技有限公司 Block synchronization method, device and storage medium
KR102315226B1 (en) * 2020-03-16 2021-10-20 이정우 Block chain system based on consensus algorithm of proof-of-rule and method thereof
CN112508574A (en) * 2021-02-03 2021-03-16 北京全息智信科技有限公司 Block chain parallel transaction execution method and device and electronic equipment

Family Cites Families (33)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10002019B2 (en) * 2009-05-11 2018-06-19 International Business Machines Corporation System and method for assigning a transaction to a serialized execution group based on an execution group limit for parallel processing with other execution groups
RU2554509C2 (en) * 2010-10-06 2015-06-27 Александр Яковлевич Богданов System and method of distributed computations
US8856283B2 (en) * 2011-06-03 2014-10-07 Apple Inc. Playlists for real-time or near real-time streaming
US8688661B2 (en) * 2012-06-15 2014-04-01 International Business Machines Corporation Transactional processing
US20150379510A1 (en) * 2012-07-10 2015-12-31 Stanley Benjamin Smith Method and system to use a block chain infrastructure and Smart Contracts to monetize data transactions involving changes to data included into a data supply chain.
US9553982B2 (en) 2013-07-06 2017-01-24 Newvoicemedia, Ltd. System and methods for tamper proof interaction recording and timestamping
US11126627B2 (en) 2014-01-14 2021-09-21 Change Healthcare Holdings, Llc System and method for dynamic transactional data streaming
EP2961168A1 (en) * 2014-06-27 2015-12-30 Thomson Licensing Method and apparatus for predicting image samples for encoding or decoding
TWI528217B (en) * 2014-07-02 2016-04-01 柯呈翰 A method and system for adding dynamic labels to a file and encrypting the file
US9594644B2 (en) * 2014-09-19 2017-03-14 Sybase, Inc. Converting a serial transaction schedule to a parallel transaction schedule
US9967333B2 (en) 2015-03-02 2018-05-08 Dell Products Lp Deferred configuration or instruction execution using a secure distributed transaction ledger
US9967334B2 (en) 2015-03-02 2018-05-08 Dell Products Lp Computing device configuration and management using a secure decentralized transaction ledger
US10812274B2 (en) * 2015-05-07 2020-10-20 Blockstream Corporation Transferring ledger assets between blockchains via pegged sidechains
CN108701325B (en) 2015-12-21 2022-11-22 星茶瓦公司 Self-adjusting transaction system and method therefor
US10255108B2 (en) * 2016-01-26 2019-04-09 International Business Machines Corporation Parallel execution of blockchain transactions
US10108812B2 (en) 2016-01-28 2018-10-23 Nasdaq, Inc. Systems and methods for securing and disseminating time sensitive information using a blockchain
WO2017136643A1 (en) 2016-02-03 2017-08-10 Luther Systems System and method for secure management of digital contracts
SG11201806404SA (en) 2016-02-04 2018-08-30 Nasdaq Tech Ab Systems and methods for storing and sharing transactional data using distributed computer systems
US10129238B2 (en) 2016-02-10 2018-11-13 Bank Of America Corporation System for control of secure access and communication with different process data networks with separate security features
US10142312B2 (en) 2016-02-22 2018-11-27 Bank Of America Corporation System for establishing secure access for users in a process data network
US20170264428A1 (en) 2016-03-08 2017-09-14 Manifold Technology, Inc. Data storage system with blockchain technology
CN105893042A (en) * 2016-03-31 2016-08-24 北京航空航天大学 Intelligent contract implementation method based on block chain
AU2017240796A1 (en) 2016-03-31 2018-10-25 Clause, Inc. System and method for creating and executing data-driven legal contracts
CA3019642C (en) 2016-04-01 2023-03-07 Jpmorgan Chase Bank, N.A. Systems and methods for providing data privacy in a private distributed ledger
GB201607476D0 (en) 2016-04-29 2016-06-15 Eitc Holdings Ltd Operating system for blockchain IOT devices
CN109314635A (en) 2016-05-09 2019-02-05 诺基亚技术有限公司 Resource management based on block chain
GB201611698D0 (en) 2016-07-05 2016-08-17 Eitc Holdings Ltd Blockchain-implemented control method and system
EP3472779A4 (en) 2016-07-14 2020-01-08 Digital Asset Holdings, LLC Digital asset platform
CN106330431A (en) * 2016-08-29 2017-01-11 北京瑞卓喜投科技发展有限公司 Data processing method, apparatus and system based on block chain technology
CN106406896B (en) * 2016-09-27 2020-03-17 北京天德科技有限公司 Block chain block building method based on parallel Pipeline technology
CN106682984B (en) * 2016-10-27 2019-09-10 深圳壹账通智能科技有限公司 Transaction business process method and system based on block chain
CN108427601A (en) * 2017-02-13 2018-08-21 北京航空航天大学 A kind of cluster transaction processing method of privately owned chain node
CN106980649B (en) * 2017-02-28 2020-07-10 创新先进技术有限公司 Method and device for writing block chain service data and service subset determining method

Also Published As

Publication number Publication date
US20190361731A1 (en) 2019-11-28
EP3561700A1 (en) 2019-10-30
US10642643B2 (en) 2020-05-05
RU2019124224A (en) 2021-02-01
EP3561700A4 (en) 2020-01-15
AU2018228540A1 (en) 2019-08-22
CN106980649A (en) 2017-07-25
SG11201907212SA (en) 2019-09-27
RU2019124224A3 (en) 2021-02-01
AU2019101606A4 (en) 2020-01-23
CA3054813A1 (en) 2018-09-07
MX2019009728A (en) 2019-10-22
WO2018157778A1 (en) 2018-09-07
JP2020509495A (en) 2020-03-26
BR112019017863A2 (en) 2020-05-12
KR102103130B1 (en) 2020-04-22
CN106980649B (en) 2020-07-10
TW201833796A (en) 2018-09-16
MY197445A (en) 2023-06-19
AU2018228540B2 (en) 2020-09-03
JP6928104B2 (en) 2021-09-01
PH12019501795A1 (en) 2020-03-09
ZA201904916B (en) 2020-08-26
KR20190099087A (en) 2019-08-23
US10664305B1 (en) 2020-05-26
CA3054813C (en) 2021-04-20
TWI660281B (en) 2019-05-21
RU2744585C2 (en) 2021-03-11

Similar Documents

Publication Publication Date Title
US10664305B1 (en) Method and apparatus for writing service data into block chain and method for determining service subset
US10698885B2 (en) Method and device for writing service data in block chain system
CN105718455B (en) A kind of data query method and device
JP6498767B2 (en) System for efficient processing of transaction requests related to database accounts
CN108846749B (en) Partitioned transaction execution system and method based on block chain technology
WO2020015533A1 (en) Transaction processing method and apparatus, and blockchain system
WO2021051782A1 (en) Consensus method, apparatus and device of block chain
US20210311916A1 (en) Blockchain-based hierarchical data storage
EP3961461A1 (en) Method and apparatus for obtaining number for transaction-accessed variable in blockchain in parallel
US20210056088A1 (en) Blockchain based hierarchical data storage
CN104598567A (en) Data statistics and de-duplication method based on Hadoop MapReduce programming frame
WO2021115002A1 (en) Method and apparatus for processing blockchain transaction record
US20210149746A1 (en) Method, System, Computer Readable Medium, and Device for Scheduling Computational Operation Based on Graph Data
US11669358B2 (en) Virtual network functions allocation in a datacenter
CN105072047A (en) Message transmitting and processing method
US20240078222A1 (en) Selective Addition of Datum to a Tree Data Structure
CN117573368A (en) Spark calculation scheduling method, device, electronic equipment and medium
CN116881361A (en) Transaction execution method, node and blockchain system

Legal Events

Date Code Title Description
FEPP Fee payment procedure

Free format text: ENTITY STATUS SET TO UNDISCOUNTED (ORIGINAL EVENT CODE: BIG.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

STCF Information on status: patent grant

Free format text: PATENTED CASE

AS Assignment

Owner name: ADVANTAGEOUS NEW TECHNOLOGIES CO., LTD., CAYMAN ISLANDS

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:ALIBABA GROUP HOLDING LIMITED;REEL/FRAME:053702/0392

Effective date: 20200826

AS Assignment

Owner name: ADVANCED NEW TECHNOLOGIES CO., LTD., CAYMAN ISLANDS

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:ADVANTAGEOUS NEW TECHNOLOGIES CO., LTD.;REEL/FRAME:053796/0281

Effective date: 20200910

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 4TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1551); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 4