The embodiment discussed herein is related to a transaction management device, non transitory computer readable recording medium having stored therein a transaction management program, and a transaction management method.
Services using blockchain (Blockchain) techniques have been becoming popular in a wide variety of industries.
When a long-term operation of the blockchain is attempted, it is assumed that the amount of data increases due to accumulation of block information in each node, one of methods for solving the increase in the amount of data may be, for example, periodically migrating collective data of a blockchain to another system and restarting the blockchain at a migration source every time the blockchain is migrated.
A system at a migration destination includes a blockchain into which a hash value of each transaction data is registered and a database (DB; Database) into which each transaction data is registered.
When referring to the data in the system at the migration destination, by comparing reference data and the hash values registered into the blockchain, data tampering on the database can be detected. The reference data is, for example, the transaction data obtained by referring to (searching) the database. If the hash value obtained by performing hash operation on the reference data matches the hash value registered into the blockchain, the data in the database can be determined not to have been tampered with, and if not, the data in the database can be determined to nave been tampered with.
[Patent Document 1] Japanese National Publication of International Patent Application No. 2018-537022
[Patent Document 2] Japanese Laid-open Patent Publication No. 2018-147016
[Patent Document 3] International Publication Pamphlet No. WO 2017/170912
Since the system at the migration destination hashes each transaction data, tampering verification of data in the database is performed for each transaction, which results in poor processing efficiency, in addition, as compared with a case of hashing a lump size of data, hashing each transaction data results in poor compression efficiency of the capacity of the system at the migration destination. As such, regarding the tampering verification of transactions, processing efficiency of the verification and the compression efficiency of the hash data are poor.
According to an aspect of the embodiment, a transaction management device includes: a memory; and a processor coupled to the memory, the processor being configured to register, into a database, with respect to a first blockchain that stores a plurality of transactions with which first information and second information are associated, a plurality of pieces of the second information in the plurality of transactions in units of groups based on the first information; and register, into a second blockchain, hash values obtained by hashing the plurality of pieces of second information in the units of groups.
The object and advantages of the invention will be realized and attained by means of the elements and combinations particularly pointed out in the claims.
It is to be understood that both the foregoing general description and the following detailed description are exemplary and explanatory and are not restrictive of the invention, as claimed.
Hereinafter, an embodiment of the present invention will now be described with reference to the drawings. The embodiment described below is merely illustrative, and can be variously modified and implemented without departing from the scope thereof, in the drawings used for the following embodiment, the same reference symbols denote the same or similar parts, unless otherwise specified.
The data to be migrated is one or more blocks in the migration source blockchain 111, and the data after the migration is stored (held) into the migration source blockchain 112 as non-migrated blocks until the migration source blockchain 112 is restarted next time.
The migration source blockchain 112 is used for operations such as registering new data into the migration source system 110 and referring to non-migrated data. On the other hand, the migration destination system 120 is used for referring to the migrated data, in other words, archived data.
Hereinafter, the migration source blockchain 111 before the restart is sometimes referred to as a “previous blockchain 111”, and the migration source blockchain 112 used for operation after the restart is sometimes referred to as an “operational blockchain 112”.
The blockchain 121 includes one or more blocks connected in a chain as blocks 121a, 121b, 121c, . . . . One or more hash values of the transaction data are registered into each of the blocks 121a, 121b, and 121c. In the example of
The user obtains the hash values of the transaction data from the migration destination blockchain 121 by using each TxID obtained from the DB 122 as a key (see symbol (ii)). Then, by comparing each data (update history) obtained from the DB 122 and each hash value obtained from the blockchain 121 one by one, the user verifies data tampering on the DB 122 (see symbol (iii)). As such, by comparing the data registered into the DB 122 with the hash values registered into the blockchain 121, which are difficult to tamper, it is possible to perform tampering verification of the data that is registered into the DB 122 and that has a risk of tampering.
However, in the migration destination system 120 illustrated in
However, as in
In addition, after a migration process is performed, the user (client) is to be aware of (determine) which one of the migration source (operational) blockchain 112 and a combination of the DB 122 and the migration destination blockchain 121 has the transaction data to be referred to. However, it is difficult for the user to determine which one of the migration source system 110 and the migration destination system 120 the data to be referred to exists in.
In view of the above, one embodiment describes a method for achieving migration (archiving) of blockchain data so that the amount of data managed by a blockchain can be reduced and tampering verification can be efficiently performed.
The migration source blockchain 2 is an example of a first blockchain that stores multiple transactions with which keys and values are associated. Each of the “keys” may be a processing target of a transaction and is an example of first information. Each of the “values” may be a value of a key (e.g., an updated value), which is updated by a process of a transaction, and is an example of second information.
The transaction is a record of a transaction, and the data of the transaction stored in the migration source blockchain 2 can be called an update history of a key. The transaction may exclude the key and the value themselves, and the value may be calculated from a record of one or more transactions for the same key.
In order to eliminate the enlargement of the data in the migration source blockchain 2, which is to be accumulated by the operation, the one embodiment assumes an operation that migrates the data in the migration source blockchain 2 to the migration destination blockchain 3 and the migration destination DB 4, and that initializes the migration source blockchain 2. Into the migration source blockchain 2 after the initialization, part of the migrated data and information on the migration destination are registered in advance, and then, the operation is resumed. The migration source blockchain 2 after the initialization is an example of a third blockchain.
As illustrated in
The blockchain control unit 21 controls processes such as registration of and reference to transactions for the ledger 22. The blockchain control unit 21 may include a transceiving unit 21a. The transceiving unit 21a performs update on and reference to (obtainment from) the ledger 22, transmission and reception of data to and from the data migration unit 5, the data registration unit 6, and the data reference unit 7, and the like.
The ledger 22 includes a blockchain that connects and stores one or mere blocks. Each of the blocks may include one or more transactions. The ledger 22 may include a DB in a key-value format, which stores a value (value) in association with a unique key.
For example, in the ledger 22, the transceiving unit 21a may write execution histories of transactions on the blockchain and the latest state of the result of the execution of the transactions on the DB. The transactions may include timestamps. The timestamps can be obtained and added by known methods. The transactions stored into the ledger 22 may be hash values, non-hashed values or both. When the hash values of the transactions are stored into the blockchain, the ledger 22 may, for example, further store records of the transactions of the non-hashed values.
The migration destination blockchain 3 is one of migration destinations of transaction data from the migration source blockchain 2, and is an example of a second blockchain. As illustrated in
The blockchain control unit 31 controls processes such as registration of and reference to transactions for the ledger 32. The blockchain control unit 31 may include a transceiving unit 31a. The transceiving unit 31a performs update on and reference to (obtainment from) the ledger 32, transmission and reception of data to and from the data migration unit 5 and the data reference unit 7, and the like.
The ledger 32 includes a blockchain that connects and stores one or more blocks. Each of the blocks may include one or more transactions. The ledger 32 may include a DB in a key-value format, which stores a value (value) in association with a unique key.
For example, in the Ledger 32, the transceiving unit 31a may write execution histories of transactions on the blockchain and the latest state of the result of the execution of the transactions on the DB. The transaction may include timestamps. The timestamps can be obtained and added by known methods. The transactions stored into the ledger 32 may be hash values.
The migration destination DB 4 is one of the migration destinations of the transaction data from the migration source blockchain 2, and is an example of a database. As illustrated in
The DB control unit 41 controls processes such as registration of and reference to data for the DB 42. The DB control unit 41 may include a data transceiving unit 41a. The data transceiving unit 41a performs update on and reference to (obtainment from) the DB 42, transmission and reception of data to and from the data migration unit 5 and the data reference unit 7, and the like.
The DB 42 stores the update histories of the keys of the migration source blockchain 2 and the transaction IDs (TxIDs) registered into the migration destination blockchain 3. For example, in the DB 42, the data transceiving unit 41a may write the update histories of the keys and the TxIDs. The reason why the migration destination DB 4 is used instead of registering the data directly into the migration destination blockchain 3 is to reduce the amount of data.
The data migration unit 5, the data registration unit 6, and the data reference unit 7 may be executed as, for example, processes (a data migration process, a data registration process, and a data reference process, respectively) each of which is a unit of processing performed by a processor of a computer. Each process of the data migration unit 5, the data registration unit 6, and the data reference unit 7 may be executed by different computers, or multiple processes may be executed by a common computer. The computer may be referred to as an information processing device or a transaction management device.
The one embodiment, assumes that a wallet balance (value) of each customer is managed for each key in the migration source blockchain 2. Further, it is assumed that, in the migration destination blockchain 3, reading and writing of data migration information for the blockchain are defined by smart contracts or the likes, and time ranges can be specified when the data of the migration source and the migration destination are referred to. Furthermore, while the data is being migrated, it is assumed that the registration of and the reference to new data are unaccepted in the migration source blockchain 2.
The data migration unit 5 integrates the transaction data of the migration source blockchain 2 into units in which the same keys are updated by the transactions, and migrates the integrated data to the migration destination blockchain 3 and the migration destination DB 4.
As illustrated in
The blockchain communication unit 51 performs communication of data between the migration source blockchain 2 and the migration source blockchain 3, and includes a block acquisition unit 51a and a transaction transceiving unit 51b.
The block data process unit 52 generates the transaction data and the hash values of data migration based on the data received from the blockchain communication unit 51, and includes a data integration unit 52a and a data
The DB communication unit 53 performs communication of data with the migration destination DB 4, and includes a data transceiving unit 53a.
Hereinafter, the above-described functional blocks included in the data migration unit 5 will be explained in the description of the process by the data migration unit 5. The data migration unit 5 may illustratively execute processes of following (i) to (iv) (corresponding to symbols (i) to (iv) in
(i) The block acquisition unit 51a collectively obtains block information of the migration source blockchain 2, in other words, the transaction data, from the transceiving unit 21a of the migration source blockchain 2.
The block acquisition unit 51a transmits (outputs) the obtained block information to the data integration unit 52a.
The block acquisition unit 51a may, for example, obtain transaction data in the migration source blockchain 2 from the first (oldest) block to the last (latest) block in ascending chronological order, in other words, in registration order of each of the multiple transactions.
(ii) The data integration unit 52a divides all transaction data obtained in the above (i) into units of groups based on the keys, and integrates them as update history groups. Each of the groups may be, for example, formed by integrating multiple data (values) associated with the same key in accordance with a predetermined condition.
The predetermined condition may include the number of cases of values to be included in each of the groups being set as at least one of: a predetermined number of cases; a number in which the total data size of values to be included in each of the groups becomes a predetermined data size or less; and the number of cases to be included in a predetermined number of blocks. The predetermined number of cases, the predetermined data size, and the predetermined number (of blocks) can be set in advance.
As illustrated in
As an example, the update history groups 50a and 50b indicate that the update history of balance of customer A is in the order of 100 yen, 200 yen, 300 yen, 400 yen, and 500 yen (the last is the latest value). In the example of
In
(iii) The data migration unit 5 adds, to the hash values of the update history groups 50a to 50d, access information for accessing the DB 42 (or the migration destination DB 4) at the respective migration destinations, and registers the hash values into the migration destination blockchain 3. The access information may be, for example, a URI (uniform Resource Identifier) such as a URL (Uniform Resource Locator) and an IP (Internet Protocol) address of the DB 42 at the migration destination or the migration destination DB 4.
For example, the data compression unit 52b calculates the hash values by performing hash operation on each of the update history groups 50a to 50d integrated by the data integration unit 52a. The calculation of the hash values may be achieved by known methods.
In the migration destination blockchain 3, one block may be allocated to each hash value, and each block may be connected in the order of the update history groups 50a to 50d.
The block data process unit 52 transmits (outputs), to the transaction transceiving unit 51b, migration transactions obtained by the addition of the access information to the hash values calculated by the data compression unit 52b.
Upon receiving (getting) the migration transactions from the block data process unit 52, the transaction transceiving unit 51b transmits the migration transactions to the transceiving unit 31a of the migration destination blockchain 3 together with registration instruction for the ledger 32. Further, the transaction transceiving unit 51b receives, from the transceiving unit 31a, the TxIDs (migration TxIDs) at the time when the migration transactions were registered into the ledger 32, and transmits the TxIDs to the DB communication unit 53.
For example, as illustrated in
Further, for example, the block data process unit 52 adds the access information (DB1) to the hash value (Hash({A:[400,500]})) obtained through hashing of the update history group 50b. The transaction transceiving unit 51b registers, through the transceiving unit 31a, the migration transaction into a block 30b connected to the block 30a. Since this migration transaction is a transaction of migration TxID:Tx2 in the blockchain 30, the transaction transceiving unit 51b notifies the data transceiving unit 53a of migration TxID:Tx2.
As such, in the blockchain 30, the hash values integrated in the units of groups are registered into blocks (the blocks 30a to 30d in the example of
According to the above description, the blockchain communication unit 51 and the block data process unit 52 are an example of a second registration unit that registers, into the migration destination blockchain 3, the hash values obtained by hashing multiple values in the units of groups baaed on the keys.
iv) The data migration unit 5 adds, to each of the update history groups 50a to 50d, a TxID at the time of registration of each hash value into the blockchain 30 and the access information for accessing the migration destination blockchain 3 or the blockchain 30, and registers the update history groups 50a to 50d into the migration destination DB 4. The access information may be, for example, a URI such as a URL and an IP address of the migration destination blockchain 3 or the blockchain 30.
As an example, the block data process unit 52 transmits key A of the update history group 50a and the values [100,200,300] of the update history group 50a, in other words, the transaction data, to the data transceiving unit 53a.
The data transceiving unit 53a transmits the transaction data received from the block data process unit 52 and the migration TxIDs received from the transaction transceiving unit 51b to the data transceiving unit 41a of the migration destination DB 4 together with registration instruction for the DB 42.
For example, as illustrated in
The migration TxIDs 42d is information that can identify registration position of the hash value in the blockchain 30, and is an example of registration position information on the hash value. In addition to the TxIDs, the update histories corresponding to the TxIDs may be registered into the migration TxID 42d.
As illustrated in
As illustrated in
According to the above description, the block data process unit 52 and the DB communication unit 53 are an example of a first registration unit that registers, into the migration destination DB 4, with respect to the migration source blockchain 2, multiple values in multiple transactions in the units of groups based on the keys.
As described above, the data migration unit 5 executes the migration process of the transaction data from the migration source blockchain 2 to the migration destination blockchain 3 and the migration destination DB 4.
The migration process described above may be executed by, for example, a data migration process (the data migration unit 5) which is started by the processor upon receiving an execution request for the migration process from the user.
After the end of the migration process, the processor may start the data registration process. The started data registration process (the data registration unit 6) may initialize the migration source blockchain 2 and may inherit the information on the update history groups 50a to 50d held in the storing region 50 through the data migration process.
As illustrated in
The request transmission unit 61 transmits requests such as registration requests for the updated value of each key to the migration source blockchain 2. As an example, the request transmission unit 61 may generate and transmit a registration request when receiving an updated value of a key from the user (client).
The data registration unit 6 may illustratively execute a process of following (v) (corresponding to symbol (v) in
(v) The request, transmission unit 61 registers the latest values of the update history groups 50a to 50d into the migration source blockchain 2.
For example, the request transmission unit 61 waits until both the registration) of data into the blockchain 30 and the DB 42 by the migration process of the data migration unit 5, and the initialization of the migration source blockchain 2 and.
After the end of the migration process and the initialization, the request transmission unit 61 obtains, from the data integration unit 52a, the latest values of the update history groups 50a to 53d each registered into the DB 42. The data integration unit 52a may obtain the respective latest values from the update history groups 50a to 50d stored in the storing region 50, or may obtain the latest value 42b of each key 42a in the DB 42 at the migration destination (see
Further, the request transmission unit 61 registers, into the migration source blockchain, a transaction with which the latest value of each of the update history groups 50a to 53d and a flag indicating existence of an update history of keys in each of the update history groups 50a to 50d in the migration destination DB 4 are associated. The flag (archive flag) is an example of third information indicating that a value older than the latest value among one or more values (update histories) exists in the migration destination DB 4.
In the migration source blockchain 2 after the initialization, the latest values (500, 3, 90) of the keys (keys A, B, and C) in the update history groups 50b to 50d are registered into the blocks 20a to 20c, respectively. In the blocks 20a to 20c, true indicating that the archive flag is ON is registered into the key Archive. As illustrated in
As described above, the request transmission unit 61 is an example of a third registration unit that registers, into the third blockchain, a transaction with which the first information, the second information, and the third information are associated. By using the flag, referring to the migration source blockchain 2 enables easy detection (determination) of the existence of an updated value older than the latest updated value in the migration destination DB 4.
In addition, the request transmission unit 61 is an example of a fourth registration unit that registers, after the registration of the transaction including the flag and in response to a registration request for a new transaction, a transaction related to the registration request subsequent to the transaction including the flag. This ensures consistency of the transactions before and after the migration in the migration source blockchain 2.
Although the above description relates to an example of using (reusing) the database resulted from the initialization of the migration source blockchain 2 as a new migration source blockchain 2 after the data migration from the migration source blockchain 2, the present disclosure is not limited to this example. As the “new migration source blockchain”, another blockchain different from the migration source blockchain 2 may be used. The migration source blockchain 2 or another blockchain different from the migration source blockchain 2 used as the new migration source blockchain is an example of the third blockchain.
The data reference process is operable if neither the data migration process nor the data registration process is operating and the migration source blockchain 2, the migration destination blockchain 3, and the migration destination DB 4 are activated. For example, in response to a request for data reference from the user (client), the data reference process (data reference unit 7) obtains the update history group corresponding to the key by specifying a time range. The user can refer to the update history group in one of or both the migration source blockchain 2 and the combination of the migration destination blockchain 3 and the migration destination DB 4, without being aware of the destination into which the data is stored.
The data reference unit 7 performs a tampering verification process for the data received from a reference in response to a data reference request.
As illustrated in
The request destination control unit 71 controls request destinations at the time of data reference.
The request transmission unit 72 transmits a reference re-guest for data to one of or both the migration source blockchain 2 and the combination of the migration destination blockchain 3 and the migration destination DB 4 in response to the control by the request destination control unit 71.
For example, the request destination control unit 71 specifies the update history group for the key of the obtainment target by a time range, and through the request transmission unit 72, refers to the oldest update history data of the key of the obtainment target in the migration source blockchain 2. In the example of
As illustrated in
when the oldest time in the time range of the obtainment target is newer than the oldest time of the migration source blockchain 2, the request destination control unit 71 determines to refer to the data in the range of “the oldest time of the obtainment target to the latest time of the obtainment target” in the reference (corresponding to the example of (I) in
on the other hand, when the oldest time in the time range of the obtainment target is older than the oldest time of the migration source blockchain 2, the request destination control unit 71 determines to refer to the data in a first range of “the oldest time of the migration source blockchain 2 to the latest time of the obtainment target” in the reference. The data in the first range corresponds to the data in the range of (III-1) in the example of (III) in
Further, when the oldest time of the obtainment target is older than the oldest time of the migration source blockchain 2 and the archive flag is added to the obtained data, the request destination control unit 71 determines to set the migration destination blockchain 3 and the migration destination DB 4 as the reference of the update history data.
When the latest time of the obtainment target is older than the time of the obtained data, the request destination control unit 71 determines to refer to the data in the range of “the oldest time of the obtainment target to the latest time of the obtainment target” in the reference (migration destination) (corresponding to the example of (II) in
On the other hand, when the latest time of the obtainment target is newer than the oldest time of the migration source blockchain 2, the request destination control unit 71 determines to refer to the data in a second range of “the oldest time of the obtainment target to the oldest time of the migration source blockchain 2” in the reference (migration destination). The data in the second range corresponds to the data in the range of (III-2) in the example of (III) in
As described above, the request destination control unit 71 and the request transmission unit 72 are an example of a reference unit. The reference unit refers to the transaction data in the migration source blockchain 2 based on the keys included in the multiple transactions registered by the request transmission unit 61. Further, when the data older than the referred data is requested by the data reference, the reference unit refers to the older data in the migration destination DB 4 based on the flag associated with the transaction of the referred data. This enables reference to older transaction data in the migration destination blockchain 3 and the migration destination DB 4.
The tampering verification unit 73 performs tampering verification for the data obtained (referred) in response to the reference request transmitted by the request transmission unit 72.
For example, the tampering verification unit 73 obtains the hash value by referring to the update history data of the migration destination blockchain 3 through the request transmission unit 72 while using one or more TxIDs associated with the update history data obtained in the example of (II) or (III-2) in
Then, the tampering verification unit 73 calculates the hash value of the above update history data, compares the calculated hash value and the hash value obtained from the migration destination blockchain 3, and verifies the tampering of the data obtained from the migration destination DB 4 based on the comparison result. For example, the tampering verification unit 73 may determine that the data obtained from the migration destination DB 4 has not been tampered with when the comparison result matches, and may determine that the data obtained from the migration destination DB 4 has been tampered with when the comparison result does not match.
As described above, the tampering verification unit 73 is an example of a first acquisition unit that obtains, from the migration destination DB 4, one or more data to which a predetermined TxID is added. Further, the tampering verification unit 73 is an example of a second acquisition unit that obtains, from the migration destination blockchain 3, a hash value corresponding to the predetermined TxID. Furthermore, the tampering verification unit 73 is an example of a verification unit that performs tampering verification for one or more data obtained from the migration destination DB 4 based on a hash value obtained by hashing one or more data obtained as the first acquisition unit and a hash value obtained as the second acquisition unit. As such, according to the tampering verification unit 73, the tampering verification of the migrated transactions can be streamlined.
Next, an operation example of the blockchain system 1 according to the one embodiment will be described with reference to
As illustrated in
The data integration unit 52a integrates all of the transaction data obtained by the block acquisition unit 51a into the units in which the same keys are updated by the transactions, and thereby, forms the update history groups (Step S2).
The data compression unit 52b calculates the hash value of each update history group, and the transaction transceiving unit 51b registers the calculated hash values into the migration destination blockchain 3 (Step S3).
The transaction transceiving unit 51b obtains the migration TxID from the migration destination blockchain 3, and the block data process unit 52 adds the migration TxID to each update history group. The data transceiving unit 53a registers, into the migration destination database 4, each update history group to which the migration TxID is added (Step S4), and the process ends.
The data migration unit 5 or the data registration unit G may initialize the migration source blockchain 2 after the process of Step S4 is completed.
As illustrated in
The request transmission unit 61 obtains the latest value of each update history group, adds the archive flag to the latest value, and registers the latest value into the migration source blockchain 2 (Step S12), and the process ends.
As illustrated in
In addition, the request destination control unit 71 obtains the oldest update history data of the target key from the migration source blockchain 2 (Step S22). Then, the request destination control unit 71 determines whether or not the latest time of the obtainment target is larger (newer) than the oldest transaction time of the migration source blockchain 2 (Step S23).
In the case of No in Step S23, the process proceeds to Step S27 in
In the case of No in Step S24, the request destination control unit 71 obtains, through the request transmission unit 12 and from the migration source blockchain 2, the update history data in the range of the oldest transaction time to the latest time of the obtainment target (Step S25). Then, the process proceeds to Step S27.
In the case of Yes in Step S24, the request destination control unit 71 obtains, through the request transmission unit 72 and from the migration source blockchain 2, the update history data in the range of the oldest time of the obtainment target to the latest time of the obtainment target (Step S26), and the process proceeds to Step S27.
As illustrated in
In the case of No in Step S27, the process ends. On the other hand, in the case of Yes in Step S27, the request destination control unit 71 determines whether or not the latest time of the obtainment target is smaller than the oldest transaction time of the migration source blockchain 2 (Step S28).
the case of No in Step S26, the request destination control unit 71 obtains, through the request transmission unit 72 and from the migration destination DB 4, the update history data in the range of the oldest time of the obtainment target to the oldest transaction time of the migration source blockchain 2 (Step S29). Then, the process proceeds to step S31.
In the case of Yes in Step S23, the request destination control unit 71 obtains, through the request transmission unit 72 and from the migration destination DB 4, the update history data in the range of the oldest time of the obtainment target to the latest time of the obtainment target (Step S30), and the process proceeds to Step S31.
In Step S31, the tampering verification unit 73 obtains the hash value from the update history data by referring to the update history data in the migration destination blockchain 3 by using the TxID associated with the obtained transaction data.
The tampering verification unit 73 verifies the tampering of the data by comparing the hash values of the update history data obtained from the migration destination DB 4 and the migration destination blockchain 3 (Step S32), and the process ends.
As described above, in the blockchain system 1 according to the one embodiment, the first registration unit registers, into the migration destination DB 4, with respect to the migration source blockchain 2 that stores multiple transactions with which the first information and the second information are associated, multiple pieces of the second information in the multiple transactions in units of groups based on the first information. In addition, the second registration unit registers, into the migration destination blockchain 3, hash values obtained by hashing the multiple pieces of second information in the units of groups.
As a result, the amount of data managed on the migration destination blockchain 3 can be reduced. For example, when 100 transaction data are collectively hashed together, as compared with the case where the transaction data is hashed one by one, the amount of data in the blockchain can be 1/100 or less (compression ratio can be 100 times or more) and the number of hash verifications at the time of data reference can be 1/100 or less. Therefore, the tampering verification of the data at the migration destinations can be easily performed, and the tampering verification can be streamlined.
Each of the groups may be formed by integrating multiple pieces of second information associated with the same first information in accordance with a predetermined condition. Consequently, the number of hash values managed by the migration destination blockchain 3 can be reduced, and the reference to the migration destination blockchain 3 can be facilitated.
Further, the predetermined condition may include the number of pieces of second information to be included in each of the groups being set as at least one of a predetermined number, a number in which the total data size of second information to be included in each of the groups becomes a predetermined data size or less, and a number of pieces of second information to be included in a predetermined number of blocks.
Consequently, the number of cases of data to be hashed together is limited, which can suppress an increase in the processing load (for example, the hash operation load of the reference data) at the time of the tampering verification.
When registering the multiple pieces of second information into the migration destination DB 4, the first registration unit may add migration TxIDs of the hash values in the units of groups registered into the migration destination blockchain 3 to second information included in groups corresponding to the hash values. Consequently, the hash values corresponding to the reference data can be efficiently obtained.
The first acquisition unit obtains, from the migration destination DB 4, one or more pieces of second information to which a predetermined migration TxID is added, and the second acquisition unit obtains, from the migration destination blockchain 3, a hash value corresponding to the predetermined migration TxID. Further, the verification unit may perform tampering verification for the one or more pieces of second information obtained from the migration destination DB 4 based on a hash value obtained by hashing the one or more pieces of second information obtained by the first acquisition unit and the hash value obtained by the second acquisition unit. Accordingly, the tampering verification of data in the migration destination blockchain 3 and the migration destination block DB 4 can be efficiently performed.
The reference unit may refer to the second information in the migration source blockchain 2 after the restart based on the first information included in the multiple transactions registered by the third registration unit, and when second information older than the referred second information is requested, the reference unit may refer to the older second information in the migration destination DB 4 based on the third information associated with a transaction of the referred second information.
As such, by initializing the migration source blockchain 2 and registering the latest values of the update history groups, and at the time of data reference, by allocating the reference to the migration source blockchain 2 and the combination of the migration destination blockchain 3 and the migration destination DB 4 based on the blockchain, it becomes possible for the clients to refer to the data without being aware of the reference of the data.
As illustrated in
The processor 10a is an example of an arithmetic processing device that performs various controls and arithmetic operations. The processor 10a may be connected to each block in the computer 10 so as to be mutually communicable via a bus 10i. The processor 10a may be a multiprocessor including multiple processors or a multi-core processor including multiple processor cores, or may have a configuration having multiple multi-core processors.
An example of the processor 10a is an integrated circuit (IC; integrated Circuit) such as a CPU, an MPU, a GPU, an APU, a DSP, an ASIC, and an FPGA. Alternatively, the processor 10a may be a combination of two or more integrated circuits exemplified as the above. The CPU is an abbreviation of Central Processing Unit, the MPU is an abbreviation of Micro Processing Unit, the GPU is an abbreviation of Graphics Processing Unit, the APU is an abbreviation of Accelerated Processing Unit, the DSP is an abbreviation of Digital Signal Processor, the ASIC is an abbreviation of Application Specific IC, and the FPGA is an abbreviation of Field-Programmable Gate Array.
The memory 10b is an example of a HW that stores information such as various data and programs. An example of the memory 10b may be a volatile memory such as a DRAM (Dynamic RAM).
The storing device 10c is an example of a HW that stores information ouch as various data and programs. Examples of the storing device 10c include various storing devices exemplified by a magnetic disk device such as an HDD (Hard Disk Drive), a semiconductor drive device such as an SSD (Solid State Drive), and a non-volatile memory. The non-volatile memory may be, for example, a flash memory, an SCM (Storage Class Memory), a ROM (Read Only Memory), or the like.
For the storing regions 50 (see
The storing device 10c may store a program 10g (transaction management program) that achieves all or part of the functions of the computer 10.
For example, by expanding the program 10g stored in the storing device 10c onto the memory 10b and executing the expanded program 10g, the processor 10a can execute at least one of the data migration process, the data registration process, and the data reference process, which are provided by the program 10g. In addition, the functions of at least one of the blockchain control unit 21, the blockchain control unit 31, and the DB control unit 41 may also be provided by the program 10g.
In other words, the computer 10 can operate as the transaction management device configured by at least one or various combinations of the migration source blockchain 2, the migration destination blockchain 3, the migration destination DB 4, the data migration unit 5, data registration unit 6, and the data reference unit 7. As a non-limiting example, the migration source blockchain 2 and the data migration unit 5 may be achieved by a single computer 10, or alternatively, the migration source blockchain 2, the data migration unit 5, data registration unit 6, and the data reference unit 7 may be achieved by a single computer 10. Further, the migration destination blockchain 3 and the migration destination DB 4 may each be achieved by a single computer 10.
The IF unit 10d is an example of a communication IF that controls connection to and communication with a network, and the like. For example, the IF unit 10d may include an adaptor compatible with a LAN (Local Area Network) or an optical communication (e.g., FC (Fibre Channel)), or the like. The adaptor may be compatible with one or both of wired and wireless communication schemes. For example, the program 10g may be downloaded from a network to the computer 10 through the communication IF and then stored into the storing device 10c.
In cases where the blockchain system 1 is achieved by multiple computers 10, the above network may connect the computers to one another.
The I/O unit 10e may include an input device, an output device, or both. Examples of the input device may be a keyboard, a mouse, and a touch screen. Examples of the output device may be a monitor, a projector, and a printer.
The reader 10f is an example of a reader that reads information on data and programs recorded on a recording medium 10h. The reader 10f may include a connecting terminal or a device to which the recording medium 10h can be connected or inserted. Examples of the reader 10f include an adapter conforming to, for example, USB (Universal serial Bus), a drive device that accesses a recording disk, and a card reader that accesses a flash memory such as an SD card. The program 10g may be stored in the recording medium 10h, and the reader 10f may read the program 10g from the recording medium 10h and then store the read program 10g into the storing device 10c.
The recording medium 10h may illustratively be a non-transitory computer-readable recording medium such as a magnetic/optical disk and a flash memory. The magnetic/optical disk may illustratively be a flexible disk, a CD (Compact Disc), a DVD (Digital Versatile Disc), a Blu-ray disk, an HVD (Holographic Versatile Disc), or the like. The flash memory may illustratively be a semiconductor memory ouch as a USD memory and an SD card.
The HW configuration of the computer 10 described above is merely illustrative. Accordingly, the computer 10 may appropriately undergo increase or decrease of HW (e.g., addition or deletion of arbitrary blocks), division, integration in an arbitrary combination, and addition or deletion of the bus. For example, at least one of the I/O unit 10e and the reader 10f may be omitted in the computer 10.
The blockchain system 1, for example, as a cloud system may be configured by a HW resource and a NW (Network) resource that are configured by multiple computers 10 mutually connected so as to be communicable with each other via a non-illustrated network.
In this case, each of nodes such as the migration source blockchain 2, the migration destination blockchain 3, the migration destination DB 4, the data migration unit 5, the data registration unit 6, and the data reference unit 7 included in the blockchain system 1 may be realized by logically (virtually) or physically dividing the HW resource and the NW resource configured by the multiple computers 10 and allocating them to the nodes.
In other words, the blockchain system 1 may be regarded as a single transaction management device including a processor resource (processor), a memory resource (memory), a storage resource (storing device), and an IF resource (IF unit), which serve as the HW resource and the NW resource provided by the multiple computers 10. The blockchain system 1 as the transaction management device (computer) can allocate the processor resource, the memory resource, the storage resource, and the IF resource to the nodes for implementing particular functional blocks, or can release the allocations to the nodes, by a scale out process.
in the blockchain system 1 as a cloud system, the program 10g for realizing the function as the blockchain system 1 may be divided into units of execution in each of multiple nodes and the divided program may be distributed to the multiple nodes. The multiple nodes (the functional blocks 2 to 7 in
That is, even if the program 10g is distributed to the multiple nodes, the program 10g can be regarded as a single program that causes the transaction management device (computer) or the transaction management system to execute the function of the blockchain system 1.
The technique according to the one embodiment described above can be changed or modified as follows.
For example, each functional block included in the blockchain system 1 depicted in
In one aspect, tampering verification of migrated transactions can be streamlined.
Throughout the descriptions, the indefinite article “a” or “an”, or adjective “one” does not exclude a plurality.
All examples and conditional language recited herein are intended for the pedagogical purposes of aiding the reader in understanding the invention and the concepts contributed by the inventor to further the art, and are not to be construed limitations to such specifically recited examples and conditions, nor does the organization of such examples in the specification relate to a showing of the superiority and inferiority of the invention. Although one or more embodiments of the present inventions have been described in detail, it should be understood that the various changes, substitutions, and alterations could be made hereto without departing from the spirit and scope of the invention.
This application is a continuation application of International Application PCT/JP2019/038699 filed on Oct. 1, 2019 and designated the U.S., the entire contents of which are incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/JP2019/038699 | Oct 2019 | US |
Child | 17704215 | US |