The present invention relates to a data sharing system, a management terminal, a data sharing method, and a data sharing program.
In IoT (Internet of Things), IoT terminals that are nodes communicate with each other. Methods for managing and coordinating such IoT terminals include a method in which a management server that manages IoT terminals is deployed. Patent Literature 1 discloses a technology in which a node participating in an IoT network is handled on a specified terminal.
A blockchain is known, as a mechanism that can ensure reliability with no need for centralized management. In the blockchain, reliability of exchanged information is ensured through a consensus building process in a distributed network, and soundness is maintained by preventing fraud, such as falsification and double-spending, in a system-wide manner. In the blockchain, inter-participant transaction information (transactions) is collected in a unit of “block”, each block is concatenated one after another and managed in chronological order. Non-Patent Literature 1 discloses technology related to the blockchain.
For IoT networks, unified standardization of implementation methods is underway. Therefore, current IoT networks are siloed, and it is difficult to share information between or among a plurality of IoT networks.
If an attempt is made to monitor a plurality of IoT networks, a monitoring server is needed that monitors management servers installed for the IoT networks, respectively, and a mechanism for alive monitoring of the monitoring server is further needed, and accordingly a system configuration become large in scale and complicated.
An object of the present invention, which has been devised in view of the above described problems, is to provide a technology that makes it possible to easily share information in a plurality of IoT networks.
To achieve the object, an aspect of the present invention provides a data sharing system that includes a plurality of IoT networks, and a plurality of management terminals connected to a blockchain network, in which each of the management terminals includes a reception unit that receives a transaction including IoT terminal information related to an IoT terminal from at least one IoT network of the plurality of the IoT networks, a communication unit that transmits and receives the transaction to/from another management terminal, a block generation unit that attempts to generate a block including the transaction, a block verification unit that verifies a block generated by another management terminal, and a distributed ledger that stores the generated blocks.
An aspect of the present invention provides a management terminal connected to a blockchain network. The management terminal includes a reception unit that receives a transaction including IoT terminal information related to an IoT terminal from at least one IoT network of a plurality of IoT networks, a communication unit that transmits and receives the transaction to/from another management terminal, a block generation unit that attempts to generate a block including the transaction, a block verification unit that verifies a block generated by another management terminal, and a distributed ledger that stores the generated blocks.
An aspect of the present invention provides a data sharing method performed by a data sharing system, in which the data sharing system includes a plurality of IoT networks, and a plurality of management terminals connected to a blockchain network. The data sharing method includes by each of the IoT networks, transmitting a transaction including IoT terminal information related to an IoT terminal to at least one management terminal, by each of the management terminals, receiving the transaction from at least one IoT network of the plurality of IoT networks, transmitting and receiving the transaction to/from another management terminal, attempting to generate a block including the transaction, or verifying a block generated by another management terminal, and storing the generated block in a distributed ledger.
An aspect of the present invention provides a data sharing program for causing a computer to function as the management terminal.
According to the present invention, a technology that makes it possible to easily share information in a plurality of IoT networks can be provided.
Hereinafter, an embodiment of the present invention will be described with reference to drawings. In a description of the drawings, the same portions are denoted by the same reference numerals, and an overlapping description thereof will be omitted.
(Configuration of Data Sharing System)
In the present embodiment, a distributed ledger on a blockchain and a smart contract is used for a history, whereby data sharing between or among a plurality of IoT networks is achieved. Each terminal (blockchain node) included in a blockchain includes a distributed ledger in which the latest-state blockchain is stored nearly in real time through loose synchronization with all terminals connected to a blockchain network. In other words, individual terminals store information on each other while replicating the information, mutually verify the information, and store the distributed ledgers with the same contents.
In the present embodiment, the terminals in the blockchain, each monitoring at least one IoT network, exchange information on the monitored IoT network with each other and keep the distributed ledgers, whereby data sharing between or among a plurality of a plurality of the IoT networks is achieved.
The data sharing system shown in
The management terminals 1 are blockchain nodes, each of which manages an IoT terminal 2 in at least one of the IoT networks 20. The management terminals 1 are connected to the blockchain network, which is a P2P network, in an autonomous and decentralized manner. The management terminals 1 connected to the blockchain network 10 each include a distributed ledger, which will be described later, and maintain a system by mutually verifying data and transactions recorded in the distributed ledgers. Note that although the three management terminals 1 are depicted in the drawing, the number of management terminals 1 is not limited to three.
The IoT networks 20 are networks constructed by individual companies, respectively. For example, it is assumed that the IoT network A is constructed by a company in Tokyo, the IoT network B is constructed by a company in Osaka, and the IoT network C is constructed by a university in Hokkaido. A plurality of IoT terminals 2 is connected to each IoT network 20. Each IoT terminal 2 is, for example, a sensor terminal or the like and transmits measured or acquired data to at least one of the management terminals 1 via the network.
(Configuration of Management Terminal)
The depicted management terminal 1 includes a blockchain control unit 11, a reception unit 12, a communication unit 13, a block generation unit 14, a block verification unit 15, and a distributed ledger 16.
The blockchain control unit 11 maintains the blockchain system by cooperating, in an autonomous and decentralized manner, with the management terminals 1 connected to the blockchain network. The blockchain control unit 11 accesses the distributed ledger 16 and reads or updates the blockchain and a dataset in the distributed ledger 16.
In the distributed ledger 16, the latest-state blockchain is stored nearly in real time through loose synchronization, via the blockchain control unit 11, with all of the terminals connected to the blockchain network. The blockchain and the dataset managed by the blockchain are stored in the distributed ledger 16 in the present embodiment. A block that is generated by the own management terminal 1 or any other management terminal 1 and that includes IoT terminal information is stored in the distributed ledger 16 in the present embodiment.
The reception unit 12 receives, from at least one IoT network 20 of the plurality of IoT networks 20, a transaction including IoT terminal information related to an IoT terminal 2. The communication unit 13 transmits and receives a transaction received from an IoT terminal 2, to/from any other management terminal.
The block generation unit 14 attempts to generate a block including a transaction. In other words, the block generation unit 14 verifies a transaction and attempts to generate a block in accordance with a consensus algorithm for block generation, such as Proof of Work. Specifically, the block generation unit 14 includes a consensus execution unit, a transaction verification unit, and a block issuance unit, which are not shown.
The consensus execution unit performs calculation required for consensus, such as a hashing operation. As the consensus algorithm, in addition to Proof of Work, which is used for bitcoin, any other consensus algorithm for block generation may be used, such as Proof of Stake in which the quantity of owned coins is used for a resource, or PBFT that is a consensus algorithm in a Byzantine failure.
After the transaction verification unit receives a transaction, the transaction verification unit verifies the transaction, such as correctness of an electronic signature on the received transaction. The block issuance unit generates one block by aggregating transactions issued within a predetermined time period in the blockchain network. In other words, if verification by the transaction verification unit succeeds, the block issuance unit generates a block including the transaction and has the generated block reflected in the distributed ledgers 16 of all terminals connected to the blockchain network.
The block verification unit 15 verifies a block generated by another management terminal 1. Specifically, the block verification unit 15 verifies correctness of a block that is generated by another management terminal 1 and added to the own distributed ledger, for example, by performing hash calculation using a block header for an input value. The block verification unit 15 verifies whether a solution presented by the other management terminal is a correct solution.
(Configuration of IoT Terminal)
The detection unit 21 detects or measures a predetermined type of physical amount. For example, the detection unit 21 may be a sensor that acquires an ambient temperature, humidity, or the like.
The processing unit 22 performs predetermined computational processing. For example, the processing unit 22 stores, in the storage unit 25, detection data (a temperature, a humidity, or the like) detected by the detection unit 21, together with a time acquired from a clock unit (not shown).
The transaction generation unit 23 generates a transaction including IoT terminal information, based on information stored in the storage unit 25. The IoT terminal information includes, for example, a terminal ID, a time, detection data detected by the detection unit 21, and the like. The terminal ID is identification information that is stored in the storage unit 25 and that uniquely specifies the own terminal. The transaction generation unit 23 generates a transaction including IoT terminal information and an electronic signature of the IoT terminal information. The transaction is a transaction for registering the IoT terminal information in the distributed ledger 16 of each management terminal 1.
The communication unit 24 communicates with any management terminal 1 in the blockchain or any other IoT terminal 2 in the same IoT network 20. In the present embodiment, the communication unit 24 transmits a transaction generated by the transaction generation unit 23 to at least one of the management terminals 1.
The storage unit 25 stores the terminal ID, an own private key for an electronic signature, detection data detected by the detection unit 21, a time at which the detection data is acquired, and the like.
(System Operation)
Each management terminal A, B, and C performs computation for generating a block including the received transaction (S14, S15, and S16). As the computation for generating the block, for example, each management terminal A, B, and C verifies the transmitted transaction, and searches for a nonce for generating one block by aggregating the transaction together with other transactions that are generated within a predetermined time period.
Such block generation is performed competitively, and any management terminal, among the management terminals A, B, and C, that most quickly computes a solution (nonce or the like) generates the block including the received transaction. The generated block is added to the distributed ledger of the management terminal (S17).
Then, through loose synchronization among the terminals, the block including the transaction transmitted in S11 to S13 is reflected in the distributed ledgers of all management terminals connected to the blockchain network (S18 and S19). In other words, all management terminals add the block including the transaction in the distributed ledgers kept by the management terminals. Here, it is assumed that the management terminal A generates the block (S17), and that the generated block is propagated to the management terminals B and C (S18 and S19).
The management terminals B and C each verify the block generated by the other management terminal A (S20 and S21) and, if verification succeeds, transmit a message indicating consent to the block to the management terminal A (S22 and S23). For example, the management terminals B and C each verify whether the solution included in the block is a correct solution and, if the solution is a correct solution, consent the block. Note that a unit of data stored in the distributed ledger of each management terminal A, B, and C is a block in which a plurality of transactions is aggregated.
At a next transmission timing, the IoT terminal (a) generates a transaction including IoT terminal information and transmits the transaction to the management terminals A, B, and C as in S11, S12, and S13 (S24, S25, and S26). Thus, each management terminal A, B, and C performs the above described processing in S14 to S23. As described above, in the data sharing system of the present embodiment, the processing in S11 to S23 is performed repeatedly, whereby transactions (IoT terminal information) transmitted from the IoT terminal (a) is stored in the distributed ledger of each management terminal A, B, and C.
Although a case where transactions are transmitted from the single IoT terminal (a) is described as an example in
Note that the operation of each management terminal A, B, and C in S14 to S23 shown in
Then, at a next transmission timing, the IoT terminal (a) generates a transaction including IoT terminal information and transmits the transaction to the management terminal A as in S11A (S24A). The management terminal A transmits the received transaction to other management terminals B and C as in S12A and S13A (S25A and S26A). Thus, each management terminal A, B, and C performs the above-described processing in S14 to S23.
For example, suppose that the management terminal A is deployed in Tokyo, the management terminal B is deployed in Osaka, the management terminal C is deployed in Sapporo, and the IoT network A is operated in Tokyo by the company in Tokyo. In the above case, it is inefficient for each IoT terminal in the IoT network A to directly communicate with the management terminals B and C at remote locations.
In such a case, each IoT terminal in the IoT network A deployed in Tokyo transmits a transaction only to the management terminal A that is deployed at the nearest location, and the management terminal A transmits the transaction to other management terminals B and C. Accordingly, communication loads on the IoT terminals can be reduced.
In
In such a case, as described in
Note that in the present embodiment, an IoT terminal transmits the own IoT terminal information by using a transaction that is interpretable by the management terminals that are nodes of the blockchain. Accordingly, even if a new IoT network is added, a modification to the management terminals (a change, a correction to a program) is not needed.
Thereafter, if a new IoT network is added at a location close to the management terminal D, the management terminal D receives a transaction from each IoT terminal in the new IoT network.
Note that as shown in the drawing, the IoT networks A and B that include the management servers 3 and the IoT network C that does not include the management server 3 may coexist.
The data sharing system of the present embodiment as described hereinabove includes a plurality of the IoT networks 20, and a plurality of the management terminals 1 connected to the blockchain network. Each management terminal 1 includes the reception unit 12, the communication unit 13, the block generation unit 14, the block verification unit 15, and the distributed ledger 16. The reception unit 12 receives a transaction including IoT terminal information related to an IoT terminal 2 from at least one IoT network 20 of the plurality of IoT networks 20. The communication unit 13 transmits and receives the transaction to/from another management terminal 1. The block generation unit 14 attempts to generate a block including the transaction. The block verification unit 15 verifies a block generated by another management terminal 1. The distributed ledger 16 stores the generated blocks.
As described above, in the present embodiment, the blockchain is used for an overlay network, whereby IoT terminal information on each IoT terminal in the plurality of IoT networks is stored in the distributed ledger of each management terminal 1. In other words, each management terminals 1 in the present embodiment can share IoT terminal information in the plurality of IoT networks. Therefore, a user can monitor the plurality of IoT networks 20 overall by referring to the distributed ledger of any one of the management terminals 1.
In the blockchain, information is autonomously exchanged through loose synchronization among the terminals, and the latest-state blockchain (IoT terminal information history) is stored nearly in real time in the distributed ledger of each management terminal 1. Accordingly, in the present embodiment, it is easy to newly add or delete an IoT network 20 and a management terminal 1, so that a workload required for scale out (a change to the system) can be reduced.
In IoT networks, the number of IoT terminals tends to increase with enhancement of the networks. On the other hand, IoT terminals themselves are vulnerable in general, and it happens frequently that an IoT terminal is detached from a network due to power-supply or network disconnection or the like. Therefore, if each individual IoT terminal is managed, IoT terminals to be managed need to be reconfigured in each management server each time an IoT terminal is added or deleted, and accordingly configuration work becomes complicated. By contrast, in the present embodiment, a management server does not need to be deployed for each IoT network 20, and accordingly, IoT terminal information does not need to be set in each management server each time an IoT terminal 2 is added or deleted. Moreover, in the present embodiment, since a management server does not need to be deployed for each IoT network 20, it is possible to avoid a system configuration from being large in scale and complicated.
For each management terminal 1 and each IoT terminal 2 described above, for example, a general-purpose computer system as shown in
Each management terminal 1 may be implemented by using a single computer, or may be implemented by using a plurality of computers. Each management terminal 1 may be a virtual machine implemented on a computer.
The program for the management terminals 1 and the program for the IoT terminals 2 each can be stored in a computer-readable recording medium, such as an HDD, an SSD, a USB (Universal Serial Bus) memory, a CD (Compact Disc), or a DVD (Digital Versatile Disc), or can be distributed via a network.
The present invention is not limited to the above-described embodiment, and various changes can be made within the scope of the gist of the present invention.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/JP2019/027357 | 7/10/2019 | WO |