WO2022113699A1 - 管理装置 - Google Patents

管理装置 Download PDF

Info

Publication number
WO2022113699A1
WO2022113699A1 PCT/JP2021/040767 JP2021040767W WO2022113699A1 WO 2022113699 A1 WO2022113699 A1 WO 2022113699A1 JP 2021040767 W JP2021040767 W JP 2021040767W WO 2022113699 A1 WO2022113699 A1 WO 2022113699A1
Authority
WO
WIPO (PCT)
Prior art keywords
node
data
communication
quality
packets
Prior art date
Application number
PCT/JP2021/040767
Other languages
English (en)
French (fr)
Inventor
昌志 安沢
広樹 石塚
Original Assignee
株式会社Nttドコモ
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 株式会社Nttドコモ filed Critical 株式会社Nttドコモ
Priority to JP2022565186A priority Critical patent/JPWO2022113699A1/ja
Publication of WO2022113699A1 publication Critical patent/WO2022113699A1/ja

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • H04L45/42Centralised routing
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/24Traffic characterised by specific attributes, e.g. priority or QoS

Definitions

  • the present invention relates to a management device.
  • a system using a blockchain is known (see, for example, Patent Document 1).
  • the blockchain is a database related to data such as transaction data.
  • a blockchain contains multiple blocks connected in series. Each block contains data such as transaction data.
  • the blockchain is shared by multiple nodes. When any node of multiple nodes generates additional data (eg, transaction data or block) that should be added to the blockchain, the additional data is communicated between the multiple nodes and added to the blockchain. ..
  • An object of the present invention is to provide a technique for assisting a node in order to reduce the delay in the timing of adding data to the blockchain.
  • the management device is in a group composed of a first node and a plurality of second nodes having a blockchain together and executing communication for adding additional data to the blockchain.
  • the providing unit that provides the first information corresponding to the control request to the first node and the first node provide the first information.
  • the communication quality of the first communication data is set to a quality equal to or higher than the first quality. Includes a quality control unit and.
  • FIG. 1 is a diagram showing a network system 1.
  • the network system 1 includes a network NW and a management device 10.
  • the network NW includes groups A1 of nodes 20, 30, 40, 50 and 60.
  • the network NW also includes a plurality of nodes that do not belong to the group A1.
  • Node 20 is an example of the first node.
  • Nodes 30, 40, 50 and 60 are examples of a plurality of second nodes.
  • Each of the nodes 30, 40, 50 and 60 is an example of a second node.
  • the number of the second node is not limited to 4, and may be 2 or more.
  • Group A1 is an example of a group composed of a first node and a plurality of second nodes.
  • Nodes 20, 30, 40, 50 and 60 constitute a P2P (Peer to Peer) network.
  • the configuration of the P2P network is not limited to the configuration shown in FIG. 1, and can be appropriately changed.
  • Each of the nodes 20, 30, 40, 50 and 60 has a common blockchain BC. That is, the nodes 20, 30, 40, 50 and 60 both have a blockchain BC.
  • FIG. 2 is a diagram showing an example of blockchain BC.
  • the blockchain BC includes a plurality of blocks B1 connected in series.
  • Each block B1 includes block-related data Q1 and target data T1.
  • the block-related data Q1 is based on the data contained in the immediately preceding block B1.
  • the block-related data Q1 is, for example, a hash value based on the data included in the immediately preceding block B1.
  • the block-related data Q1 contributes to resistance to data tampering in the blockchain BC.
  • the target data T1 is, for example, transaction data D1.
  • the transaction data D1 is, for example, data relating to a transaction of a cryptographic asset.
  • Cryptographic assets are also referred to as virtual transit or electronic currency.
  • the transaction data D1 is not limited to the data related to the transaction of cryptographic assets.
  • the transaction data D1 may be, for example, data relating to a real estate transaction, data relating to a transaction of a movable property, or data relating to a transaction of information.
  • the transaction data D1 is also referred to as a transaction.
  • the target data T1 is not limited to the transaction data D1, and may be, for example, data related to the exchange of information such as a contract.
  • the blockchain BC is an example of a database that manages the target data T1.
  • the transaction data D1 can be generated by each of the plurality of nodes 20, 30, 40, 50 and 60.
  • the transaction data D1 is propagated from the node that is the source of the transaction data D1 to a node among a plurality of nodes 20, 30, 40, 50, and 60 that is different from the node that is the source of the transaction data D1.
  • the plurality of nodes 20, 30, 40, 50 and 60 verify the transaction data D1.
  • Block B1 is generated by a node called a minor node among a plurality of nodes 20, 30, 40, 50 and 60.
  • the minor node combines a plurality of transaction data D1 into one block B1.
  • the block B1 is propagated from the minor node that is the generator of the block B1 to a node of a plurality of nodes 20, 30, 40, 50 and 60 that is different from the node that is the generator of the block B1.
  • each of the plurality of nodes 20, 30, 40, 50 and 60 receives the block B1, it verifies the block B1.
  • Each of the plurality of nodes 20, 30, 40, 50 and 60 adds the block B1 to the existing blockchain BC when the verification result of the block B1 is valid.
  • Adding the block B1 to the existing blockchain BC means connecting the block B1 to the existing blockchain BC.
  • Each of the block B1, the target data T1 and the transaction data D1 is an example of predetermined data.
  • the predetermined data is an example of additional data.
  • Each of the nodes 20, 30, 40, 50 and 60 executes communication for adding the transaction data D1 to the blockchain BC.
  • “communication for adding transaction data D1 to the blockchain BC” is also referred to as "data addition communication”.
  • An example of data addition communication is transaction data D1 communication.
  • Another example of data addition communication is communication of block B1 including transaction data D1.
  • data such as transaction data D1 and block B1 are communicated by packets.
  • the management device 10 reduces the delay in the timing at which the transaction data D1 is added to the blockchain BC by controlling the quality of the data addition communication.
  • the management device 10 accelerates the timing at which the transaction data D1 is considered to be finalized by reducing the delay in the timing at which the transaction data D1 is added to the blockchain BC.
  • the management device 10 supports at least one of the nodes 20, 30, 40, 50, and 60 by accelerating the timing at which the transaction data D1 is considered to be finalized.
  • FIG. 3 is a diagram showing an example of a network NW.
  • the network NW includes communication devices 71, 72, 73 and 74 in addition to the nodes 20, 30, 40, 50 and 60.
  • Each of the communication devices 71, 72, 73 and 74 is, for example, a router.
  • the nodes 20, 30, 40, 50 and 60 and the communication devices 71, 72, 73 and 74 can communicate with the management device 10.
  • the management device 10 controls the quality of communication in the network NW by causing at least one of the communication devices 71, 72, 73, and 74 to execute at least one of priority control and band control.
  • Priority control is, for example, control for preferentially forwarding a packet related to a specific communication.
  • priority control When priority control is executed, low latency, improved throughput, high speed, high reliability, etc. are realized in a specific communication.
  • Bandwidth control is control that adjusts the bandwidth used for communication. When the bandwidth of communication is expanded by bandwidth control, for example, low delay, improvement of throughput, high speed, high reliability and the like are realized in communication.
  • Each of priority control and bandwidth control is an example of QoS (Quality of Service) control.
  • the management device 10 reduces the delay in the timing at which the transaction data D1 is added to the blockchain BC by causing at least one of the communication devices 71, 72, 73, and 74 to execute QoS control.
  • Node 20 is a personal computer.
  • the node 20 is not limited to a personal computer, and may be, for example, a smartphone or a tablet.
  • the node 20 executes data addition communication (communication for adding transaction data D1 to the blockchain BC) with each of the nodes 30 and 40.
  • FIG. 4 is a diagram showing an example of the node 20.
  • the node 20 includes an input device 21, an output device 22, a communication device 23, a storage device 24, and a processing device 25.
  • the input device 21 includes a keyboard.
  • the input device 21 may include at least one of a mouse and a touch panel.
  • the input device 21 may not include at least one of a keyboard and a mouse.
  • the input device 21 accepts an operation performed by the user.
  • the output device 22 includes a display.
  • the output device 22 may include a touch panel.
  • the output device 22 displays various information.
  • the output device 22 may not include a display.
  • the touch panel may be used as the input device 21 and the output device 22.
  • the communication device 23 communicates with the node 30 via a communication device 71 such as a router.
  • the communication device 23 communicates with the node 40 via a communication device 72 such as a router.
  • the communication device 23 further communicates with the management device 10.
  • the storage device 24 is a recording medium that can be read by the processing device 25.
  • the storage device 24 includes, for example, a non-volatile memory and a volatile memory.
  • the non-volatile memory is, for example, ROM (ReadOnlyMemory), EPROM (ErasableProgrammableReadOnlyMemory), and EEPROM (ElectricallyErasableProgrammableReadOnlyMemory).
  • the volatile memory is, for example, RAM (RandomAccessMemory).
  • the storage device 24 stores the application program 241 and the blockchain BC.
  • the processing device 25 includes one or a plurality of CPUs (Central Processing Units).
  • CPUs Central Processing Units
  • One or more CPUs is an example of one or more processors.
  • Each of the processor and the CPU is an example of a computer.
  • the processing device 25 reads the application program 241 from the storage device 24.
  • the processing device 25 functions as an operation control unit 251, a request unit 252, a verification unit 254, and a block generation unit 255 by executing the application program 241.
  • the operation control unit 251 may be realized by a circuit such as a DSP (Digital Signal Processor), an ASIC (Application Specific Integrated Circuit), a PLD (Programmable Logic Device), and an FPGA (Field Programmable Gate Array).
  • a circuit such as a DSP (Digital Signal Processor), an ASIC (Application Specific Integrated Circuit), a PLD (Programmable Logic Device), and an FPGA (Field Programmable Gate Array).
  • At least one of the request unit 252, the verification unit 254, and the block generation unit 255 may be realized by circuits such as DSP, ASIC, PLD, and FPGA.
  • the operation control unit 251 controls the communication for adding the transaction data D1 to the blockchain BC, that is, the data addition communication.
  • the request unit 252 transmits the request C1 to the management device 10.
  • Request C1 indicates a request for QoS control for communication regarding transaction data D1.
  • the communication regarding the transaction data D1 includes the communication of the transaction data D1 and the communication of the block B1 including the transaction data D1. That is, the communication regarding the transaction data D1 means the entire communication for adding the transaction data D1 to the blockchain BC.
  • the communication related to the transaction data D1 is an example of the data addition communication.
  • QoS control is an example of controlling the quality of communication.
  • Request C1 is an example of a control request that requests control of the quality of communication for adding predetermined data to the blockchain BC.
  • the control request is a request for controlling the quality of communication for adding predetermined data (additional data) to the blockchain BC.
  • the verification unit 254 verifies the transaction data D1 generated by another node.
  • the verification unit 254 verifies the block B1 generated by another node.
  • the block generation unit 255 generates the block B1 including the transaction data D1. For example, the block generation unit 255 collects a plurality of transaction data D1 into one block B1.
  • ⁇ A3 Nodes 30, 40, 50 and 60> Each of the nodes 30, 40, 50 and 60 has components similar to those of the node 20.
  • the node 30 executes data addition communication (communication for adding transaction data D1 to the blockchain BC) with the node 20.
  • the node 40 executes data addition communication with each of the nodes 20, 50 and 60.
  • the node 50 executes data addition communication with the node 40.
  • the node 60 executes data addition communication with the node 40.
  • FIG. 5 is a diagram showing an example of the management device 10.
  • the management device 10 is a server.
  • the management device 10 includes a communication device 11, a storage device 12, and a processing device 13.
  • the communication device 11 directly or indirectly communicates with each of the nodes 20, 30, 40, 50 and 60.
  • the communication device 11 directly or indirectly communicates with each of the communication devices 71, 72, 73 and 74.
  • the storage device 12 is a recording medium that can be read by the processing device 13.
  • the storage device 12 includes, for example, a non-volatile memory and a volatile memory.
  • the storage device 12 stores the program 121 and the management table 122.
  • FIG. 6 is a diagram showing an example of the management table 122.
  • the management table 122 is used to manage QoS control for the communication performed by each of the nodes 20, 30, 40, 50 and 60.
  • the processing device 13 includes one or more CPUs.
  • the processing device 13 reads the program 121 from the storage device 12.
  • the processing device 13 functions as the providing unit 131 and the quality control unit 132 by executing the program 121.
  • At least one of the providing unit 131 and the quality control unit 132 may be realized by circuits such as DSP, ASIC, PLD and FPGA.
  • the providing unit 131 When the request C1 is received from the first node (for example, the node 20), the providing unit 131 provides the one-time pass P1 to the first node.
  • the one-time pass P1 is used to perform the control indicated in request C1.
  • the first node When the first node receives the one-time pass P1, it generates the first communication data having the one-time pass P1.
  • the first communication data has a plurality of packets M1a.
  • Each of the plurality of packets M1a has a one-time pass P1 and a part of the transaction data D1.
  • Each of the plurality of packets M1a is communicated within the group A1.
  • Each of the plurality of packets M1a propagates to each of the plurality of second nodes.
  • the quality control unit 132 controls the communication quality of the data having the one-time pass P1.
  • An example of data having a one-time pass P1 is packet M1a.
  • the quality control unit 132 sets the communication quality of the packet M1a to a quality equal to or higher than a predetermined quality in a situation where the packet M1a is communicated within the group A1.
  • the predetermined quality is an example of the first quality.
  • the predetermined quality is, for example, a communication quality in which the communication band is "X1" Mbps. "X1" is a positive number. In this case, the quality of the predetermined quality or higher means the quality in which the communication band is "X1" Mbps or higher.
  • the predetermined quality is not limited to the communication quality in which the communication band is "X1" Mbps, and may be, for example, the communication quality in which the delay is "X2" ms. "X2" is a positive number. In this case, a quality equal to or higher than a predetermined quality means a quality having a delay of "X2" ms or less.
  • the predetermined quality may be pre-registered in the storage device 12 or may be indicated in the request C1.
  • FIG. 7 is a diagram for explaining the operation of the network system 1.
  • FIG. 7 shows the operation when the node 20 is a transaction request node, the node 30 is a customer node (transaction node), and each of the nodes 40, 50, and 60 is a minor node for the sake of simplification of the description. show.
  • the transaction request node is not limited to the node 20, but may be any of the nodes 30, 40, 50 and 60.
  • the business partner node is not limited to the node 30, and may be any of the nodes 20, 40, 50, and 60.
  • the account node is different from the transaction request node.
  • the minor node is not limited to each of the nodes 40, 50 and 60, and may be, for example, at least one of the nodes 20 and 30. The number of minor nodes is not limited to three.
  • the transaction request node is an example of the first node.
  • a plurality of nodes different from the transaction request node is an example of a plurality of second nodes.
  • Each of the nodes 20, 30, 40, 50 and 60 communicates using the communication device 23 shown in FIG. However, for the sake of brevity, the description of the communication device 23 will be omitted.
  • the management device 10 communicates using the communication device 11 shown in FIG. However, for the sake of brevity, the description of the communication device 11 will be omitted.
  • the operation control unit 251 of the node 20 receives the content information indicating the content of the transaction, and the operation control unit 251 of the node 20 receives the content information based on the content information.
  • FIG. 8 is a diagram showing an example of transaction data D1.
  • the transaction data D1 indicates information D11 indicating a transaction request node, information D12 indicating a transaction partner node, and information D13 indicating transaction details.
  • information D11 indicates node 20 and information D12 indicates node 30.
  • the request unit 252 of the node 20 transmits the request C1 to the management device 10 in step S101 shown in FIG.
  • Request C1 indicates a request for QoS control for communication regarding transaction data D1.
  • the providing unit 131 of the management device 10 issues the one-time pass P1 in step S102.
  • step S103 the providing unit 131 registers the one-time pass P1 in the one-time pass column 122a of the management table 122 (see FIG. 6).
  • the providing unit 131 sets the processing column 122b corresponding to the one-time pass to "not yet" in the management table 122.
  • the quality control unit 132 first identifies the one-time pass (in this case, the one-time pass P1) in which the processing column 122b of the management table 122 is set to "not yet". Subsequently, the quality control unit 132 sets the communication quality of the packet having the specified one-time path to a quality equal to or higher than a predetermined quality. For example, the quality control unit 132 causes the communication devices 71 to 74 to execute priority control and bandwidth control for the packet having the one-time pass P1, so that the communication quality of the packet having the one-time pass P1 is equal to or higher than the predetermined quality. Set to quality.
  • QoS control is started for the communication of the packet having the one-time pass P1.
  • the quality control unit 132 may cause the communication devices 71 to 74 to execute only one of the priority control and the band control.
  • the quality control unit 132 changes the processing column 122b corresponding to the one-time path in which the QoS control is started from the processing column 122b from "not yet” to "finished".
  • step S105 the providing unit 131 provides the one-time pass P1 to the node 20 that is the source of the request C1.
  • Providing the one-time pass P1 to the source of request C1 means approval of request C1.
  • the operation control unit 251 of the node 20 Upon receiving the one-time pass P1, the operation control unit 251 of the node 20 generates first communication data having a plurality of packets M1a in step S106.
  • step S106 the operation control unit 251 of the node 20 generates, for example, a plurality of packets M1a as the first communication data.
  • the plurality of packets M1a are examples of the plurality of first packets.
  • the plurality of packets M1a correspond one-to-one with the plurality of first data E obtained by dividing the transaction data D1.
  • Each of the plurality of packets M1a has the data corresponding to the packet M1a among the plurality of first data E and the one-time pass P1.
  • FIG. 9 is a diagram showing an example of a method for generating a plurality of packets M1a in step S106.
  • the operation control unit 251 of the node 20 first divides the transaction data D1 into a plurality of first data E.
  • the operation control unit 251 of the node 20 generates a packet M1 including the first data E for each first data E.
  • the operation control unit 251 of the node 20 generates a plurality of packets M1a by including the one-time path P1 in each packet M1.
  • step S106 the operation control unit 251 of the node 20 completes step S106
  • step S107 the operation control unit 251 of the node 20 transmits a plurality of packets M1a to the node 40.
  • Each of the plurality of packets M1a has a one-time path P1. Therefore, in step S107, the communication quality of each of the plurality of packets M1a is equal to or higher than the predetermined quality. Therefore, the time required for communication of the plurality of packets M1a (transaction data D1) is shortened.
  • the verification unit 254 of the node 40 receives a plurality of packets M1a from the node 20, the verification unit 254 generates transaction data D1 by using the plurality of packets M1a. Subsequently, in step S108, the verification unit 254 of the node 40 verifies the transaction data D1.
  • step S107 the operation control unit 251 of the node 20 completes step S107
  • step S109 the operation control unit 251 of the node 20 transmits a plurality of packets M1a to the node 30.
  • Each of the plurality of packets M1a has a one-time path P1. Therefore, in step S109, the communication quality of each of the plurality of packets M1a is equal to or higher than the predetermined quality. Therefore, the time required for communication of the plurality of packets M1a (transaction data D1) is shortened.
  • the verification unit 254 of the node 30 receives a plurality of packets M1a from the node 20, the verification unit 254 generates transaction data D1 by using the plurality of packets M1a. Subsequently, in step S110, the verification unit 254 of the node 30 verifies the transaction data D1.
  • Steps S109 to S110 may be executed before steps S107 to S108. Steps S109 to S110 may be performed in parallel with steps S107 to S108. In this case, the time required for steps S107 to S110 can be shortened as compared with the configuration in which steps S107 to S108 and steps S109 to S110 are executed in order.
  • step S111 the operation control unit 251 of the node 40 transmits a plurality of packets M1a to the node 50.
  • Each of the plurality of packets M1a has a one-time path P1. Therefore, in step S111, the communication quality of each of the plurality of packets M1a is equal to or higher than the predetermined quality. Therefore, the time required for communication of the plurality of packets M1a (transaction data D1) is shortened.
  • the verification unit 254 of the node 50 receives a plurality of packets M1a from the node 40, the verification unit 254 generates transaction data D1 by using the plurality of packets M1a. Subsequently, in step S112, the verification unit 254 of the node 50 verifies the transaction data D1.
  • step S111 When the operation control unit 251 of the node 40 completes step S111, it executes a handshake with the node 60. Subsequently, in step S113, the operation control unit 251 of the node 40 transmits a plurality of packets M1a to the node 60. Each of the plurality of packets M1a has a one-time path P1. Therefore, in step S113, the communication quality of each of the plurality of packets M1a is equal to or higher than the predetermined quality. Therefore, the time required for communication of the plurality of packets M1a (transaction data D1) is shortened.
  • the verification unit 254 of the node 60 receives a plurality of packets M1a from the node 40, the verification unit 254 generates transaction data D1 by using the plurality of packets M1a. Subsequently, in step S114, the verification unit 254 of the node 60 verifies the transaction data D1.
  • Steps S113 to S114 may be executed before steps S111 to S112. Steps S113 to S114 may be performed in parallel with steps S111 to S112. In this case, the time required for steps S111 to S114 can be shortened as compared with the configuration in which steps S111 to S112 and steps S113 to S114 are sequentially executed.
  • step S113 the block generation unit 255 of the node 40 starts the generation (mining) of the block B1 including the transaction data D1 in step S115.
  • step S112 the block generation unit 255 of the node 50 starts the generation (mining) of the block B1 including the transaction data D1 in step S116.
  • step S114 the block generation unit 255 of the node 60 starts generation (mining) of the block B1 including the transaction data D1 in step S117.
  • the operation control unit 251 of the node 50 stores the block B1 in the block chain BC in the storage device 24. Connect to.
  • the operation control unit 251 of the node 50 generates the second communication data having the one-time pass P1 in step S119.
  • the node 50 is an example of a receiving node.
  • Nodes 20, 30, 40 and 60 are examples of different nodes belonging to group A1 that are different from the receiving node (node 50), respectively.
  • the second communication data includes a plurality of packets M2a.
  • step S119 the operation control unit 251 of the node 50 generates, for example, a plurality of packets M2a as second communication data.
  • the plurality of packets M2a are examples of the plurality of second packets.
  • the plurality of packets M2a correspond one-to-one with the plurality of second data F obtained by dividing the block B1.
  • Each of the plurality of packets M2a has the data corresponding to the packet M2a among the plurality of second data Fs and the one-time pass P1.
  • FIG. 10 is a diagram showing an example of a method for generating a plurality of packets M2a in step S119.
  • the operation control unit 251 of the node 50 first divides the block B1 into a plurality of second data Fs.
  • the operation control unit 251 of the node 50 generates a packet M2 including the second data F for each second data F.
  • the operation control unit 251 of the node 50 generates a plurality of packets M2a by including the one-time path P1 in each packet M2.
  • step S119 the operation control unit 251 transmits a plurality of packets M2a to the node 40 in step S120.
  • Each of the plurality of packets M2a has a one-time pass P1. Therefore, in step S120, the communication quality of each of the plurality of packets M2a is equal to or higher than the predetermined quality. Therefore, the time required for communication of the plurality of packets M2a (block B1) is shortened.
  • the verification unit 254 of the node 40 When the verification unit 254 of the node 40 receives a plurality of packets M2a from the node 50, the verification unit 254 generates the block B1 by using the plurality of packets M2a. Subsequently, in step S121, the verification unit 254 of the node 40 verifies the block B1. When the verification result of the block B1 is valid, the verification unit 254 of the node 40 connects the block B1 to the blockchain BC in the storage device 24 of the node 40.
  • the operation control unit 251 of the node 40 transmits a plurality of packets M2a to the node 60 in step S122.
  • Each of the plurality of packets M2a has a one-time pass P1. Therefore, in step S122, the communication quality of each of the plurality of packets M2a is equal to or higher than the predetermined quality. Therefore, the time required for communication of the plurality of packets M2a (block B1) is shortened.
  • the verification unit 254 of the node 60 receives a plurality of packets M2a from the node 40, the verification unit 254 generates the block B1 by using the plurality of packets M2a. Subsequently, in step S123, the verification unit 254 of the node 60 verifies the block B1. When the verification result of the block B1 is valid, the verification unit 254 of the node 60 connects the block B1 to the blockchain BC in the storage device 24 of the node 60.
  • the operation control unit 251 of the node 40 transmits a plurality of packets M2a to the node 20 in step S124 following step S122.
  • Each of the plurality of packets M2a has a one-time pass P1. Therefore, in step S124, the communication quality of each of the plurality of packets M2a is equal to or higher than the predetermined quality. Therefore, the time required for communication of the plurality of packets M2a (block B1) is shortened.
  • Step S124 may be executed before step S122 in time, or may be executed in parallel with step S122.
  • the verification unit 254 of the node 20 receives a plurality of packets M2a from the node 40, the verification unit 254 generates the block B1 by using the plurality of packets M2a. Subsequently, in step S125, the verification unit 254 of the node 20 verifies the block B1. When the verification result of the block B1 is valid, the verification unit 254 of the node 20 connects the block B1 to the blockchain BC in the storage device 24 of the node 20.
  • the operation control unit 251 of the node 20 transmits a plurality of packets M2a to the node 30 in step S126.
  • Each of the plurality of packets M2a has a one-time pass P1. Therefore, in step S126, the communication quality of each of the plurality of packets M2a is equal to or higher than the predetermined quality. Therefore, the time required for communication of the plurality of packets M2a (block B1) is shortened.
  • the verification unit 254 of the node 30 receives a plurality of packets M2a from the node 20, the verification unit 254 generates the block B1 by using the plurality of packets M2a. Subsequently, in step S127, the verification unit 254 of the node 30 verifies the block B1. When the verification result of the block B1 is valid, the verification unit 254 of the node 30 connects the block B1 to the blockchain BC in the storage device 24 of the node 20.
  • ⁇ A6 Summary of the first embodiment>
  • the providing unit 131 receives the request C1 requesting the control of the quality of communication for adding data to the blockchain BC from the first node (for example, the node 20)
  • one The time path P1 is provided to the first node.
  • the quality control unit 132 improves the communication quality of the first communication data to a predetermined quality or higher in a situation where the first communication data is communicated within the group A1 after the first node generates the first communication data having the one-time path P1. Set to the quality of.
  • QoS control is executed when the target data T1 is generated. Therefore, the QoS control can be started from the timing when the QoS control is required.
  • the QoS control is performed only for the communication of the data including the target data T1. Can be executed.
  • the QoS control may not be executed for the communication of the transaction data D1.
  • the first modification a modification in which the QoS control is not executed for the communication of the transaction data D1 and the QoS control is executed for the communication of the block B1 including the transaction data D1 will be described as the first modification.
  • the first modification will be described with a focus on the differences from the first embodiment.
  • FIG. 11 is a diagram for explaining the operation of the first modification.
  • the QoS control is started when the node 50 that has succeeded in generating (mining) the block B1 transmits the request C1 to the management device 10.
  • the node 50 is an example of the first node
  • the nodes 20, 30, 40 and 60 are examples of the plurality of second nodes.
  • the operation control unit 251 of the node 20 receives the content information indicating the content of the transaction, and the operation control unit 251 of the node 20 receives the content information based on the content information.
  • the transaction data D1 is transmitted to the node 40 in step S201.
  • the verification unit 254 of the node 40 Upon receiving the transaction data D1 from the node 20, the verification unit 254 of the node 40 verifies the transaction data D1 in step S202. In the following, it is assumed that the verification result of the transaction data D1 is valid.
  • step S201 the operation control unit 251 of the node 20 transmits the transaction data D1 to the node 30 in step S203.
  • the verification unit 254 of the node 30 receives the transaction data D1 from the node 20
  • the verification unit 254 verifies the transaction data D1 in step S204. In the following, it is assumed that the verification result of the transaction data D1 is valid.
  • Steps S203 to S204 may be executed before steps S201 to S202. Steps S203 to S204 may be performed in parallel with steps S201 to S202. In this case, the time required for steps S201 to S204 can be shortened as compared with the configuration in which steps S201 to S202 and steps S203 to S204 are executed in order.
  • step S202 If the verification result of the transaction data D1 in step S202 is valid, the operation control unit 251 of the node 40 transmits the transaction data D1 to the node 50 in step S205.
  • the verification unit 254 of the node 50 receives the transaction data D1 from the node 40, the verification unit 254 verifies the transaction data D1 in step S206. In the following, it is assumed that the verification result of the transaction data D1 is valid.
  • step S205 the operation control unit 251 of the node 40 transmits the transaction data D1 to the node 60 in step S207.
  • the verification unit 254 of the node 60 receives the transaction data D1 from the node 40, the verification unit 254 verifies the transaction data D1 in step S208. In the following, it is assumed that the verification result of the transaction data D1 is valid.
  • Steps S207 to S208 may be executed before steps S205 to S206. Steps S207 to S208 may be performed in parallel with steps S205 to S206. In this case, the time required for steps S205 to S208 can be shortened as compared with the configuration in which steps S205 to S206 and steps S207 to S208 are executed in order.
  • step S207 the block generation unit 255 of the node 40 starts the generation (mining) of the block B1 including the transaction data D1 in step S115.
  • step S206 the block generation unit 255 of the node 50 starts the generation (mining) of the block B1 including the transaction data D1 in step S116.
  • step S208 the block generation unit 255 of the node 60 starts the generation (mining) of the block B1 including the transaction data D1 in step S117.
  • the request unit 252 of the node 50 transmits the request C1 to the management device 10 in step S209.
  • Request C1 indicates a request for QoS control for communication regarding transaction data D1.
  • the providing unit 131 of the management device 10 issues the one-time pass P1 in step S210.
  • step S211 the providing unit 131 registers the one-time pass P1 in the one-time pass column 122a of the management table 122.
  • the providing unit 131 sets the processing column 122b corresponding to the one-time pass to "not yet" in the management table 122.
  • step S212 the quality control unit 132 first identifies the one-time pass (in this case, the one-time pass P1) in which the processing column 122b of the management table 122 is set to "not yet". Subsequently, the quality control unit 132 sets the communication quality of the packet having the specified one-time path to a quality equal to or higher than a predetermined quality.
  • the method of setting the communication quality of the packet having the specified one-time path to a quality equal to or higher than a predetermined quality is the same as the method of step S104.
  • step S213 the providing unit 131 provides the one-time pass P1 to the node 50 that is the source of the request C1.
  • Providing the one-time pass P1 to the source of request C1 means approval of request C1.
  • the second communication data (plurality of packets M2a) generated in step S119 is another example of the first communication data.
  • the plurality of second data F generated by dividing the block B1 is an example of a plurality of data (a plurality of third data) obtained by dividing the block.
  • the plurality of packets M2a are an example of a plurality of packets (a plurality of third packets).
  • the delay in the communication of the block B1 is small, the possibility that the block B1 arrives at each node before the other blocks B1 is high. If the block B1 arrives at each node before the other blocks B1, the probability that the block B1 will be connected to the blockchain BC is high. Therefore, it is desirable that the delay in the communication of the block B1 is small not only for the user who expects the early confirmation of the transaction data D1 but also for the minor node that generates the block B1.
  • the QoS control is not executed for the communication of the transaction data D1, but the QoS control is executed for the communication of the block B1 including the transaction data D1. Therefore, the delay can be reduced in the communication of the block B1. Therefore, as compared with the configuration in which the QoS control is not executed in either the communication of the transaction data D1 or the communication of the block B1 including the transaction data D1, the transaction data D1 can be determined earlier and the block B1 can be determined. Can be connected to the blockchain BC.
  • the quality control unit 132 may return the quality of the communication set to the quality equal to or higher than the predetermined quality to the quality of the communication before the quality is set to the quality equal to or higher than the predetermined quality.
  • Request C1 requests control of the quality of communication related to the transaction data D1 within the group A1. That is, the request C1 is a request for controlling the quality of communication related to the transaction data D1 within the group A1.
  • the transaction data D1 indicates any of the plurality of second nodes as a customer node (see FIG. 8).
  • the quality control unit 132 responds to the notification indicating that the customer node (transaction node) has received the block B1 including the transaction data D1, and the quality of the communication related to the transaction data D1 in the group A1 is equal to or higher than the predetermined quality. To return to the quality before setting the quality to the specified quality or higher.
  • the operation control unit 251 of the node 30 transmits the notification N1 to the management device 10.
  • the notification N1 indicates that the customer node has received the block B1 containing the transaction data D1.
  • the quality control unit 132 of the management device 10 returns the communication quality set to the predetermined quality or higher to the communication quality before being set to the predetermined quality or higher in response to the notification N1.
  • the quality control unit 132 responds to the reception of the notification N1 by receiving the information registered in the management table 122 (one-time pass P1) and the information set in the management table 122 (“not” and “finished”). And delete it.
  • the quality control unit 132 then executes communication quality control using the management table 122 (for example, the control method in step S104). In this case, the communication devices 71 to 74 return to the state before being controlled by the quality control unit 132 (for example, a predetermined state).
  • the quality control unit 132 changes the communication quality set to the predetermined quality or higher to the quality equal to or higher than the predetermined quality. Restore the communication quality before setting.
  • the predetermined time is not limited to 2 minutes, and may be longer than 2 minutes or shorter than 2 minutes. It is desirable that the predetermined time is longer than the time until the new block B1 reaches all the nodes in the group A1.
  • the second modification it is possible to prevent the communication quality in the group A1 from becoming high quality for a longer time than necessary.
  • the storage devices 12 and 24 are a flexible disk, a photomagnetic disk (for example, a compact disk, a digital versatile disk, a Blu-ray (for example). Disks), smart cards, flash memory devices (eg, cards, sticks, key drives), CD-ROMs (Compact Disc-ROMs), registers, removable disks, hard disks, floppy disks, magnetic strips, It may include a database, server or other suitable storage medium.
  • the program may also be transmitted from the network via a telecommunication line.
  • Each of the first embodiment and the first modification to the second modification is LTE (Long Term Evolution), LTE-A (LTE-Advanced), SUPER 3G, IMT-Advanced, 4G, 5G, FRA ( Future Radio Access), W-CDMA (registered trademark), GSM (registered trademark), CDMA2000, UMB (Ultra Mobile Broadband), IEEE 802.11 (Wi-Fi), LTE 802.16 (WiMAX), IEEE 802.20 , UWB (Ultra-WideBand), Bluetooth®, and other systems that utilize suitable systems and / or extended next-generation systems based on them.
  • the input / output information and the like may be stored in a specific place (for example, a memory) or may be managed by a table. good. Information to be input / output may be overwritten, updated, or added. The output information and the like may be deleted. The input information or the like may be transmitted to another device.
  • the determination may be made based on the value (0 or 1) represented by 1 bit, or the truth value. It may be performed based on (Boolean: true or false), or it may be performed based on a numerical comparison (for example, a comparison with a predetermined value).
  • Each function exemplified in FIG. 4 or FIG. 5 is realized by any combination of hardware and software. Further, each function may be realized by a single device, or may be realized by two or more devices configured as separate bodies from each other.
  • the programs exemplified in each of the first embodiment and the first modification to the second modification may be referred to as software, firmware, middleware, microcode or hardware description language, or may be referred to by other names.
  • software instruction sets, codes, code segments, program codes, subprograms, software modules, applications, software applications, software packages, routines, subroutines, objects, executable files, execution threads, procedures or functions, etc. It should be broadly interpreted.
  • software, instructions, and the like may be transmitted and received via a transmission medium.
  • the software may use wired technology such as coaxial cable, fiber optic cable, twist pair and digital subscriber line (DSL) and / or wireless technology such as infrared, wireless and microwave to website, server, or other. When transmitted from a remote source, these wired and / or wireless technologies are included within the definition of transmission medium.
  • DSL digital subscriber line
  • At least one of the nodes 20, 30, 40, 50 and 60 may be a mobile station.
  • Mobile stations can be used by those skilled in the art as subscriber stations, mobile units, subscriber units, wireless units, remote units, mobile devices, wireless devices, wireless communication devices, remote devices, mobile subscriber stations, access terminals, mobile terminals, wireless. It may also be referred to using a terminal, remote terminal, handset, user agent, mobile client, client, or some other suitable term.
  • the term “device” may be read as another term such as a circuit, a device, or a unit.
  • the management device includes a providing unit and a quality control unit.
  • the provider controls the quality of the communication within a group composed of a first node having a blockchain together and performing communication for adding additional data to the blockchain and a plurality of second nodes.
  • the control request for the purpose is received from the first node, the first information corresponding to the control request is provided to the first node.
  • the quality control unit is in a situation where the first communication data is communicated within the group after the first node generates the first communication data having the first information, and the quality control unit communicates with the first communication data. Set the quality to the quality of the first quality or higher.
  • Communication for adding additional data to the blockchain is executed in the situation where data is communicated within the group.
  • the communication quality of the first communication data having the first information can be set to the quality of the first quality or higher. Therefore, if the first node generates communication data including additional data added to the blockchain and the first information as the first communication data, the delay in the timing at which the additional data is added to the blockchain is reduced. can. Therefore, it is possible to assist the node in reducing the delay in the timing of adding data to the blockchain.
  • the additional data is the target data to be included in the block to be connected to the blockchain.
  • the control request can be provided to the providing unit according to the generation of the target data.
  • the first communication data has a plurality of first packets.
  • the plurality of first packets correspond one-to-one with the plurality of first data obtained by dividing the target data.
  • Each of the plurality of first packets has the data corresponding to the first packet among the plurality of first data and the first information.
  • the communication quality of the first communication data regarding the target data can be set to the quality of the first quality or higher.
  • the receiving node that has received the first communication data among the plurality of second nodes has the first information.
  • the communication quality of the second communication data is determined by the first. Set the quality to be higher than the quality.
  • the communication quality of the second communication data generated by the receiving node that has received the first communication data can be set to the quality of the first quality or higher.
  • the second communication data has a plurality of second packets.
  • the plurality of second packets correspond one-to-one with the plurality of second data obtained by dividing the block.
  • Each of the plurality of second packets has the data corresponding to the second packet among the plurality of second data and the first information.
  • the communication quality of the second communication data regarding the block can be set to the quality of the first quality or higher.
  • the additional data is a block to be connected to the blockchain.
  • the control request can be provided to the providing unit, for example, in response to the generation of the block to be connected to the blockchain.
  • the first communication data has a plurality of third packets.
  • the plurality of third packets correspond one-to-one with the plurality of third data obtained by dividing the block.
  • Each of the plurality of third packets has the data corresponding to the third packet among the plurality of third data and the first information.
  • the communication quality of the first communication data regarding the block can be set to the quality of the first quality or higher.
  • the additional data is transaction data communicated within the group.
  • the control request is a request for controlling the quality of communication related to the transaction data.
  • the transaction data indicates any of the plurality of second nodes as a transaction node.
  • the quality control unit returns the quality of the communication to the quality before setting the quality to the first quality or higher in response to the notification indicating that the transaction node has received the block containing the transaction data. According to this aspect, it is possible to prevent the quality of communication in the group from becoming high quality for a longer time than necessary.
  • the quality control unit has not set the quality of the communication to the quality of the first quality or higher when the first time has elapsed from the reception of the notification. Return to quality. According to this aspect, it is possible to increase the possibility of maintaining the quality of communication in the group at the quality of the first quality or higher until the block reaches all the nodes in the group.

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)

Abstract

管理装置は、ブロックチェーンを共に有し前記ブロックチェーンに追加データを追加するための通信を実行する第1ノードと複数の第2ノードとによって構成されるグループ内での前記通信の品質を制御をするための制御要求を、前記第1ノードから受信する場合、前記制御要求に対応する第1情報を、前記第1ノードに提供する提供部と、前記第1ノードが、前記第1情報を有する第1通信データを生成した後に、前記第1通信データが前記グループ内で通信される状況において、前記第1通信データの通信の品質を、第1品質以上の品質に設定する品質制御部と、を含む。

Description

管理装置
 本発明は、管理装置に関する。
 ブロックチェーンを用いるシステムが知られている(例えば、特許文献1参照)。ブロックチェーンは、取引データ等のデータに関するデータベースである。ブロックチェーンは、直列に接続された複数のブロックを含む。各ブロックは、取引データ等のデータを含む。ブロックチェーンは、複数のノードによって共有される。複数のノードのいずれかのノードが、ブロックチェーンに追加されるべき追加データ(例えば、取引データ又はブロック)を生成すると、追加データは、複数のノードの間で通信され、ブロックチェーンに追加される。
特開2019-213161号公報
 追加データの通信に時間がかかると、追加データをブロックチェーンに追加するタイミングが遅くなってしまう。このため、追加データをブロックチェーンに追加するタイミングの遅延を小さくするためにノードを支援する技術が望まれる。
 本発明の目的は、データをブロックチェーンに追加するタイミングの遅延を小さくするためにノードを支援する技術を提供することである。
 本発明の一態様に係る管理装置は、ブロックチェーンを共に有し前記ブロックチェーンに追加データを追加するための通信を実行する第1ノードと複数の第2ノードとによって構成されるグループ内での前記通信の品質を制御するための制御要求を、前記第1ノードから受信する場合、前記制御要求に対応する第1情報を、前記第1ノードに提供する提供部と、前記第1ノードが、前記第1情報を有する第1通信データを生成した後に、前記第1通信データが前記グループ内で通信される状況において、前記第1通信データの通信の品質を、第1品質以上の品質に設定する品質制御部と、を含む。
 本発明の一態様によれば、データをブロックチェーンに追加するタイミングの遅延を小さくするためにノードを支援できる。
ネットワークシステム1を示す図である。 ブロックチェーンBCの一例を示す図である。 ネットワークNWの一例を示す図である。 ノード20の一例を示す図である。 管理装置10の一例を示す図である。 管理テーブル122の一例を示す図である。 ネットワークシステム1の動作を説明するための図である。 取引データD1の一例を示す図である。 複数のパケットM1aを生成する手法の一例を示す図である。 複数のパケットM2aを生成する手法の一例を示す図である。 第1変形例の動作を説明するための図である。
 <A:第1実施形態>
 <A1:ネットワークシステム1>
 図1は、ネットワークシステム1を示す図である。ネットワークシステム1は、ネットワークNWと、管理装置10と、を含む。ネットワークNWは、ノード20、30、40、50及び60のグループA1を含む。ネットワークNWは、グループA1に属さない複数のノードも含む。
 ノード20は、第1ノードの一例である。ノード30、40、50及び60は、複数の第2ノードの一例である。ノード30、40、50及び60の各々は、第2ノードの一例である。第2ノードの数は、4に限らず2以上であればよい。グループA1は、第1ノードと複数の第2ノードとによって構成されるグループの一例である。
 ノード20、30、40、50及び60は、P2P(Peer to Peer)ネットワークを構成する。P2Pネットワークの構成は、図1に示される構成に限らず適宜変更可能である。
 ノード20、30、40、50及び60の各々は、共通のブロックチェーンBCを保有する。すなわち、ノード20、30、40、50及び60は、ブロックチェーンBCを共に有する。
 図2は、ブロックチェーンBCの一例を示す図である。ブロックチェーンBCは、直列に接続された複数のブロックB1を含む。各ブロックB1は、ブロック関連データQ1と、対象データT1と、を含む。
 ブロック関連データQ1は、直前のブロックB1に含まれるデータに基づいている。ブロック関連データQ1は、例えば、直前のブロックB1に含まれるデータに基づくハッシュ値である。ブロック関連データQ1は、ブロックチェーンBCにおけるデータの改ざんへの耐性に寄与する。
 対象データT1は、例えば、取引データD1である。取引データD1は、例えば、暗号資産の取引に関するデータである。暗号資産は、仮想通過又は電子通貨とも称される。取引データD1は、暗号資産の取引に関するデータに限らない。取引データD1は、例えば、不動産の取引に関するデータ、動産の取引に関するデータ、又は、情報の取引に関するデータでもよい。取引データD1は、トランザクションとも称される。対象データT1は、取引データD1に限らず、例えば、契約書等の情報のやり取りに関するデータでもよい。ブロックチェーンBCは、対象データT1を管理するデータベースの一例である。
 以下、説明の簡略化のため、対象データT1が取引データD1である例を説明する。取引データD1は、複数のノード20、30、40、50及び60の各々によって生成可能である。
 取引データD1は、取引データD1の生成元であるノードから、複数のノード20、30、40、50及び60のうち取引データD1の生成元とは異なるノードに伝搬される。複数のノード20、30、40、50及び60の各々は、取引データD1を受け取ると、当該取引データD1を検証する。
 ブロックB1は、複数のノード20、30、40、50及び60のうち、マイナーノードと称されるノードによって生成される。マイナーノードは、複数の取引データD1を1つのブロックB1にまとめる。
 ブロックB1は、ブロックB1の生成元であるマイナーノードから、複数のノード20、30、40、50及び60のうちブロックB1の生成元とは異なるノードに伝搬される。複数のノード20、30、40、50及び60の各々は、ブロックB1を受け取ると、当該ブロックB1を検証する。
 複数のノード20、30、40、50及び60の各々は、ブロックB1の検証結果が有効を示す場合、当該ブロックB1を既存のブロックチェーンBCに追加する。ブロックB1を既存のブロックチェーンBCに追加することは、ブロックB1を既存のブロックチェーンBCに接続することを意味する。ブロックB1、対象データT1及び取引データD1の各々は、所定データの一例である。所定データは、追加データの一例である。
 ノード20、30、40、50及び60の各々は、ブロックチェーンBCに取引データD1を追加するための通信を実行する。以下「ブロックチェーンBCに取引データD1を追加するための通信」を「データ追加用通信」とも称する。データ追加用通信の一例は、取引データD1の通信である。データ追加用通信の他の例は、取引データD1を含むブロックB1の通信である。ネットワークNWにおいて、取引データD1等のデータ及びブロックB1は、パケットによって通信される。
 取引データD1がブロックチェーンBCに追加されるタイミングが早いほど、取引データD1が確定したとみなされるタイミングは早くなる。管理装置10は、データ追加用通信の品質を制御することによって、取引データD1がブロックチェーンBCに追加されるタイミングの遅延を小さくする。管理装置10は、取引データD1がブロックチェーンBCに追加されるタイミングの遅延を小さくすることによって、取引データD1が確定したとみなされるタイミングを早くする。管理装置10は、取引データD1が確定したとみなされるタイミングを早くすることによって、ノード20、30、40、50及び60のうち少なくとも1つのノードを支援する。
 図3は、ネットワークNWの一例を示す図である。ネットワークNWは、ノード20、30、40、50及び60に加えて、通信装置71、72、73及び74を含む。通信装置71、72、73及び74の各々は、例えば、ルータである。ノード20、30、40、50及び60と、通信装置71、72、73及び74は、管理装置10と通信可能である。
 管理装置10は、通信装置71、72、73及び74の少なくとも1つに、優先制御及び帯域制御の少なくとも一方を実行させることによって、ネットワークNWにおける通信の品質を制御する。
 優先制御は、例えば、特定の通信に係るパケットを優先的に転送する制御である。優先制御が実行されると、特定の通信において、低遅延、スループットの向上、高速化、及び高信頼性等が実現される。帯域制御は、通信に使用される帯域の広さを調節する制御である。帯域制御によって通信の帯域が広がると、通信において、例えば、低遅延、スループットの向上、高速化、及び高信頼性等が実現される。優先制御及び帯域制御の各々は、QoS(Quality of Service)制御の一例である。
 管理装置10は、通信装置71、72、73及び74の少なくとも1つにQoS制御を実行させることによって、取引データD1がブロックチェーンBCに追加されるタイミングの遅延を小さくする。
 <A2:ノード20>
 ノード20は、パーソナルコンピュータである。ノード20は、パーソナルコンピュータに限らず、例えば、スマートフォン又はタブレットでもよい。ノード20は、データ追加用通信(ブロックチェーンBCに取引データD1を追加するための通信)をノード30及び40の各々と実行する。
 図4は、ノード20の一例を示す図である。ノード20は、入力装置21と、出力装置22と、通信装置23と、記憶装置24と、処理装置25と、を含む。
 入力装置21は、キーボードを含む。入力装置21は、マウス及びタッチパネルの少なくとも一方を含んでもよい。入力装置21は、タッチパネルを含む場合、キーボード及びマウスの少なくとも一方を含まなくてもよい。入力装置21は、ユーザが行う操作を受け付ける。
 出力装置22は、ディスプレイを含む。出力装置22は、タッチパネルを含んでもよい。出力装置22は、種々の情報を表示する。出力装置22は、タッチパネルを含む場合、ディスプレイを含まなくてもよい。タッチパネルが、入力装置21及び出力装置22として用いられてもよい。
 通信装置23は、ルータ等の通信装置71を介してノード30と通信する。通信装置23は、ルータ等の通信装置72を介してノード40と通信する。通信装置23は、さらに、管理装置10と通信する。
 記憶装置24は、処理装置25が読み取り可能な記録媒体である。記憶装置24は、例えば、不揮発性メモリーと揮発性メモリーとを含む。不揮発性メモリーは、例えば、ROM(Read Only Memory)、EPROM(Erasable Programmable Read Only Memory)及びEEPROM(Electrically Erasable Programmable Read Only Memory)である。揮発性メモリーは、例えば、RAM(Random Access Memory)である。記憶装置24は、アプリケーションプログラム241と、ブロックチェーンBCと、を記憶する。
 処理装置25は、1又は複数のCPU(Central Processing Unit)を含む。1又は複数のCPUは、1又は複数のプロセッサの一例である。プロセッサ及びCPUの各々は、コンピュータの一例である。
 処理装置25は、記憶装置24からアプリケーションプログラム241を読み取る。処理装置25は、アプリケーションプログラム241を実行することによって、動作制御部251、要求部252、検証部254及びブロック生成部255として機能する。
 動作制御部251は、DSP(Digital Signal Processor)、ASIC(Application Specific Integrated Circuit)、PLD(Programmable Logic Device)及びFPGA(Field Programmable Gate Array)等の回路によって実現されてもよい。要求部252、検証部254及びブロック生成部255のうち少なくとも1つは、DSP、ASIC、PLD及びFPGA等の回路によって実現されてもよい。
 動作制御部251は、ブロックチェーンBCに取引データD1を追加するための通信、すなわち、データ追加用通信を制御する。
 要求部252は、要求C1を管理装置10に送信する。要求C1は、取引データD1に関する通信についてのQoS制御の要求を示す。取引データD1に関する通信は、取引データD1の通信と、取引データD1を含むブロックB1の通信と、を含む。すなわち、取引データD1に関する通信は、ブロックチェーンBCに取引データD1を追加するための通信の全体を意味する。取引データD1に関する通信は、データ追加用通信の一例である。QoS制御は、通信の品質の制御の一例である。要求C1は、ブロックチェーンBCに所定データを追加するための通信の品質の制御を要求する制御要求の一例である。制御要求は、ブロックチェーンBCに所定データ(追加データ)を追加するための通信の品質を制御するための要求である。
 検証部254は、他のノードが生成した取引データD1を検証する。検証部254は、他のノードが生成したブロックB1を検証する。
 ブロック生成部255は、取引データD1を含むブロックB1を生成する。例えば、ブロック生成部255は、複数の取引データD1を1つのブロックB1にまとめる。
 <A3:ノード30、40、50及び60>
 ノード30、40、50及び60の各々は、ノード20が有する構成要素と同様の構成要素を有する。ノード30は、データ追加用通信(ブロックチェーンBCに取引データD1を追加するための通信)をノード20と実行する。ノード40は、データ追加用通信をノード20、50及び60の各々と実行する。ノード50は、データ追加用通信をノード40と実行する。ノード60は、データ追加用通信をノード40と実行する。
 <A4:管理装置10>
 図5は、管理装置10の一例を示す図である。管理装置10は、サーバである。管理装置10は、通信装置11と、記憶装置12と、処理装置13と、を含む。
 通信装置11は、ノード20、30、40、50及び60の各々と直接的又は間接的に通信する。通信装置11は、通信装置71、72、73及び74の各々と直接的又は間接的に通信する。
 記憶装置12は、処理装置13が読み取り可能な記録媒体である。記憶装置12は、例えば、不揮発性メモリーと揮発性メモリーとを含む。記憶装置12は、プログラム121と、管理テーブル122と、を記憶する。図6は、管理テーブル122の一例を示す図である。管理テーブル122は、ノード20、30、40、50及び60の各々が実行する通信についてのQoS制御を管理するために用いられる。
 説明を図5に戻す。処理装置13は、1又は複数のCPUを含む。処理装置13は、記憶装置12からプログラム121を読み取る。処理装置13は、プログラム121を実行することによって、提供部131及び品質制御部132として機能する。提供部131及び品質制御部132の少なくとも1つは、DSP、ASIC、PLD及びFPGA等の回路によって実現されてもよい。
 提供部131は、要求C1を第1ノード(例えば、ノード20)から受信する場合、ワンタイムパスP1を第1ノードに提供する。ワンタイムパスP1は、要求C1に示された制御を実行するために使用される。
 第1ノードは、ワンタイムパスP1を受信すると、ワンタイムパスP1を有する第1通信データを生成する。第1通信データは、複数のパケットM1aを有する。複数のパケットM1aの各々は、ワンタイムパスP1と、取引データD1の一部と、を有する。複数のパケットM1aの各々は、グループA1内で通信される。複数のパケットM1aの各々は、複数の第2ノードの各々に伝播する。
 品質制御部132は、ワンタイムパスP1を有するデータの通信の品質を制御する。ワンタイムパスP1を有するデータの一例は、パケットM1aである。例えば、品質制御部132は、パケットM1aがグループA1内で通信される状況において、パケットM1aの通信の品質を、所定品質以上の品質に設定する。所定品質は、第1品質の一例である。
 所定品質は、例えば、通信帯域が「X1」Mbpsである通信品質である。「X1」は正数である。この場合、所定品質以上の品質は、通信帯域が「X1」Mbps以上である品質を意味する。所定品質は、通信帯域が「X1」Mbpsである通信品質に限らず、例えば、遅延が「X2」msである通信品質でもよい。「X2」は正数である。この場合、所定品質以上の品質は、遅延が「X2」ms以下である品質を意味する。所定品質は、記憶装置12に予め登録されてもよいし、要求C1に示されてもよい。
 <A5:動作の説明>
 図7は、ネットワークシステム1の動作を説明するための図である。図7は、説明の簡略化のため、ノード20が取引要求ノードであり、ノード30が取引先ノード(取引ノード)であり、ノード40、50及び60の各々がマイナーノードである場合における動作を示す。
 取引要求ノードは、ノード20に限らず、ノード30、40、50及び60のいずれかでもよい。取引先ノードは、ノード30に限らず、ノード20、40、50及び60のいずれかでもよい。取引先ノードは、取引要求ノードと異なる。マイナーノードは、ノード40、50及び60の各々に限らず、例えば、ノード20及び30の少なくとも一方でもよい。マイナーノードの数は、3に限らない。
 図7に示される例では、取引要求ノードが第1ノードの一例である。取引要求ノードと異なる複数のノードが複数の第2ノードの一例である。
 ノード20、30、40、50及び60の各々は、図4に示される通信装置23を用いて通信を行う。しかしながら、説明の簡略化のため、通信装置23に関する記載を省略する。管理装置10は、図5に示される通信装置11を用いて通信を行う。しかしながら、説明の簡略化のため、通信装置11に関する記載を省略する。
 ノード20の入力装置21が、ノード20のユーザから、ブロックチェーンBCに新たに追加されるべき取引の内容を示す内容情報を受け取ると、ノード20の動作制御部251は、内容情報に基づいて、取引データD1を生成する。
 図8は、取引データD1の一例を示す図である。取引データD1は、取引要求ノードを示す情報D11と、取引先ノードを示す情報D12と、取引内容を示す情報D13と、を示す。図7に示される例では、情報D11はノード20を示し、情報D12はノード30を示す。
 ノード20の動作制御部251が取引データD1を生成すると、図7に示されるステップS101においてノード20の要求部252が、要求C1を管理装置10に送信する。要求C1は、取引データD1に関する通信についてのQoS制御の要求を示す。
 管理装置10の提供部131は、要求C1をノード20から受信する場合、ステップS102において、ワンタイムパスP1を発行する。
 続いて、ステップS103において提供部131は、ワンタイムパスP1を、管理テーブル122のワンタイムパスの欄122aに登録する(図6参照)。
 提供部131は、ワンタイムパスの欄122aにワンタイムパスを新たに登録する場合、管理テーブル122において当該ワンタイムパスに対応する処理の欄122bを「未」に設定する。
 続いて、ステップS104において品質制御部132は、まず、管理テーブル122の処理の欄122bが「未」に設定されているワンタイムパス(この場合、ワンタイムパスP1)を特定する。続いて、品質制御部132は、特定したワンタイムパスを有するパケットの通信の品質を、所定品質以上の品質に設定する。例えば、品質制御部132は、ワンタイムパスP1を有するパケットについて通信装置71~74に優先制御及び帯域制御を実行させることによって、ワンタイムパスP1を有するパケットの通信の品質を、所定品質以上の品質に設定する。
 このため、ワンタイムパスP1を有するパケットの通信について、QoS制御が開始される。なお、品質制御部132は、通信装置71~74に、優先制御及び帯域制御のいずれか一方のみを実行させてもよい。
 続いて、品質制御部132は、処理の欄122bのうち、QoS制御が開始されたワンタイムパスに対応する処理の欄122bを、「未」から「済」に変更する。
 続いて、ステップS105において提供部131は、要求C1の送信元であるノード20に、ワンタイムパスP1を提供する。ワンタイムパスP1を要求C1の送信元に提供することは、要求C1の承認を意味する。
 ノード20の動作制御部251は、ワンタイムパスP1を受信すると、ステップS106において複数のパケットM1aを有する第1通信データを生成する。
 ステップS106では、ノード20の動作制御部251は、例えば、複数のパケットM1aを第1通信データとして生成する。複数のパケットM1aは、複数の第1パケットの一例である。複数のパケットM1aは、取引データD1を分割することによって得られる複数の第1データEと1対1に対応する。複数のパケットM1aの各々は、複数の第1データEのうち当該パケットM1aに対応するデータと、ワンタイムパスP1と、を有する。
 図9は、ステップS106において複数のパケットM1aを生成する手法の一例を示す図である。
 ノード20の動作制御部251は、まず、取引データD1を、複数の第1データEに分割する。
 続いて、ノード20の動作制御部251は、第1データEごとに、当該第1データEを含むパケットM1を生成する。
 続いて、ノード20の動作制御部251は、各パケットM1にワンタイムパスP1を含めることによって、複数のパケットM1aを生成する。
 説明を図7に戻す。ノード20の動作制御部251は、ステップS106を完了すると、ノード40とハンドシェイクを実行する。続いて、ステップS107においてノード20の動作制御部251は、複数のパケットM1aをノード40に送信する。複数のパケットM1aの各々は、ワンタイムパスP1を有する。このため、ステップS107において複数のパケットM1aの各々の通信の品質は、所定品質以上となる。したがって、複数のパケットM1a(取引データD1)の通信に要する時間が短くなる。
 ノード40の検証部254は、ノード20から複数のパケットM1aを受信すると、複数のパケットM1aを用いることによって取引データD1を生成する。続いて、ステップS108においてノード40の検証部254は、取引データD1を検証する。
 ノード20の動作制御部251は、ステップS107を完了すると、ノード30とハンドシェイクを実行する。続いて、ステップS109においてノード20の動作制御部251は、複数のパケットM1aをノード30に送信する。複数のパケットM1aの各々は、ワンタイムパスP1を有する。このため、ステップS109において複数のパケットM1aの各々の通信の品質は、所定品質以上となる。したがって、複数のパケットM1a(取引データD1)の通信に要する時間が短くなる。
 ノード30の検証部254は、ノード20から複数のパケットM1aを受信すると、複数のパケットM1aを用いることによって取引データD1を生成する。続いて、ステップS110においてノード30の検証部254は、取引データD1を検証する。
 ステップS109~S110は、ステップS107~S108よりも時間的に前に実行されてもよい。ステップS109~S110は、ステップS107~S108と並行に実施されてもよい。この場合、ステップS107~S108とステップS109~S110とを順番に実行する構成に比べてステップS107~S110に要する時間を短縮できる。
 ノード40の検証部254が取引データD1を有効と判定すると、ノード40の動作制御部251は、ノード50とハンドシェイクを実行する。続いて、ステップS111において、ノード40の動作制御部251は、複数のパケットM1aをノード50に送信する。複数のパケットM1aの各々は、ワンタイムパスP1を有する。このため、ステップS111において複数のパケットM1aの各々の通信の品質は、所定品質以上となる。したがって、複数のパケットM1a(取引データD1)の通信に要する時間が短くなる。
 ノード50の検証部254は、ノード40から複数のパケットM1aを受信すると、複数のパケットM1aを用いることによって取引データD1を生成する。続いて、ステップS112においてノード50の検証部254は、取引データD1を検証する。
 ノード40の動作制御部251は、ステップS111を完了すると、ノード60とハンドシェイクを実行する。続いて、ステップS113においてノード40の動作制御部251は、複数のパケットM1aをノード60に送信する。複数のパケットM1aの各々は、ワンタイムパスP1を有する。このため、ステップS113において複数のパケットM1aの各々の通信の品質は、所定品質以上となる。したがって、複数のパケットM1a(取引データD1)の通信に要する時間が短くなる。
 ノード60の検証部254は、ノード40から複数のパケットM1aを受信すると、複数のパケットM1aを用いることによって取引データD1を生成する。続いて、ステップS114においてノード60の検証部254は、取引データD1を検証する。
 ステップS113~S114は、ステップS111~S112よりも時間的に前に実行されてもよい。ステップS113~S114は、ステップS111~S112と並行に実施されてもよい。この場合、ステップS111~S112とステップS113~S114とを順番に実行する構成に比べてステップS111~S114に要する時間を短縮できる。
 ステップS113が完了すると、ノード40のブロック生成部255は、ステップS115において、取引データD1を含むブロックB1の生成(マイニング)を開始する。
 ステップS112が完了すると、ノード50のブロック生成部255は、ステップS116において、取引データD1を含むブロックB1の生成(マイニング)を開始する。
 ステップS114が完了すると、ノード60のブロック生成部255は、ステップS117において、取引データD1を含むブロックB1の生成(マイニング)を開始する。
 ノード50のブロック生成部255が、ステップS118において取引データD1を含むブロックB1の生成(マイニング)に成功すると、ノード50の動作制御部251は、当該ブロックB1を、記憶装置24内のブロックチェーンBCに接続する。
 続いて、ノード50の動作制御部251は、ステップS119においてワンタイムパスP1を有する第2通信データを生成する。この場合、ノード50は、受信ノードの一例である。ノード20、30、40及び60は、それぞれ、グループA1に属するノードのうち受信ノード(ノード50)とは異なる相違ノードの一例である。第2通信データは、複数のパケットM2aを含む。
 ステップS119では、ノード50の動作制御部251は、例えば、複数のパケットM2aを第2通信データとして生成する。複数のパケットM2aは、複数の第2パケットの一例である。複数のパケットM2aは、ブロックB1を分割することによって得られる複数の第2データFと1対1に対応する。複数のパケットM2aの各々は、複数の第2データFのうち当該パケットM2aに対応するデータと、ワンタイムパスP1とを有する。
 図10は、ステップS119において複数のパケットM2aを生成する手法の一例を示す図である。
 ノード50の動作制御部251は、まず、ブロックB1を、複数の第2データFに分割する。
 続いて、ノード50の動作制御部251は、第2データFごとに、当該第2データFを含むパケットM2を生成する。
 続いて、ノード50の動作制御部251は、各パケットM2にワンタイムパスP1を含めることによって、複数のパケットM2aを生成する。
 説明を図7に戻す。ノード50の動作制御部251は、ステップS119を完了すると、ステップS120において複数のパケットM2aをノード40に送信する。複数のパケットM2aの各々は、ワンタイムパスP1を有する。このため、ステップS120において複数のパケットM2aの各々の通信の品質は、所定品質以上となる。したがって、複数のパケットM2a(ブロックB1)の通信に要する時間が短くなる。
 ノード40の検証部254は、ノード50から複数のパケットM2aを受信すると、複数のパケットM2aを用いることによってブロックB1を生成する。続いて、ステップS121においてノード40の検証部254は、ブロックB1を検証する。ブロックB1の検証結果が有効を示す場合、ノード40の検証部254は、ブロックB1を、ノード40の記憶装置24内のブロックチェーンBCに接続する。
 続いて、ノード40の動作制御部251は、ステップS122において複数のパケットM2aをノード60に送信する。複数のパケットM2aの各々は、ワンタイムパスP1を有する。このため、ステップS122において複数のパケットM2aの各々の通信の品質は、所定品質以上となる。このため、複数のパケットM2a(ブロックB1)の通信に要する時間が短くなる。
 ノード60の検証部254は、ノード40から複数のパケットM2aを受信すると、複数のパケットM2aを用いることによってブロックB1を生成する。続いて、ステップS123においてノード60の検証部254は、ブロックB1を検証する。ブロックB1の検証結果が有効を示す場合、ノード60の検証部254は、ブロックB1を、ノード60の記憶装置24内のブロックチェーンBCに接続する。
 ノード40の動作制御部251は、ステップS122に続いて、ステップS124において複数のパケットM2aをノード20に送信する。複数のパケットM2aの各々は、ワンタイムパスP1を有する。このため、ステップS124において複数のパケットM2aの各々の通信の品質は、所定品質以上となる。このため、複数のパケットM2a(ブロックB1)の通信に要する時間が短くなる。
 ステップS124は、ステップS122よりも時間的に前に実行されてもよいし、ステップS122と並行に実行されてもよい。
 ノード20の検証部254は、ノード40から複数のパケットM2aを受信すると、複数のパケットM2aを用いることによってブロックB1を生成する。続いて、ステップS125においてノード20の検証部254は、ブロックB1を検証する。ブロックB1の検証結果が有効を示す場合、ノード20の検証部254は、ブロックB1を、ノード20の記憶装置24内のブロックチェーンBCに接続する。
 続いて、ノード20の動作制御部251は、ステップS126において複数のパケットM2aをノード30に送信する。複数のパケットM2aの各々は、ワンタイムパスP1を有する。このため、ステップS126において複数のパケットM2aの各々の通信の品質は、所定品質以上となる。このため、複数のパケットM2a(ブロックB1)の通信に要する時間が短くなる。
 ノード30の検証部254は、ノード20から複数のパケットM2aを受信すると、複数のパケットM2aを用いることによってブロックB1を生成する。続いて、ステップS127においてノード30の検証部254は、ブロックB1を検証する。ブロックB1の検証結果が有効を示す場合、ノード30の検証部254は、ブロックB1を、ノード20の記憶装置24内のブロックチェーンBCに接続する。
 <A6:第1実施形態のまとめ>
 第1実施形態によれば、提供部131は、ブロックチェーンBCにデータを追加するための通信の品質の制御を要求する要求C1を、第1ノード(例えば、ノード20)から受信する場合、ワンタイムパスP1を、第1ノードに提供する。品質制御部132は、第1ノードがワンタイムパスP1を有する第1通信データを生成した後に第1通信データがグループA1内で通信される状況において第1通信データの通信の品質を所定品質以上の品質に設定する。
 グループA1内でデータが通信される状況において、ブロックチェーンBCにデータを追加するための通信が実行される。このため、第1ノードが、ブロックチェーンBCに追加される対象データT1とワンタイムパスワードとを含む通信データを、第1通信データとして生成すれば、対象データT1がブロックチェーンBCに追加されるタイミングの遅延を小さくできる。したがって、対象データT1をブロックチェーンBCに追加するタイミングの遅延を小さくするためにノードを支援できる。
 また、対象データT1の生成を契機にQoS制御が実行される。このため、QoS制御が必要なタイミングから、QoS制御を開始することができる。
 また、第1ノードが、ブロックチェーンBCに追加される対象データT1とワンタイムパスワードとを含む通信データを、第1通信データとして生成すれば、対象データT1を含むデータの通信についてのみ、QoS制御を実行することができる。
 <B:変形例>
 上述の実施形態における変形の態様を以下に示す。以下の変形の態様から任意に選択された2以上の態様を、相互に矛盾しない範囲において適宜に併合してもよい。
 <B1:第1変形例>
 第1実施形態において、取引データD1の通信についてQoS制御が実行されなくてもよい。
 第1実施形態において、取引データD1の通信にはQoS制御が実行されずに、取引データD1を含むブロックB1の通信にQoS制御が実行される変形例を、第1変形例として説明する。以下、第1実施形態と異なる点を中心に第1変形例について説明する。
 第1変形例におけるハードウェア構成は、第1実施形態におけるハードウェア構成と同様である。図11は、第1変形例の動作を説明するための図である。
 第1変形例では、ブロックB1の生成(マイニング)に成功したノード50が要求C1を管理装置10に送信することを契機として、QoS制御が開始される。この場合、ノード50が第1ノードの一例となり、ノード20、30、40及び60が複数の第2ノードの一例となる。
 ノード20の入力装置21が、ノード20のユーザから、ブロックチェーンBCに新たに追加されるべき取引の内容を示す内容情報を受け取ると、ノード20の動作制御部251は、内容情報に基づいて、取引データD1を生成する。
 ノード20の動作制御部251は、取引データD1を生成すると、ステップS201において、取引データD1をノード40に送信する。
 ノード40の検証部254は、ノード20から取引データD1を受信すると、ステップS202において、取引データD1を検証する。以下では、取引データD1の検証結果が有効を示すとする。
 ノード20の動作制御部251は、ステップS201の完了後、ステップS203において、取引データD1をノード30に送信する。
 ノード30の検証部254は、ノード20から取引データD1を受信すると、ステップS204において取引データD1を検証する。以下では、取引データD1の検証結果が有効を示すとする。
 ステップS203~S204は、ステップS201~S202よりも時間的に前に実行されてもよい。ステップS203~S204は、ステップS201~S202と並行に実施されてもよい。この場合、ステップS201~S202とステップS203~S204とを順番に実行する構成に比べて、ステップS201~S204に要する時間を短縮できる。
 ノード40の動作制御部251は、ステップS202における取引データD1の検証結果が有効を示す場合、ステップS205において、取引データD1をノード50に送信する。
 ノード50の検証部254は、ノード40から取引データD1を受信すると、ステップS206において取引データD1を検証する。以下では、取引データD1の検証結果が有効を示すとする。
 ノード40の動作制御部251は、ステップS205の完了後、ステップS207において、取引データD1をノード60に送信する。
 ノード60の検証部254は、ノード40から取引データD1を受信すると、ステップS208において取引データD1を検証する。以下では、取引データD1の検証結果が有効を示すとする。
 ステップS207~S208は、ステップS205~S206よりも時間的に前に実行されてもよい。ステップS207~S208は、ステップS205~S206と並行に実施されてもよい。この場合、ステップS205~S206とステップS207~S208とを順番に実行する構成に比べて、ステップS205~S208に要する時間を短縮できる。
 ステップS207が完了すると、ノード40のブロック生成部255は、ステップS115において、取引データD1を含むブロックB1の生成(マイニング)を開始する。
 ステップS206が完了すると、ノード50のブロック生成部255は、ステップS116において、取引データD1を含むブロックB1の生成(マイニング)を開始する。
 ステップS208が完了すると、ノード60のブロック生成部255は、ステップS117において、取引データD1を含むブロックB1の生成(マイニング)を開始する。
 ノード50のブロック生成部255が、ステップS118において取引データD1を含むブロックB1の生成(マイニング)に成功すると、ステップS209においてノード50の要求部252は、要求C1を管理装置10に送信する。要求C1は、取引データD1に関する通信に対するQoS制御の要求を示す。
 管理装置10の提供部131は、要求C1をノード50から受信する場合、ステップS210において、ワンタイムパスP1を発行する。
 続いて、ステップS211において提供部131は、ワンタイムパスP1を、管理テーブル122のワンタイムパスの欄122aに登録する。
 提供部131は、ワンタイムパスの欄122aにワンタイムパスを新たに登録する場合、管理テーブル122において当該ワンタイムパスに対応する処理の欄122bを「未」に設定する。
 続いて、ステップS212において品質制御部132は、まず、管理テーブル122の処理の欄122bが「未」に設定されているワンタイムパス(この場合、ワンタイムパスP1)を特定する。続いて、品質制御部132は、特定したワンタイムパスを有するパケットの通信の品質を、所定品質以上の品質に設定する。特定したワンタイムパスを有するパケットの通信の品質を、所定品質以上の品質に設定する手法は、ステップS104の手法と同様である。
 続いて、ステップS213において提供部131は、要求C1の送信元であるノード50に、ワンタイムパスP1を提供する。ワンタイムパスP1を要求C1の送信元に提供することは、要求C1の承認を意味する。
 以下、上述のステップS119~S127が実行される。第1変形例では、ステップS119において生成される第2通信データ(複数のパケットM2a)は、第1通信データの他の例である。第1変形例において、ブロックB1を分割することによって生成される複数の第2データFは、ブロックを分割することによって得られる複数のデータ(複数の第3データ)の一例である。第1変形例において、複数のパケットM2aは、複数のパケット(複数の第3パケット)の一例である。
 ブロックB1の通信において遅延が小さいと、当該ブロックB1が他のブロックB1よりも先に、各ノードに到着する可能性が高くなる。当該ブロックB1が他のブロックB1よりも先に各ノードに到着する場合、当該ブロックB1がブロックチェーンBCに接続される確率が高くなる。このため、ブロックB1の通信において遅延が小さいことは、取引データD1の早期の確定を期待するユーザに加えて、ブロックB1を生成するマイナーノードにとっても望ましい。
 第1変形例によれば、取引データD1の通信にはQoS制御が実行されずに、取引データD1を含むブロックB1の通信にQoS制御が実行される。このため、ブロックB1の通信において遅延を小さくできる。よって、取引データD1の通信と、取引データD1を含むブロックB1の通信と、のいずれにもQoS制御が実行されない構成に比べて、取引データD1の早期の確定が可能になり、かつ、ブロックB1がブロックチェーンBCに接続される確率を高くできる。
 <B2:第2変形例>
 第1実施形態及び第1変形例において、品質制御部132は、所定品質以上の品質に設定した通信の品質を、所定品質以上の品質に設定する前の通信の品質に戻してもよい。
 要求C1は、グループA1内での取引データD1に関連する通信の品質の制御を要求する。すなわち、要求C1は、グループA1内での取引データD1に関連する通信の品質を制御するための要求である。取引データD1は、複数の第2ノードのいずれかを取引先ノードとして示す(図8参照)。品質制御部132は、取引データD1を含むブロックB1を取引先ノード(取引ノード)が受信したことを示す通知に応じて、グループA1内での取引データD1に関連する通信における所定品質以上の品質を、所定品質以上の品質に設定する前の品質に戻す。
 例えば、取引データD1に取引先ノードとして示されるノード30が、取引データD1を含むブロックB1を受信すると、ノード30の動作制御部251は、通知N1を管理装置10に送信する。通知N1は、取引データD1を含むブロックB1を取引先ノードが受信したことを示す。
 管理装置10の品質制御部132は、通知N1に応じて、所定品質以上の品質に設定した通信の品質を、所定品質以上の品質に設定する前の通信の品質に戻す。例えば、品質制御部132は、管理テーブル122に登録されている情報(ワンタイムパスP1)及び管理テーブル122に設定されている情報(「未」と「済」)を、通知N1の受信に応じて削除する。品質制御部132は、その後、管理テーブル122を用いた通信品質の制御(例えば、ステップS104の制御手法)を実行する。この場合、通信装置71~74は、品質制御部132に制御される前の状態(例えば、予め定められている状態)に戻る。
 一例を挙げると、品質制御部132は、通知N1を受信してから所定時間(例えば、2分)が経過した場合に、所定品質以上の品質に設定した通信品質を、所定品質以上の品質に設定する前の通信品質に戻す。所定時間は、2分に限らず、2分よりも長くてもよいし2分よりも短くてもよい。所定時間は、グループA1内のすべてのノードに、新たなブロックB1が到達するまでの時間よりも長いことが望ましい。
 第2変形例によれば、グループA1における通信の品質が、必要以上に長い時間、高品質になることを抑制できる。
 <C:その他>
 (1)第1実施形態及び第1変形例~第2変形例の各々においては、記憶装置12及び24は、フレキシブルディスク、光磁気ディスク(例えば、コンパクトディスク、デジタル多用途ディスク、Blu-ray(登録商標)ディスク)、スマートカード、フラッシュメモリデバイス(例えば、カード、スティック、キードライブ)、CD-ROM(Compact Disc-ROM)、レジスタ、リムーバブルディスク、ハードディスク、フロッピー(登録商標)ディスク、磁気ストリップ、データベース、サーバその他の適切な記憶媒体を含んでもよい。また、プログラムは、電気通信回線を介してネットワークから送信されてもよい。
 (2)第1実施形態及び第1変形例~第2変形例の各々は、LTE(Long Term Evolution)、LTE-A(LTE-Advanced)、SUPER 3G、IMT-Advanced、4G、5G、FRA(Future Radio Access)、W-CDMA(登録商標)、GSM(登録商標)、CDMA2000、UMB(Ultra Mobile Broadband)、IEEE 802.11(Wi-Fi)、IEEE 802.16(WiMAX)、IEEE 802.20、UWB(Ultra-WideBand)、Bluetooth(登録商標)、その他の適切なシステムを利用するシステム及び/又はこれらに基づいて拡張された次世代システムに適用されてもよい。
 (3)第1実施形態及び第1変形例~第2変形例の各々において説明した情報などは、様々な異なる技術のいずれかを使用して表されてもよい。例えば、上記の説明全体に渡って言及され得るデータ、情報などは、電圧、電流、電磁波、磁界、磁性粒子、光場、光子、又はこれらの任意の組み合わせにて表されてもよい。
 なお、本明細書において説明した用語及び/又は本明細書の理解に必要な用語は、同一の又は類似する意味を有する用語と置き換えられてもよい。
 (4)第1実施形態及び第1変形例~第2変形例の各々において、入出力された情報等は特定の場所(例えば、メモリ)に保存されてもよいし、テーブルによって管理されてもよい。入出力される情報等は、上書き、更新、又は追記され得る。出力された情報等は削除されてもよい。入力された情報等は他の装置へ送信されてもよい。
 (5)第1実施形態及び第1変形例~第2変形例の各々において、判定は、1ビットによって表される値(0か1か)に基づいて行われてもよいし、真偽値(Boolean:true又はfalse)に基づいて行われてもよいし、数値の比較(例えば、所定の値との比較)に基づいて行われてもよい。
 (6)第1実施形態及び第1変形例~第2変形例の各々において例示した処理手順、シーケンス、又はフローチャート等は、矛盾のない限り、順序を入れ替えてもよい。例えば、本明細書において説明した方法については、例示的な順序において様々なステップの要素を提示しており、提示した特定の順序に限定されない。
 (7)図4又は図5に例示された各機能は、ハードウェア及びソフトウェアの任意の組み合わせによって実現される。また、各機能は、単体の装置によって実現されてもよいし、相互に別体にて構成された2以上の装置によって実現されてもよい。
 (8)第1実施形態及び第1変形例~第2変形例の各々において例示したプログラムは、ソフトウェア、ファームウェア、ミドルウェア、マイクロコード又はハードウェア記述言語と呼ばれるか、他の名称によって呼ばれるかを問わず、命令、命令セット、コード、コードセグメント、プログラムコード、サブプログラム、ソフトウェアモジュール、アプリケーション、ソフトウェアアプリケーション、ソフトウェアパッケージ、ルーチン、サブルーチン、オブジェクト、実行可能ファイル、実行スレッド、手順又は機能等を意味するよう広く解釈されるべきである。
 また、ソフトウェア、又は命令などは、伝送媒体を介して送受信されてもよい。例えば、ソフトウェアが、同軸ケーブル、光ファイバケーブル、ツイストペア及びデジタル加入者回線(DSL)などの有線技術及び/又は赤外線、無線及びマイクロ波などの無線技術を使用してウェブサイト、サーバ、又は他のリモートソースから送信される場合、これらの有線技術及び/又は無線技術は、伝送媒体の定義内に含まれる。
 (9)第1実施形態及び第1変形例~第2変形例の各々において、「システム」及び「ネットワーク」という用語は、互換的に使用される。
 (10)第1実施形態及び第1変形例~第2変形例の各々において、ノード20、30、40、50及び60の少なくとも1つは、移動局でもよい。移動局は、当業者によって、加入者局、モバイルユニット、加入者ユニット、ワイヤレスユニット、リモートユニット、モバイルデバイス、ワイヤレスデバイス、ワイヤレス通信デバイス、リモートデバイス、モバイル加入者局、アクセス端末、モバイル端末、ワイヤレス端末、リモート端末、ハンドセット、ユーザエージェント、モバイルクライアント、クライアント、又はいくつかの他の適切な用語を用いて称される場合もある。
 (11)第1実施形態及び第1変形例~第2変形例の各々において、「に基づいて」という記載は、別段に明記されていない限り、「のみに基づいて」を意味しない。言い換えれば、「に基づいて」という記載は、「のみに基づいて」と「に少なくとも基づいて」の両方を意味する。
 (12)本明細書において使用する「第1」及び「第2」などの呼称を使用した要素へのいかなる参照も、それらの要素の量又は順序を全般的に限定しない。これらの呼称は、2つ以上の要素間を区別する便利な方法として本明細書において使用され得る。したがって、第1及び第2の要素への参照は、2つの要素のみが採用され得ること又は何らかの形において第1要素が第2要素に先行しなければならないことを意味しない。
 (13)第1実施形態及び第1変形例~第2変形例の各々において「含む(including)」、「含んでいる(comprising)」、及びそれらの変形が、本明細書あるいは特許請求の範囲において使用されている限り、これら用語は、用語「備える」と同様に、包括的であることが意図される。さらに、本明細書あるいは特許請求の範囲において使用されている用語「又は(or)」は、排他的論理和ではないことが意図される。
 (14)本願の全体において、例えば、英語におけるa、an及びtheのように、翻訳によって冠詞が追加された場合、これらの冠詞は、文脈から明らかにそうではないことが示されていなければ、複数を含む。
 (15)本明細書において、「装置」という用語は、回路、デバイス又はユニット等の他の用語に読み替えられてもよい。
 (16)本発明が本明細書中に説明した実施形態に限定されないことは当業者にとって明白である。本発明は、特許請求の範囲の記載に基づいて定まる本発明の趣旨及び範囲を逸脱することなく修正及び変更態様として実施できる。したがって、本明細書の記載は、例示的な説明を目的とし、本発明に対して何ら制限的な意味を有さない。また、本明細書に例示した態様から選択された複数の態様を組み合わせてもよい。
 <D:上述の形態又は変形例から把握される態様>
 上述の形態又は変形例の少なくとも1つから以下の態様が把握される。
 <D1:第1態様>
 第1態様に係る管理装置は、提供部と、品質制御部と、を含む。提供部は、ブロックチェーンを共に有し前記ブロックチェーンに追加データを追加するための通信を実行する第1ノードと複数の第2ノードとによって構成されるグループ内での前記通信の品質を制御するための制御要求を、前記第1ノードから受信する場合、前記制御要求に対応する第1情報を、前記第1ノードに提供する。品質制御部は、前記第1ノードが、前記第1情報を有する第1通信データを生成した後に、前記第1通信データが前記グループ内で通信される状況において、前記第1通信データの通信の品質を、第1品質以上の品質に設定する。
 グループ内でデータが通信される状況において、ブロックチェーンに追加データを追加するための通信が実行される。この態様によれば、第1情報を有する第1通信データの通信の品質を、第1品質以上の品質に設定できる。このため、第1ノードが、ブロックチェーンに追加される追加データと第1情報とを含む通信データを、第1通信データとして生成すれば、追加データがブロックチェーンに追加されるタイミングの遅延を小さくできる。したがって、データをブロックチェーンに追加するタイミングの遅延を小さくするためにノードを支援できる。
 <D2:第2態様>
 第1態様の例(第2態様)において、前記追加データは、前記ブロックチェーンに接続されるべきブロックに含まれるべき対象データである。この態様によれば、例えば、対象データの生成に応じて、制御要求を提供部に提供することができる。
 <D3:第3態様>
 第2態様の例(第3態様)において、前記第1通信データは、複数の第1パケットを有する。前記複数の第1パケットは、前記対象データを分割することによって得られる複数の第1データと1対1に対応する。前記複数の第1パケットの各々は、前記複数の第1データのうち当該第1パケットに対応するデータと、前記第1情報と、を有する。この態様によれば、パケットを用いることによって、対象データに関する第1通信データの通信の品質を、第1品質以上の品質に設定できる。
 <D4:第4態様>
 第2態様又は第3態様の例(第4態様)において、前記品質制御部は、前記複数の第2ノードのうち前記第1通信データを受信した受信ノードが、前記第1情報を有する第2通信データを生成した後に、前記第2通信データが、前記グループに属するノードのうち前記受信ノードとは異なる相違ノードに通信される状況において、前記第2通信データの通信の品質を、前記第1品質以上の品質に設定する。この態様によれば、第1通信データを受信した受信ノードが生成する第2通信データの通信の品質を、第1品質以上の品質に設定できる。
 <D5:第5態様>
 第4態様の例(第5態様)において、前記第2通信データは、複数の第2パケットを有する。前記複数の第2パケットは、前記ブロックを分割することによって得られる複数の第2データと1対1に対応する。前記複数の第2パケットの各々は、前記複数の第2データのうち当該第2パケットに対応するデータと、前記第1情報と、を有する。この態様によれば、パケットを用いることによって、ブロックに関する第2通信データの通信の品質を、第1品質以上の品質に設定できる。
 <D6:第6態様>
 第1態様の例(第6態様)において、前記追加データは、前記ブロックチェーンに接続されるべきブロックである。この態様によれば、例えば、ブロックチェーンに接続されるべきブロックの生成に応じて、制御要求を提供部に提供することができる。
 <D7:第7態様>
 第6態様の例(第7態様)において、前記第1通信データは、複数の第3パケットを有する。前記複数の第3パケットは、前記ブロックを分割することによって得られる複数の第3データと1対1に対応する。前記複数の第3パケットの各々は、前記複数の第3データのうち当該第3パケットに対応するデータと、前記第1情報と、を有する。この態様によれば、パケットを用いることによって、ブロックに関する第1通信データの通信の品質を、第1品質以上の品質に設定できる。
 <D8:第8態様>
 第1態様から第7態様のいずれかの例(第8態様)において、前記追加データは、前記グループ内で通信される取引データである。前記制御要求は、前記取引データに関連する通信の品質を制御するための要求である。前記取引データは、前記複数の第2ノードのいずれかを取引ノードとして示す。前記品質制御部は、前記取引データを含むブロックを前記取引ノードが受信したことを示す通知に応じて、前記通信の品質を、前記第1品質以上の品質に設定する前の品質に戻す。この態様によれば、グループにおける通信の品質が、必要以上に長い時間、高品質になることを抑制できる。
 <D9:第9態様>
 第8態様の例(第9態様)において、前記品質制御部は、前記通知の受信から第1時間が経過した場合に、前記通信の品質を、前記第1品質以上の品質に設定する前の品質に戻す。この態様によれば、グループ内のすべてのノードにブロックが到達するまで、グループにおける通信の品質を第1品質以上の品質に維持する可能性を高くできる。
 1…ネットワークシステム、10…管理装置、11…通信装置、12…記憶装置、13…処理装置、131…提供部、132…品質制御部、20…ノード、21…入力装置、22…出力装置、23…通信装置、24…記憶装置、25…処理装置、251…動作制御部、252…要求部、254…検証部、255…ブロック生成部、30…ノード、40…ノード、50…ノード、60…ノード、71~74…通信装置。

Claims (9)

  1.  ブロックチェーンを共に有し前記ブロックチェーンに追加データを追加するための通信を実行する第1ノードと複数の第2ノードとによって構成されるグループ内での前記通信の品質を制御するための制御要求を、前記第1ノードから受信する場合、前記制御要求に対応する第1情報を、前記第1ノードに提供する提供部と、
     前記第1ノードが、前記第1情報を有する第1通信データを生成した後に、前記第1通信データが前記グループ内で通信される状況において、前記第1通信データの通信の品質を、第1品質以上の品質に設定する品質制御部と、
     を含む管理装置。
  2.  前記追加データは、前記ブロックチェーンに接続されるべきブロックに含まれるべき対象データである、
     請求項1に記載の管理装置。
  3.  前記第1通信データは、複数の第1パケットを有し、
     前記複数の第1パケットは、前記対象データを分割することによって得られる複数の第1データと1対1に対応し、
     前記複数の第1パケットの各々は、前記複数の第1データのうち当該第1パケットに対応するデータと、前記第1情報と、を有する、
     請求項2に記載の管理装置。
  4.  前記品質制御部は、
     前記複数の第2ノードのうち前記第1通信データを受信した受信ノードが、前記第1情報を有する第2通信データを生成した後に、前記第2通信データが、前記グループに属するノードのうち前記受信ノードとは異なる相違ノードに通信される状況において、前記第2通信データの通信の品質を、前記第1品質以上の品質に設定する、
     請求項2又は3に記載の管理装置。
  5.  前記第2通信データは、複数の第2パケットを有し、
     前記複数の第2パケットは、前記ブロックを分割することによって得られる複数の第2データと1対1に対応し、
     前記複数の第2パケットの各々は、前記複数の第2データのうち当該第2パケットに対応するデータと、前記第1情報と、を有する、
     請求項4に記載の管理装置。
  6.  前記追加データは、前記ブロックチェーンに接続されるべきブロックである、
     請求項1に記載の管理装置。
  7.  前記第1通信データは、複数の第3パケットを有し、
     前記複数の第3パケットは、前記ブロックを分割することによって得られる複数の第3データと1対1に対応し、
     前記複数の第3パケットの各々は、前記複数の第3データのうち当該第3パケットに対応するデータと、前記第1情報と、を有する、
     請求項6に記載の管理装置。
  8.  前記追加データは、前記グループ内で通信される取引データであり、
     前記制御要求は、前記取引データに関連する通信の品質を制御するための要求であり、
     前記取引データは、前記複数の第2ノードのいずれかを取引ノードとして示し、
     前記品質制御部は、前記取引データを含むブロックを前記取引ノードが受信したことを示す通知に応じて、前記通信の品質を、前記第1品質以上の品質に設定する前の品質に戻す、
     請求項1から7のいずれか1項に記載の管理装置。
  9.  前記品質制御部は、前記通知の受信から第1時間が経過した場合に、前記通信の品質を、前記第1品質以上の品質に設定する前の品質に戻す、
     請求項8に記載の管理装置。
PCT/JP2021/040767 2020-11-25 2021-11-05 管理装置 WO2022113699A1 (ja)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP2022565186A JPWO2022113699A1 (ja) 2020-11-25 2021-11-05

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
JP2020-194987 2020-11-25
JP2020194987 2020-11-25

Publications (1)

Publication Number Publication Date
WO2022113699A1 true WO2022113699A1 (ja) 2022-06-02

Family

ID=81754386

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/JP2021/040767 WO2022113699A1 (ja) 2020-11-25 2021-11-05 管理装置

Country Status (2)

Country Link
JP (1) JPWO2022113699A1 (ja)
WO (1) WO2022113699A1 (ja)

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2006262379A (ja) * 2005-03-18 2006-09-28 Fujitsu Ltd ネットワークQoS制御システムおよび制御方法
JP2019161580A (ja) * 2018-03-16 2019-09-19 日本電気株式会社 データ送信装置、データ送受信システム、データ受信装置、データ送信方法、プログラム
CN111934998A (zh) * 2020-09-25 2020-11-13 支付宝(杭州)信息技术有限公司 消息传输方法及装置
CN111934990A (zh) * 2020-09-25 2020-11-13 支付宝(杭州)信息技术有限公司 消息传输方法及装置

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2006262379A (ja) * 2005-03-18 2006-09-28 Fujitsu Ltd ネットワークQoS制御システムおよび制御方法
JP2019161580A (ja) * 2018-03-16 2019-09-19 日本電気株式会社 データ送信装置、データ送受信システム、データ受信装置、データ送信方法、プログラム
CN111934998A (zh) * 2020-09-25 2020-11-13 支付宝(杭州)信息技术有限公司 消息传输方法及装置
CN111934990A (zh) * 2020-09-25 2020-11-13 支付宝(杭州)信息技术有限公司 消息传输方法及装置

Also Published As

Publication number Publication date
JPWO2022113699A1 (ja) 2022-06-02

Similar Documents

Publication Publication Date Title
CN111344706B (zh) 管理区块链上的交易的方法和系统
US20210406250A1 (en) Method and system for reducing the size of a blockchain
CN111615818B (zh) 一种区块链构建方法及区块链节点
JP6754734B2 (ja) Ranスライスにおけるリソース管理装置及びranスライスにおけるリソース管理方法
CN110019080B (zh) 数据访问方法和装置
CN105009508A (zh) 基于网络参数的完整性校验和选择性去重复
CN110300053B (zh) 一种添加好友的方法与设备
CN105474600A (zh) 使用链接到存储所需密码的另一个通信装置的通信装置来访问基于云的服务
CN111460458B (zh) 一种数据处理方法、相关装置及计算机可存储介质
CN110430135B (zh) 一种报文处理方法和装置
JP2018502502A (ja) コンテキストモバイルデータアクセスのための技術
CN110795446A (zh) 榜单更新方法、装置、可读介质和电子设备
CN112789612A (zh) 基于链接的自动消息验证
CN110989934B (zh) 区块链节点数据存储方法、区块链系统及区块链节点
US11621950B2 (en) Data processing methods, servers, client devices and media for security authentication
WO2022102531A1 (ja) 管理装置
WO2019161939A1 (en) Methods, devices, and computer programs for provisioning or controlling operator profiles in terminals
US10448226B1 (en) Network service exchange system and method of using same
WO2022113699A1 (ja) 管理装置
CN112559898B (zh) 物品信息发送方法、装置、电子设备和计算机可读介质
WO2022113698A1 (ja) 管理装置
CN113553206B (zh) 数据事件执行方法、装置、电子设备和计算机可读介质
US9860313B2 (en) Maintaining state synchronization of an application between computing devices as well as maintaining state synchronization of common information between different applications without requiring perioidic synchronization
US20240001247A1 (en) Game login method and device
CN112507676B (zh) 能源报表生成方法、装置、电子设备和计算机可读介质

Legal Events

Date Code Title Description
121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 21897675

Country of ref document: EP

Kind code of ref document: A1

ENP Entry into the national phase

Ref document number: 2022565186

Country of ref document: JP

Kind code of ref document: A

NENP Non-entry into the national phase

Ref country code: DE

122 Ep: pct application non-entry in european phase

Ref document number: 21897675

Country of ref document: EP

Kind code of ref document: A1