WO2021176599A1 - 管理装置、管理方法、及び、管理プログラム - Google Patents

管理装置、管理方法、及び、管理プログラム Download PDF

Info

Publication number
WO2021176599A1
WO2021176599A1 PCT/JP2020/009178 JP2020009178W WO2021176599A1 WO 2021176599 A1 WO2021176599 A1 WO 2021176599A1 JP 2020009178 W JP2020009178 W JP 2020009178W WO 2021176599 A1 WO2021176599 A1 WO 2021176599A1
Authority
WO
WIPO (PCT)
Prior art keywords
ledger
distributed ledger
distributed
unit
management
Prior art date
Application number
PCT/JP2020/009178
Other languages
English (en)
French (fr)
Inventor
佐藤 光
将也 本庄
Original Assignee
三菱電機株式会社
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 三菱電機株式会社 filed Critical 三菱電機株式会社
Priority to JP2021572022A priority Critical patent/JPWO2021176599A1/ja
Priority to PCT/JP2020/009178 priority patent/WO2021176599A1/ja
Priority to CN202080097186.0A priority patent/CN115151899A/zh
Publication of WO2021176599A1 publication Critical patent/WO2021176599A1/ja
Priority to US17/857,415 priority patent/US20220335038A1/en

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/23Updating
    • G06F16/2379Updates performed during online database operations; commit processing
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/27Replication, distribution or synchronisation of data between databases or within a distributed database system; Distributed database system architectures therefor

Definitions

  • This disclosure relates to management devices, management methods, and management programs.
  • Distributed ledger is a technology for sharing data by using multiple servers.
  • a plurality of servers and the like hold information on all past data operations.
  • the data manipulation is to register the data in the distributed ledger and to update the data registered in the distributed ledger.
  • the main feature of the distributed ledger is that it is possible to easily monitor data tampering among multiple servers.
  • the blockchain is an example of a distributed ledger.
  • the blockchain generates blocks and stores data in chronological order.
  • a block is a unit of data.
  • Each block contains information that connects the previous and next blocks.
  • the blockchain has high tamper resistance.
  • the blockchain needs to store all past data in order to verify the data. Storage usage on the blockchain increases linearly. Therefore, if the blockchain is operated for a long period of time, the storage usage becomes enormous.
  • Patent Document 1 discloses a technique for setting an expiration date and time for a smart contract and making it impossible to record data for a blockchain associated with the smart contract whose expiration date and time has passed. According to this technology, the storage usage can be reduced by deleting the blockchain that can no longer be recorded.
  • Patent Document 1 discloses a method of reducing data by deleting a blockchain when the operation of a smart contract linked to the blockchain is completed. In this method, it is not possible to reduce the data of the blockchain corresponding to the smart contract until the operation of the smart contract is completed. Here, by managing the state of the blockchain, it is conceivable to identify the blockchain whose operation has ended. However, depending on the method of Patent Document 1, when a plurality of blockchains in the same state exist, the blockchain cannot be uniquely selected.
  • the purpose of this disclosure is to enable unique selection of a distributed ledger from a plurality of distributed ledgers.
  • the management device is A ledger management unit that manages multiple distributed ledgers that record distributed electronic data, A control unit that controls any of the plurality of distributed ledgers, There are a plurality of distributed ledger candidates that are candidates for the distributed ledger controlled by the control unit, and there are a plurality of distributed ledger candidates composed of two or more distributed ledgers included in the plurality of distributed ledgers.
  • the selection rule information including the selection rule indicating the rule for uniquely selecting the distributed ledger from the plurality of distributed ledger candidates is recorded and the plurality of distributed ledger candidates exist, the selection is performed. It includes a selection unit that uniquely selects a distributed ledger from the plurality of distributed ledger candidates according to a rule.
  • the management device includes a control unit and a selection unit.
  • the selection unit uniquely selects the distributed ledger from a plurality of distributed ledger candidates according to the selection rule.
  • the distributed ledger candidate is a candidate for the distributed ledger controlled by the control unit. Therefore, according to the present disclosure, it is possible to uniquely select a distributed ledger from a plurality of distributed ledgers.
  • a configuration example of the management system 90 according to the first embodiment A hardware configuration example of the management system 90 according to the first embodiment.
  • a software configuration example of the management system 90 according to the first embodiment. A configuration example of the ledger management unit 110 according to the first embodiment.
  • a configuration example of the selection unit 120 according to the first embodiment. A software configuration example of the management system 90 according to the first embodiment.
  • a configuration example of the management system 90 according to the first embodiment. The flowchart which shows the status setting process which concerns on Embodiment 1.
  • the flowchart which shows the status automatic update process which concerns on Embodiment 1. The flowchart which shows the new data registration process which concerns on Embodiment 1.
  • the flowchart which shows the ledger deletion processing which concerns on Embodiment 1. A configuration example of the management device 100 according to the modified example of the first embodiment.
  • FIG. 1 shows a configuration example of the management system 90 according to the present embodiment.
  • the management system 90 includes a management device 100, a user terminal 200, a service providing device 300, and a distributed ledger network group 400.
  • the distributed ledger network group 400 includes one or more distributed ledger networks 410.
  • the management system 90 may include a plurality of management devices 100, a user terminal 200, a service providing device 300, and a distributed ledger network 410, respectively.
  • the management device 100_1 and the management device 100_N1 in this figure are notations for distinguishing a plurality of management devices 100, respectively.
  • the user terminal 200, the service providing device 300, and the distributed ledger network 410 are also described in the same manner as the management device 100.
  • N1, N2, N3, and N4 are integers of 2 or more, respectively.
  • the management device 100, the user terminal 200, the service providing device 300, and the distributed ledger network 410 are connected to each other via a network.
  • the network is, for example, the Internet, an intranet, or a combination thereof. Not all components of the management system 90 need to be interconnected.
  • the distributed ledger network 410 is composed of one or more nodes 411.
  • the distributed ledger network 410 is composed of a plurality of nodes 411, the plurality of nodes 411 are connected to each other via the network.
  • the management device 100 manages one or more distributed ledger networks 410.
  • the management device 100 records data in the distributed ledger in response to a request from the user terminal 200 via the service providing device 300, refers to the data in the distributed ledger, and displays the data in the distributed ledger.
  • Delete or set the operation method of the distributed ledger may be shown in the ledger status.
  • the ledger status is information indicating the status of the distributed ledger.
  • Ledger status indicates the control limits of the distributed ledger.
  • the user terminal 200 is a terminal used when a user accesses the distributed ledger. Unless otherwise specified, the user is the subject who uses the distributed ledger. The user does not have to be a person such as a computer.
  • the service providing device 300 is a server that provides services to users.
  • the service is related to using a distributed ledger as an area to store data.
  • the service is provided by using a business application or a Web application.
  • An application is an application program unless otherwise specified.
  • the distributed ledger network 410 is a network including one or more nodes 411.
  • Node 411 operates a distributed ledger.
  • One node 411 may operate a plurality of distributed ledgers.
  • the distributed ledger records distributed electronic data. Control restrictions are applied to the distributed ledger. Control restrictions indicate restrictions on the user's control of the distributed ledger.
  • the electronic data may be distributed in any way.
  • the management system 90 does not have to include a user terminal 200 and a service providing device 300, respectively, when there is no user or when the service is not provided to the user.
  • FIG. 2 shows a hardware configuration example of the management system 90 according to the present embodiment.
  • the management system 90 includes a management device 100, a user terminal 200, a service providing device 300, and a distributed ledger network 410, respectively. Further, the number of nodes constituting the distributed ledger network 410 is one.
  • the management device 100 typically comprises a computer.
  • the management device 100 may be composed of a plurality of computers.
  • the management device 100 includes hardware such as a processor 11, a memory 12, an auxiliary storage device 13, and a communication device 16. These hardware are connected to each other via a signal line 19.
  • the processor 11 is an IC (Integrated Circuit) that performs arithmetic processing, and controls the hardware included in the computer.
  • the processor 11 is a CPU (Central Processing Unit), a DSP (Digital Signal Processor), or a GPU (Graphics Processing Unit).
  • the management device 100 may include a plurality of processors that replace the processor 11. The plurality of processors share the role of the processor 11.
  • the memory 12 is typically a volatile storage device.
  • the memory 12 is also called a main storage device or a main memory.
  • the memory 12 is a RAM (Random Access Memory).
  • the data stored in the memory 12 is stored in the auxiliary storage device 13 as needed.
  • the auxiliary storage device 13 is typically a non-volatile storage device.
  • the auxiliary storage device 13 is a ROM (Read Only Memory), an HDD (Hard Disk Drive), or a flash memory.
  • the data stored in the auxiliary storage device 13 is loaded into the memory 12 as needed.
  • the memory 12 and the auxiliary storage device 13 may be integrally configured.
  • the communication device 16 is a receiver and a transmitter.
  • the communication device 16 is a communication chip or a NIC (Network Interface Card).
  • NIC Network Interface Card
  • Each part of the management device 100 may use the communication device 16 when communicating with other devices and the like.
  • the auxiliary storage device 13 stores the management program.
  • the management program is a program that allows the computer to realize the functions of each part included in the management device 100.
  • the management program may consist of a plurality of files.
  • the management program is loaded into the memory 12 and executed by the processor 11.
  • the functions of each part included in the management device 100 are realized by software.
  • each part of the management device 100 uses the data via the communication device 16.
  • the data used when executing the management program and the data obtained by executing the management program are appropriately stored in the storage device included in the management device 100.
  • the storage device included in the management device 100 includes at least one of a memory 12, an auxiliary storage device 13, a register in the processor 11, and a cache memory in the processor 11.
  • data and information may have the same meaning.
  • Each of the function of the memory 12 and the function of the auxiliary storage device 13 may be realized by any one or more storage devices.
  • Any of the programs described herein may be recorded on a computer-readable non-volatile recording medium.
  • the non-volatile recording medium is, for example, an optical disk or a flash memory. Any of the programs described herein may be provided as a program product.
  • the configuration of the service providing device 300 is the same as the configuration of the management device 100.
  • the service providing device 300 stores the service providing program instead of the management program.
  • the configuration of the node 411 is the same as the configuration of the management device 100.
  • the distributed ledger network 410 stores the ledger program instead of the management program.
  • the user terminal 200 includes a processor 11, a memory 12, an auxiliary storage device 13, an input interface 14, an output interface 15, and a communication device 16.
  • the input interface 14 is a port to which an input device is connected.
  • the input device is a device that operates the management device 100, such as a keyboard or a mouse.
  • the input interface 14 is a USB (Universal Serial Bus) terminal.
  • the output interface 15 is a port to which an output device is connected.
  • the output device is, as a specific example, a display.
  • the output interface 15 is an HDMI (registered trademark, High-Definition Multimedia Interface) terminal.
  • the touch panel may include an input interface 14 and an output interface 15.
  • FIG. 3 shows an example of software configuration of the management system 90.
  • the management device 100 shown in this example is typically used when one organization operates one management system 90.
  • the management device 100 includes a ledger management unit 110, a selection unit 120, a control unit 140, and a setting unit 150.
  • the ledger management unit 110 reads the operation command input by the user and the operation target data.
  • the operation command is a command for operating the distributed ledger.
  • the operation command is a command relating to registration of data in the distributed ledger and update or reference of data registered in the distributed ledger.
  • the operation target data is data corresponding to the operation instruction.
  • the general user inputs an operation command to the general service providing device 310 via the general user terminal 200.
  • the general user may input the operation target data together with the operation command.
  • the ledger management unit 110 manages the ledger status.
  • the ledger management unit 110 selects distributed ledger candidates using operation commands.
  • the distributed ledger candidate indicates a candidate for the distributed ledger controlled by the management device 100.
  • the ledger management unit 110 may use the operation target data when selecting the distributed ledger candidate.
  • the ledger management unit 110 passes the distributed ledger candidates to the selection unit 120.
  • the ledger management unit 110 records ledger status information D12 including ledger status corresponding to each of at least one distributed ledger.
  • the ledger management unit 110 may record setting information including the ledger status information D12.
  • the ledger management unit 110 may manage a plurality of distributed ledgers.
  • the selection unit 120 selects a selective distributed ledger from the distributed ledger candidates.
  • the selective distributed ledger is a distributed ledger targeted by the management device 100.
  • the selection unit 120 selects one distributed ledger from the distributed ledger candidates according to the selection rule.
  • Selection rules indicate rules for selecting a distributed ledger. It should be noted that there may be a plurality of any of the rules described in the present specification. Selection rules may be associated with priorities. The priority indicates the priority when the selection unit 120 makes a selection rule.
  • the selection unit 120 records the selection rule information D21.
  • the selection rule information D21 includes a selection rule.
  • the selection rule indicates a rule for uniquely selecting a distributed ledger from a plurality of distributed ledger candidates when there are a plurality of distributed ledger candidates.
  • the selection rule may indicate a rule for selecting one distributed ledger from a plurality of distributed ledger candidates.
  • the plurality of distributed ledger candidates are candidates for the distributed ledger controlled by the control unit 140, and are composed of two or more distributed ledgers included in the plurality of distributed ledgers included in the ledger network 410.
  • the selection unit 120 uniquely selects the distributed ledger from the plurality of distributed ledger candidates according to the selection rule.
  • the selection rule information D21 may include a plurality of selection rules and priorities corresponding to each of the plurality of selection rules.
  • the selection unit 120 may select a priority rule from a plurality of selection rules in consideration of the priority corresponding to each of the plurality of selection rules.
  • the selection unit 120 may record setting information including selection rule information.
  • the control unit 140 executes a process according to a registration request, an update request, or a reference request for the node 411 selected by the selection unit 120.
  • Node 411 executes the process corresponding to the request and transmits the result information to the control unit 140.
  • the control unit 140 sends the result information received from the distributed ledger to the service providing device 300.
  • the result information is information indicating the execution result.
  • the registration request is a request for the distributed ledger, and is a request for newly registering new data in the distributed ledger.
  • the new data is data that a general user wants to newly register in the distributed ledger.
  • the update request is a request for the distributed ledger, and is a request for updating the data registered in the distributed ledger by using the update data.
  • the update data is data used to update the data registered in the distributed ledger.
  • the reference request is a request for the distributed ledger and is a request for referring to the reference data registered in the distributed ledger.
  • the reference data is data used to refer to the data registered in the distributed ledger.
  • the reference data may be data corresponding to the reference data.
  • the new data and the updated data are the same as the reference data, respectively.
  • the control unit 140 deletes the distributed ledger whose operation has been completed from the distributed ledger managed by the management device 100. When the control unit 140 deletes the distributed ledger, the management device 100 excludes the distributed ledger from the management target.
  • the deleted distributed ledger is typically no longer the distributed ledger that makes up the ledger network 410.
  • the control unit 140 deletes the distributed ledger according to the deletion request from the management user.
  • the deletion request is a request to delete the distributed ledger.
  • the control unit 140 identifies the distributed ledger whose operation has been completed by referring to the ledger management unit 110.
  • the control unit 140 may delete the distributed ledger that is not in operation.
  • the distributed ledger in operation demonstrates the function of the distributed ledger.
  • the distributed ledger in operation may be a distributed ledger that supports smart contracts.
  • the control unit 140 controls each of at least one distributed ledger according to the ledger status corresponding to each of at least one distributed ledger.
  • the control unit 140 may delete the distributed ledger when the ledger status indicates that the operation of the distributed ledger corresponding to the ledger status is terminated.
  • the control unit 140 may control any of a plurality of distributed ledgers.
  • result information Information including result information may be referred to as result information.
  • result information the content of the information named result information is not always the same.
  • Result information is also a general term for information indicating a result.
  • the other information presented herein is similar to the result information. Any information shown in the present specification may be a general term for information including information indicating predetermined contents.
  • the setting unit 150 receives the setting information and records the received setting information in the ledger management unit 110 or the selection unit 120.
  • the setting information is classified into status setting information and selection rule setting information.
  • the setting information may include information on the automatic update rule.
  • the automatic update rule information indicates the rule for updating the ledger status.
  • the status setting information is typically a general term for information used to set any of the ledger network information D11, the ledger status information D12, the status rule information D13, and the automatic update rule information D14.
  • the ledger network information D11 is used when the management device 100 communicates with the distributed ledger.
  • the ledger network information D11 is information indicating the configuration of the distributed ledger network 410, information indicating the configuration of the node 411, or information indicating the address of the node 411.
  • Ledger status information D12 includes ledger status.
  • the ledger status is allowed to newly register data in the distributed ledger, to allow the data registered in the distributed ledger to be updated, and to be registered in the distributed ledger. Indicates either one with allowing reference to the data, or a combination of at least two.
  • the ledger status may be information indicating that new registration of data in the distributed ledger is not accepted and that updating and reference of the data registered in the distributed ledger is permitted.
  • the ledger status information D12 may include a ledger status indicating that the operation of the distributed ledger is terminated.
  • Status rule information D13 indicates a status rule.
  • Status rules indicate rules for updating the ledger status of a distributed ledger.
  • the status rule information D13 is a rule for updating the ledger status in the order of status T1, status T2, status T3, and status T4.
  • the status automatic update unit 115 may update to the status T1 next to the status T4. The contents of status T1 to status T4 will be described later.
  • the automatic update rule information D14 indicates an automatic update rule.
  • the automatic update rule indicates a rule in which the ledger management unit 110 automatically updates the ledger status.
  • the automatic update rule may be a rule indicating the update timing.
  • the update timing is the timing for updating the ledger status.
  • the update timing may indicate the date and time, or may indicate the update condition for updating the ledger status.
  • the update condition is, as a specific example, the state of the distributed ledger.
  • the automatic update rule is a rule for updating the ledger status at a specified date and time, a rule for updating the ledger status at a specified period, or a ledger when the data usage of the distributed ledger exceeds a certain value. It is a rule to change the status.
  • the automatic update rule information D14 is a rule that the status rule information D13 is confirmed at 0:00 every day and the ledger status is updated according to the status rule information D13.
  • the automatic update rule may consist of a plurality of rules.
  • the automatic update rule information D14 may include information indicating a distributed ledger for updating the ledger status.
  • the management system 90 may be configured so that the management user can change the ledger status by operating the management user terminal 220.
  • the selection rule information D21 indicates a selection rule.
  • the selection rule is a rule used by the selection unit 120 when selecting the distributed ledger.
  • the selection rule is a rule to select the distributed ledger generated at the time closest to the current time when there are multiple distributed ledgers that can newly register data, and data update.
  • the rule is to select the distributed ledger that has the least amount of data recorded in the ledger.
  • the selection rule may be a rule for selecting a distributed ledger based on information on time, or a rule for selecting a distributed ledger based on information on data.
  • the time information is, as a specific example, the current time or the time when the distributed ledger was generated.
  • the information about the data is, as a specific example, the information contained in the data related to the distributed ledger.
  • the data related to the distributed ledger is, as a specific example, the data registered in the distributed ledger.
  • the setting unit 150 When the setting unit 150 receives the status setting information, the setting unit 150 sets the ledger management unit 110. When the setting unit 150 receives the selection rule setting information, the setting unit 150 sets the selection unit 120.
  • the management user transmits the setting information to the setting unit 150 via the management service providing device 320.
  • the management user is a user who has the authority to manage the distributed ledger.
  • the general user is a user other than the management user.
  • the management user may have the same authority as a general user.
  • a user is a general term for a general user and an administrative user.
  • the user terminal 200 is classified into a general user terminal 210 and a management user terminal 220.
  • the general user terminal 210 is a terminal handled by a general user.
  • the general user terminal 210 includes a browser unit 211. By operating the browser unit 211, a general user can newly register data in the distributed ledger or refer to the data registered in the distributed ledger.
  • the management user terminal 220 is a terminal handled by the management user.
  • the management user terminal 220 includes a browser unit 221.
  • the management user terminal 220 may have the same functions as the general user terminal 210.
  • the management user can set the management device 100 or delete the distributed ledger by operating the browser unit 221.
  • the general user or the management user controls the distributed ledger via the management device 100.
  • the browser unit 211 is an information display application.
  • the information display application has a function of displaying information.
  • the information display application is, as a specific example, a Web browser or a dedicated application.
  • the browser unit 211 has a function of receiving information from the user and a function of outputting the information received from the device.
  • the browser unit 221 is the same as the browser unit 211.
  • the service providing device 300 is classified into a general service providing device 310 and a management service providing device 320.
  • the general service providing device 310 mediates communication between the general user terminal 210 and the management device 100.
  • the general service providing device 310 includes a server application unit 311.
  • the server application unit 311 has a communication application.
  • the communication application has a function of mediating communication.
  • the management service providing device 320 mediates communication between the management user terminal 220 and the management device 100.
  • the management service providing device 320 includes a server application unit 321.
  • the server application unit 321 is the same as the server application unit 311.
  • Node 411 executes the process according to the request from the management device 100.
  • the distributed ledger network 410 may manage a set of information by distributing it to a plurality of nodes 411.
  • a plurality of nodes 411 may manage the same data in duplicate.
  • Transaction data may be recorded on node 411.
  • FIG. 4 shows a configuration example of the ledger management unit 110.
  • the ledger management unit 110 includes a status storage unit 111, a status reading unit 113, a status recording unit 114, a status automatic update unit 115, and a ledger confirmation unit 116.
  • the ledger management unit 110 is also a general term for each unit included in the ledger management unit 110.
  • the status storage unit 111 can hold the ledger network information D11, the ledger status information D12, the status rule information D13, and the automatic update rule information D14.
  • the reading unit 113 reads the information recorded in the status storage unit 111.
  • the reading unit 113 may pass the read ledger network information D11 to the selection unit 120.
  • the status recording unit 114 records the ledger status information in the status storage unit 111.
  • the status automatic update unit 115 automatically updates the ledger status based on the automatic update rule information D14 recorded by the status storage unit 111.
  • the status automatic update unit 115 updates the ledger status according to the automatic update rule.
  • FIG. 5 shows a configuration example of the selection unit 120.
  • the selection unit 120 includes a selection rule storage unit 121, a reading unit 122, a selection rule recording unit 123, a selection rule processing unit 124, a ledger selection unit 125, and a miscellaneous affairs unit 126. ..
  • the selection unit 120 is also a general term for each unit included in the selection unit 120.
  • the selection rule storage unit 121 holds the selection rule information D21 and other information.
  • the reading unit 122 reads the information recorded in the selection rule storage unit 121.
  • the selection rule recording unit 123 records the selection rule information D21 in the selection rule storage unit 121.
  • the selection rule processing unit 124 selects one distributed ledger according to the selection rule information D21.
  • the selection rule processing unit 124 may use the ledger network information D11.
  • the selection rule processing unit 124 may send information indicating the selected distributed ledger to the control unit 140.
  • the ledger selection unit 125 selects the distributed ledger.
  • the miscellaneous affairs department 126 executes the processing necessary to realize the function of the selection unit 120.
  • the status storage unit 111 may be any storage area as long as it includes input / output means.
  • the status storage unit 111 does not have to be integrally configured with other units of the management device 100.
  • the status storage unit 111 is, as a specific example, a file system or a database.
  • the selection rule storage unit 121 is the same as the status storage unit 111.
  • FIG. 6 shows an example of software configuration of the management system 90.
  • the management device 100 shown in this example is typically used when a plurality of organizations operate one management system 90.
  • the management system 90 includes a management device 100 and another management device 100 having the same function as the management device 100.
  • the difference between FIG. 3 and FIG. 6 is the presence or absence of the synchronization processing unit 160.
  • FIG. 7 shows a configuration example of the management system 90 when the management system 90 is used in a plurality of organizations.
  • three organizations, organization A, organization B, and organization C use the management system 90.
  • Each organization is connected to each other via a network.
  • the management device 100 of the organization A is connected to the management device 100 of the organization B and the management device 100 of the organization C via a network.
  • Each organization includes one management device 100.
  • Each organization includes one or more user terminals 200 and one or more service providing devices 300.
  • the organization may be a unit obtained by dividing one organization such as a department.
  • One organization may be regarded as a plurality of organizations.
  • the plurality of organizations operate a plurality of distributed ledgers at the same time. Distributed ledgers are used to share data between multiple organizations. In this case, the plurality of organizations typically operate management devices 100 that are different from each other.
  • the synchronization processing unit 160 shares the setting information with the other management device 100.
  • the synchronization processing unit 160 synchronizes the setting information with the other management device 100.
  • the setting information of the management device 100 possessed by the organization A is changed when the three organizations of the organization A, the organization B, and the organization C are using the management system 90.
  • the synchronization processing unit 160 of the organization A transmits the setting information to the synchronization processing units 160 of the organization B and the organization C via the network.
  • each of the synchronization processing units 160 of the organization B and the organization C transmits the setting information to the ledger management unit 110 or the selection unit 120 of each organization.
  • the operation procedure of the management device 100 corresponds to the management method. Further, the program that realizes the operation of the management device 100 corresponds to the management program.
  • the operation procedure of the user terminal 200 corresponds to the user terminal method.
  • the program that realizes the operation of the user terminal 200 corresponds to the user terminal program.
  • the operation procedure of the service providing device 300 corresponds to the service providing method.
  • the program that realizes the operation of the service providing device 300 corresponds to the service providing program.
  • each distributed ledger to be operated shall have four ledger statuses of status T1, status T2, status T3, and status T4.
  • the number of status types and the content of the status are not limited to these.
  • Status T1 indicates that registration, update, and reference are permitted. In status T1, the user can register data in the distributed ledger and update or refer to the data registered in the distributed ledger.
  • Status T2 indicates that updates and references are allowed. In status T2, the user cannot register data in the distributed ledger. In status T2, the user can update or refer to the data registered in the distributed ledger.
  • Status T3 indicates that the reference is allowed. In status T3, the user can only refer to the data registered in the distributed ledger.
  • Status T4 indicates that the operation of the distributed ledger is terminated. In the status T4, the general user cannot register the data in the distributed ledger and update or refer to the data registered in the distributed ledger. In status T4, the admin user can only delete the distributed ledger.
  • FIG. 8 is a flowchart showing an example of the status setting process.
  • the status setting process will be described with reference to this figure.
  • the status setting process is a process of recording information in the status storage unit 111.
  • Step S51 Information input process
  • the management user inputs the status setting information by operating the browser unit 221.
  • the status setting information corresponds to at least one of the ledger network information D11, the ledger status information D12, the status rule information D13, and the automatic update rule information D14.
  • the management user terminal 220 sends the status setting information to the server application unit 321.
  • the management service providing device 320 sends the status setting information to the setting unit 150.
  • Step S52 Number of tissues determination process
  • the setting unit 150 determines whether or not the management system 90 is operated in a plurality of organizations. When the management system 90 is operated in a plurality of organizations, the management device 100 proceeds to step S54. Otherwise, the management device 100 proceeds to step S53.
  • Step S53 Information recording process
  • the setting unit 150 sends the status setting information to the ledger management unit 110.
  • the status recording unit 114 records the status setting information in the status storage unit 111.
  • Step S54 Synchronous processing
  • the synchronization processing unit 160 shares status setting information with other management devices 100 in the management system 90.
  • the other management device 100 is a management device 100 in the management system 90, and is a management device 100 other than the management device 100 that received the status setting information in step S51.
  • the setting unit 150 transmits the status setting information to the synchronization processing unit 160.
  • the synchronization processing unit 160 transmits the status setting information to the synchronization processing unit 160 included in all the other management devices 100.
  • the synchronization processing unit 160 included in the other management device 100 transmits the received status setting information to the corresponding setting unit 150, respectively.
  • each of the other management devices 100 executes the same process as in step S53.
  • the setting unit 150 included in the other management device 100 transmits information indicating the execution result to the management device 100 that has transmitted the status setting information, respectively.
  • Step S55 Result notification process
  • the management system 90 notifies the management user of the execution result of the status setting process.
  • the setting unit 150 sends the result information to the server application unit 321.
  • the management service providing device 320 sends the result information to the browser unit 221.
  • the browser unit 221 displays an image corresponding to the result information.
  • FIG. 9 is a flowchart showing an example of the selection rule setting process.
  • the selection rule setting process will be described with reference to this figure.
  • the selection rule setting process is a process of recording information in the selection rule storage unit 121.
  • Step S56 Information input process
  • This process is a process in which the status setting information in step S51 is replaced with the selection rule setting information.
  • the selection rule setting information corresponds to the selection rule information D21.
  • Step S57 Number of tissues determination process
  • the setting unit 150 executes the same process as in step S52.
  • the management device 100 proceeds to step S59. Otherwise, the management device 100 proceeds to step S58.
  • Step S58 Information recording process
  • the setting unit 150 sends the selection rule setting information to the selection unit 120.
  • the selection rule recording unit 123 records the selection rule setting information in the selection rule storage unit 121.
  • Step S59 Synchronous processing
  • the setting unit 150 shares selection rule setting information with other management devices 100 in the organization by using the synchronization processing unit 160.
  • the management device 100 executes the process of replacing the status setting information with the selection rule setting information, the step S51 with the step S56, and the step S53 with the step S58 in step S54.
  • Step S5a Result notification process
  • the management system 90 notifies the management user of the execution result of the selection rule setting process. This process is the same as the process in step S55.
  • FIG. 10 is a flowchart showing an example of the status automatic update process.
  • the status automatic update process will be described with reference to this figure.
  • the status automatic update process is a process in which the status automatic update unit 115 automatically updates the ledger status.
  • Step S61 Startup process
  • the status automatic update unit 115 is activated according to the update timing shown in the automatic update rule information D14.
  • the status automatic update unit 115 updates the ledger status of each update distributed ledger.
  • the update distributed ledger is a distributed ledger instructed by the status automatic update unit 115 to update the ledger status. There may be multiple updated distributed ledgers.
  • the status automatic update unit 115 may use all the distributed ledgers in operation as the update distributed ledger, or may use the distributed ledger shown in the automatic update rule information D14 as the update distributed ledger.
  • the reading unit 113 reads the ledger network information D11 and the status rule information D13 from the status storage unit 111.
  • the ledger network information D11 corresponds to the updated distributed ledger.
  • the status rule information D13 may be the one shown in the automatic update rule information D14.
  • the reading unit 113 sends the ledger network information D11 and the status rule information D13 to the status automatic updating unit 115.
  • the status automatic update unit 115 generates status update request information based on the status rule information D13.
  • the status update request information is a request for the distributed ledger and indicates a request for updating the status.
  • the status automatic update unit 115 transmits update request information to the update distributed ledger using the ledger network information D11.
  • the update distributed ledger updates the ledger status according to the status update request information.
  • the updated distributed ledger sends the result information to the status automatic update unit 115.
  • Step S63 Recording process
  • the status automatic update unit 115 updates the ledger status information D12 recorded by the status storage unit 111 based on the result information.
  • the status automatic update unit 115 confirms the new automatic update rule information D14.
  • the status automatic update unit 115 confirms the update timing as a specific example.
  • the data registered in the distributed ledger or the data registered in the distributed ledger shall be composed of a data ID (Identification) and a data object.
  • the data ID is an identifier that identifies each data.
  • the data object is the content of the data and is information other than the data ID.
  • FIG. 11 is a flowchart showing an example of new data registration processing.
  • the new data registration process will be described with reference to this figure.
  • the data registration process is a process of newly registering data in the distributed ledger.
  • the ledger management unit 110 receives registration request information from a general user.
  • the registration request information indicates a registration request from a general user and includes new data.
  • a general user inputs new data to the browser unit 211.
  • the general user terminal 210 sends the registration request information to the server application unit 311.
  • the general service providing device 310 sends the registration request information to the ledger management unit 110.
  • Step S72 Network information acquisition process
  • the reading unit 113 acquires the ledger network information D11 corresponding to each of all the distributed ledgers in operation from the status storage unit 111. Specifically, the reading unit 113 acquires the ledger network information D11 corresponding to each of the distributed ledgers whose ledger status is status T1, status T2, or status T3. The ledger network information D11 acquired in this step is used as the acquired network information.
  • Step S73 Duplicate confirmation process
  • the ledger confirmation unit 116 confirms whether or not the duplicate distributed ledger exists.
  • the duplicate distributed ledger is a distributed ledger that records data including the same data ID as the data ID included in the new data.
  • the ledger confirmation unit 116 searches for a duplicate distributed ledger using new data and acquired network information. If the duplicate distributed ledger does not exist, the management device 100 proceeds to step S74. Otherwise, the management device 100 proceeds to step S79.
  • the purpose of this step is to prevent the distributed ledger network 410 from managing a plurality of data having the same data ID in a distributed manner.
  • the management device 100 can prevent data having the same data ID from being distributed and recorded in one or a plurality of distributed ledgers.
  • Step S74 Search process
  • the ledger management unit 110 searches for a distributed ledger corresponding to the ledger status indicating that registration is permitted.
  • the ledger management unit 110 may search for a plurality of distributed ledgers.
  • the reading unit 113 searches for a distributed ledger whose ledger status is status T1 by referring to the status storage unit 111.
  • the management device 100 proceeds to step S76. Otherwise, the management device 100 proceeds to step S79.
  • the distributed ledger found in this step is used as a distributed ledger candidate.
  • Step S76 Information transmission process
  • the reading unit 113 acquires the ledger network information D11 corresponding to the distributed ledger candidate from the status storage unit 111, and sends the acquired ledger network information D11 to the selection unit 120.
  • the reading unit 113 obtains the ledger network information D11 corresponding to each of the plurality of distributed ledgers. You may get it.
  • Step S77 Quantity confirmation process
  • the miscellaneous affairs department 126 confirms the number of distributed ledger candidates. If there are a plurality of distributed ledger candidates, the management device 100 proceeds to step S78. In other cases, the management device 100 sets the distributed ledger candidate as the selected distributed ledger and proceeds to step S7a.
  • Step S78 Selection process
  • the selection unit 120 selects one distributed ledger from a plurality of distributed ledger candidates.
  • the reading unit 122 extracts the priority rule by referring to the selection rule saving unit 121.
  • the priority rule is the selection rule with the highest priority.
  • the reading unit 122 may select the priority rule in any way.
  • the selection rule processing unit 124 selects one distributed ledger from the plurality of distributed ledger candidates according to the priority rule.
  • the selection rule processing unit 124 sets the selected distributed ledger candidate as the selected distributed ledger.
  • Step S79 Error handling
  • the miscellaneous affairs department 126 executes error processing.
  • the miscellaneous affairs unit 126 may appropriately select processing according to the cause of the error.
  • the miscellaneous affairs unit 126 sends result information indicating that an error has occurred to the control unit 140.
  • Step S7a Quantity confirmation process
  • the miscellaneous affairs department 126 confirms the number of selective distributed ledgers.
  • the management device 100 proceeds to step S7b. Otherwise, the management device 100 proceeds to step S79.
  • Step S7b Registration process
  • the control unit 140 newly registers new data in the selective distributed ledger.
  • the selection unit 120 sends new data and information indicating a selective distributed ledger to the control unit 140.
  • the control unit 140 orders the selective distributed ledger to newly register new data.
  • the selective distributed ledger sends the result information to the control unit 140 after newly registering new data.
  • Step S7c Result notification processing
  • the management device 100 notifies the general user of the execution result.
  • control unit 140 transmits the result information to the server application unit 311.
  • general service providing device 310 transmits the result information to the browser unit 211.
  • the browser unit 211 displays an image corresponding to the result information.
  • FIG. 12 shows a flowchart of the update data registration process.
  • the update data registration process will be described with reference to this figure.
  • the update data is used to update the data registered in the distributed ledger.
  • the management system 90 succeeds in executing the update data registration process, the data registered in the distributed ledger before the management system 90 executes the present process is changed to the data corresponding to the update data.
  • the management device 100 updates the data registered in the distributed ledger
  • the management device 100 updates the data to be updated.
  • the update target data is registered in the distributed ledger and has the same data ID as the data ID included in the update data.
  • Step S81 Data input process
  • This process is a process in step S71 in which the registration request information is replaced with the update request information and the new data is replaced with the update data.
  • the update request information indicates an update request from a general user and includes update data.
  • Step S82 Search process
  • the ledger management unit 110 searches for a distributed ledger corresponding to the ledger status indicating that the update is permitted. Specifically, the reading unit 113 searches for a distributed ledger whose ledger status is status T1 or status T2 by referring to the status storage unit 111.
  • the ledger management unit 110 finds one or more of the distributed ledgers, the management device 100 proceeds to step S83. Otherwise, the management device 100 proceeds to step S8b.
  • Step S83 Network information acquisition process
  • the reading unit 113 acquires the ledger network information D11 corresponding to the distributed ledger found in step S82 from the status storage unit 111, and sends the acquired ledger network information D11 to the selection unit 120.
  • the ledger management unit 110 acquires the ledger network information D11 corresponding to each of the plurality of distributed ledgers.
  • the ledger network information D11 acquired in this step is used as the acquired network information.
  • Step S84 Selection process
  • the ledger selection unit 125 selects the update distributed ledger. In the update distributed ledger, it is confirmed by the ledger selection unit 125 whether or not the update target data is recorded.
  • the selection unit 120 may use the distributed ledger found in step S82 as an updated distributed ledger.
  • the selection unit 120 may select a plurality of updated distributed ledgers.
  • the selection unit 120 may select a plurality of distributed ledgers.
  • Step S85 Quantity confirmation process
  • the miscellaneous affairs department 126 confirms the number of updated distributed ledgers. If there are a plurality of updated distributed ledgers, the management device 100 proceeds to step S87. In other cases, the ledger selection unit 125 uses the updated distributed ledger as the selected distributed ledger, and the management device 100 proceeds to step S86.
  • Step S86 Record confirmation process
  • the selection unit 120 confirms whether or not the update target data is recorded in the selective distributed ledger.
  • the selection unit 120 confirms the selective distributed ledger by using the acquired network information and the data ID included in the update data.
  • the management device 100 proceeds to step S8c. Otherwise, the management device 100 proceeds to step S8b.
  • the control unit 140 may check the data recorded in the selective distributed ledger.
  • Step S87 Selection process
  • the ledger selection unit 125 selects one updated distributed ledger that has not yet been selected in this step, and sets the selected updated distributed ledger as the selected distributed ledger.
  • the updated distributed ledger selected by the ledger selection unit 125 is not marked in step S89.
  • Step S88 Record confirmation process
  • the ledger selection unit 125 executes the same process as in step S86.
  • the management device 100 proceeds to step S8c. Otherwise, the management device 100 proceeds to step S89.
  • Step S89 Marking process
  • the ledger selection unit 125 adds a mark indicating that the ledger has already been selected to the selective distributed ledger.
  • Step S8a Ledger confirmation process
  • the ledger selection unit 125 confirms whether or not there is an update distributed ledger that has not yet been selected in step S87. If there is an updated distributed ledger that has not yet been selected in step S87, management device 100 proceeds to step S87. Otherwise, the management device 100 proceeds to step S8b.
  • Step S8b Error handling
  • the miscellaneous affairs department 126 executes error processing.
  • the miscellaneous affairs unit 126 transmits result information indicating an error to the control unit 140.
  • Step S8c Update process
  • the control unit 140 records the update data in the selective distributed ledger.
  • the ledger selection unit 125 sends update data and information indicating a selective distributed ledger to the control unit 140.
  • the control unit 140 instructs the selective distributed ledger to update the update target data with the update data.
  • the selective distributed ledger updates the update target data with the update data and transmits the result information to the control unit 140.
  • Step S8d Result notification processing
  • FIG. 13 is a flowchart showing an example of data reference processing.
  • the data reference process will be described with reference to this figure.
  • the data reference process is a process in which the user refers to the reference target data registered in the distributed ledger.
  • the reference target data corresponds to the reference data.
  • the reference data may be only the data ID or only the data object.
  • the reference data may be information indicating an attribute or type of data.
  • the reference target data is the same as the reference data.
  • Step S91 Data input processing
  • This process is a process in step S71 in which the registration request information is replaced with the reference request information and the new data is replaced with the reference data.
  • the reference request information indicates a reference request from a general user and includes reference data.
  • Step S92 Search process
  • the ledger management unit 110 searches for a distributed ledger corresponding to the ledger status indicating that the reference is permitted. Specifically, the reading unit 113 searches for a distributed ledger whose ledger status is status T1, status T2, or status T3 by referring to the status storage unit 111.
  • the ledger management unit 110 finds one or more of the distributed ledgers, the management device 100 proceeds to step S93. Otherwise, the management device 100 proceeds to step S9b.
  • Step S93 Network information acquisition process
  • Step S94 Selection process
  • the ledger selection unit 125 selects the reference distributed ledger.
  • the ledger selection unit 125 confirms whether or not the reference data is recorded.
  • the selection unit 120 may use the distributed ledger found in step S92 as a reference distributed ledger.
  • Step S95 Quantity confirmation process
  • the miscellaneous affairs department 126 confirms the number of reference distributed ledgers. If there are a plurality of reference distributed ledgers, the management device 100 proceeds to step S97. In other cases, the ledger selection unit 125 uses the reference distributed ledger as the selected distributed ledger, and the management device 100 proceeds to step S96.
  • Step S96 Record confirmation process
  • the selection unit 120 confirms whether or not the reference target data is recorded in the selective distributed ledger.
  • the selection unit 120 executes the same process as in step S86. If the reference data is recorded in the selective distributed ledger, the management device 100 proceeds to step S9c. Otherwise, the management device 100 proceeds to step S9b.
  • Step S97 Selection process
  • the ledger selection unit 125 selects one reference distributed ledger that has not yet been selected in this step, and sets the selected reference distributed ledger as the selected distributed ledger. This process is the same as the process in step S87.
  • Step S98 Record confirmation process
  • the ledger selection unit 125 executes the same process as in step S96.
  • the management device 100 proceeds to step S9c. Otherwise, the management device 100 proceeds to step S99.
  • Step S99 Marking process
  • Step S9a Ledger confirmation process
  • Step S9b Error handling
  • Step S9c Reference processing
  • the control unit 140 refers to the reference target data recorded in the selective distributed ledger.
  • the ledger selection unit 125 sends reference data and information indicating a selective distributed ledger to the control unit 140.
  • the control unit 140 instructs the selective distributed ledger to return the information of the reference target data.
  • the selective distributed ledger transmits the reference target data and the result information to the control unit 140.
  • Step S9d Result notification processing
  • FIG. 14 is a flowchart showing an example of the ledger deletion process by the management device 100.
  • the ledger deletion process will be described with reference to this figure.
  • the ledger deletion process is a process for deleting a distributed ledger.
  • Step S5011 Ledger selection process
  • the admin user selects the Delete Distributed Ledger.
  • the deleted distributed ledger is a distributed ledger that the management user wants to delete.
  • the management user selects the deleted distributed ledger by using the browser unit 221 of the management user terminal 220.
  • the management user terminal 220 sends the deletion request information to the server application unit 321.
  • the deletion request information indicates a request for deleting the deleted distributed ledger from the management user, and includes the information of the deleted distributed ledger.
  • the management service providing device 320 sends the deletion request information to the control unit 140.
  • Step S502 Status confirmation process
  • the control unit 140 confirms whether or not the ledger status corresponding to the deleted distributed ledger indicates the end of operation.
  • the control unit 140 inquires the ledger management unit 110 about the ledger status corresponding to the deleted distributed ledger.
  • the ledger management unit 110 acquires the ledger status information D12 corresponding to the deleted distributed ledger by referring to the status storage unit 111, and sends the acquired ledger status information D12 to the control unit 140.
  • the control unit 140 confirms whether or not the ledger status of the deleted distributed ledger is status T4.
  • the management device 100 proceeds to step S503. Otherwise, the management device 100 proceeds to step S504.
  • Step S503 Delete process
  • the control unit 140 deletes the deleted distributed ledger.
  • the control unit 140 inquires the ledger management unit 110 of the ledger network information D11 corresponding to the deleted distributed ledger.
  • the ledger management unit 110 acquires the ledger network information D11 corresponding to the deleted distributed ledger by referring to the status storage unit 111, and controls the acquired ledger network information D11. Send to.
  • the control unit 140 transmits the deletion request information to the deletion distributed ledger using the ledger network information D11.
  • the control unit 140 sends the result information indicating that the process has been completed normally to the server application unit 321.
  • Step S504 Error notification processing
  • the control unit 140 sends result information indicating that an error has occurred to the server application unit 321.
  • Step S505 Result notification processing
  • the management system 90 notifies the management user of the execution result of the ledger deletion process.
  • the management service providing device 320 transmits the result information received from the management device 100 to the browser unit 221.
  • the browser unit 221 displays an image corresponding to the result information received from the management service providing device 320.
  • the management device 100 assigns a ledger status to each of one or more distributed ledgers.
  • the ledger status corresponds to the status of the distributed ledger.
  • the management device 100 limits the processing that can be executed by the user according to the ledger status. Further, the management device 100 appropriately deletes the distributed ledger according to the ledger status. Therefore, according to the present embodiment, the management device 100 can prevent the storage usage of the distributed ledger from becoming bloated due to long-term operation.
  • the management device 100 can also operate the distributed ledger in consideration of the life cycle of the distributed ledger.
  • the ledger status may indicate the life cycle of the distributed ledger.
  • the management device 100 may appropriately delete the distributed ledger whose life cycle of all the registered data has ended.
  • the selection unit 120 when there are a plurality of candidates for the distributed ledger controlled by the management device 100, the selection unit 120 can uniquely select the distributed ledger according to the selection rule.
  • the management user can set selection rules. Therefore, according to the present embodiment, the user records data in the distributed ledger included in the ledger network 410 or records the data in the distributed ledger without worrying about the existence of a plurality of distributed ledgers in the ledger network 410. It is possible to refer to the data recorded by the distributed ledger included in the network 410.
  • the selection unit 120 does not have to select one distributed ledger from the plurality of distributed ledgers.
  • the selection unit 120 provides the user with an opportunity to select a distributed ledger.
  • the selection unit 120 may use the distributed ledger selected by the user as the selected distributed ledger.
  • the status storage unit 111 may hold a data ID corresponding to the data recorded in the distributed ledger.
  • the ledger confirmation unit 116 does not confirm the distributed ledger in step S73, and determines whether or not the duplicate distributed ledger exists by referring to the status storage unit 111. do.
  • FIG. 15 shows a hardware configuration example of the management device 100 according to this modification.
  • the management device 100 includes a processing circuit 18 instead of at least one of the processor 11, the memory 12, and the auxiliary storage device 13.
  • the processing circuit 18 is hardware that realizes at least a part of each part included in the management device 100.
  • the processing circuit 18 may be dedicated hardware, or may be a processor 11 that executes a program stored in the memory 12.
  • the processing circuit 18 is dedicated hardware, the processing circuit 18 is, as a specific example, a single circuit, a composite circuit, a programmed processor, a parallel programmed processor, an ASIC (ASIC is an Application Specific Integrated Circuit), an FPGA. (Field Programmable Gate Array) or a combination thereof.
  • the management device 100 may include a plurality of processing circuits that replace the processing circuit 18. The plurality of processing circuits share the role of the processing circuit 18.
  • management device 100 some functions may be realized by dedicated hardware, and the remaining functions may be realized by software or firmware.
  • the processing circuit 18 is realized by hardware, software, firmware, or a combination thereof.
  • the processor 11, the memory 12, the auxiliary storage device 13, and the processing circuit 18 are collectively referred to as a "processing circuit Lee". That is, the functions of the functional components of the management device 100 are realized by the processing circuit.
  • the user terminal 200, the service providing device 300, and the node 411 may each be provided with a processing circuit 18 like the management device 100.

Landscapes

  • Engineering & Computer Science (AREA)
  • Databases & Information Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Data Mining & Analysis (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Computing Systems (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

管理装置(100)は、台帳管理部(110)と、制御部(140)と、選択部(120)とを備える。台帳管理部(110)は、分散された電子データを記録する複数の分散型台帳を管理する。制御部(140)は、複数の分散型台帳のいずれかを制御する。選択部(120)は、複数の分散型台帳候補が存在する場合に、複数の分散型台帳候補から分散型台帳を一意に選択する規則を示す選択ルールを含む選択ルール情報を記録しており、かつ、複数の分散型台帳候補が存在する場合に選択ルールに従って複数の分散型台帳候補から分散型台帳を一意に選択する。分散型台帳候補は、制御部(140)が制御する分散型台帳の候補である。

Description

管理装置、管理方法、及び、管理プログラム
 本開示は、管理装置、管理方法、及び、管理プログラムに関する。
 分散型台帳は、複数のサーバ等を用いることによってデータを共有する技術である。分散型台帳において、複数のサーバ等は、過去の全てのデータ操作に関する情報を保持している。データ操作は、具体例として、分散型台帳にデータを登録することと、分散型台帳に登録されたデータを更新することとである。分散型台帳の主な特徴として、複数のサーバ間でデータの改ざん等を相互に容易に監視することができることがある。
 ブロックチェーンは、分散型台帳の一例である。ブロックチェーンは、ブロックを生成し、かつ、時系列に従ってデータを保管する。ブロックは、データの単位である。各々のブロックには、前後のブロックを結びつける情報が含まれている。
 あるブロックの内容を変更した場合、変更したブロックの後ろに連なる全てのブロックの内容を変更する必要がある。そのため、一度記録した過去のブロック内のデータを変更すること、又は削除することは困難である。従って、ブロックチェーンは、高い耐改ざん性を有する。
 ブロックチェーンは、データを検証するために、過去の全てのデータを保存する必要がある。ブロックチェーンにおけるストレージ使用量は、線形に増加する。そのため、ブロックチェーンを長期間運用すると、ストレージ使用量が膨大になる。
 特許文献1は、スマートコントラクトに満了日時を設定し、かつ、満了日時を過ぎたスマートコントラクトに紐づくブロックチェーンに対してデータを記録することができないようにする技術を開示している。本技術によれば、記録することができなくなったブロックチェーンを削除することにより、ストレージ使用量を削減することができる。
特開2019-008791号公報
 特許文献1は、ブロックチェーンに紐づいたスマートコントラクトの運用が終了した際に、ブロックチェーンを削除することによりデータを削減する手法を開示している。本手法において、スマートコントラクトの運用が終了するまで、スマートコントラクトに対応するブロックチェーンのデータを削減することができない。
 ここで、ブロックチェーンの状態を管理することによって、運用が終了したブロックチェーンを特定することが考えられる。しかしながら、特許文献1の手法によっては、同一の状態のブロックチェーンが複数存在する場合に、ブロックチェーンを一意に選択することができない。
 本開示は、複数の分散型台帳から、分散型台帳を一意に選択できるようにすることを目的とする。
 本開示に係る管理装置は、
 分散された電子データを記録する複数の分散型台帳を管理する台帳管理部と、
 前記複数の分散型台帳のいずれかを制御する制御部と、
 前記制御部が制御する分散型台帳の候補である複数の分散型台帳候補であって、前記複数の分散型台帳に含まれる2つ以上の分散型台帳から成る複数の分散型台帳候補が存在する場合に前記複数の分散型台帳候補から分散型台帳を一意に選択する規則を示す選択ルールを含む選択ルール情報を記録しており、かつ、前記複数の分散型台帳候補が存在する場合に前記選択ルールに従って前記複数の分散型台帳候補から分散型台帳を一意に選択する選択部と
を備える。
 本開示に係る管理装置は、制御部と、選択部とを備える。選択部は、選択ルールに従って複数の分散型台帳候補から分散型台帳を一意に選択する。分散型台帳候補は、制御部が制御する分散型台帳の候補である。
 従って、本開示によれば、複数の分散型台帳から、分散型台帳を一意に選択できるようにすることができる。
実施の形態1に係る管理システム90の構成例。 実施の形態1に係る管理システム90のハードウェア構成例。 実施の形態1に係る管理システム90のソフトウェア構成例。 実施の形態1に係る台帳管理部110の構成例。 実施の形態1に係る選択部120の構成例。 実施の形態1に係る管理システム90のソフトウェア構成例。 実施の形態1に係る管理システム90の構成例。 実施の形態1に係るステータス設定処理を示すフローチャート。 実施の形態1に係る選択ルール設定処理を示すフローチャート。 実施の形態1に係るステータス自動更新処理を示すフローチャート。 実施の形態1に係る新規データ登録処理を示すフローチャート。 実施の形態1に係る更新データ登録処理を示すフローチャート。 実施の形態1に係るデータ参照処理を示すフローチャート。 実施の形態1に係る台帳削除処理を示すフローチャート。 実施の形態1の変形例に係る管理装置100の構成例。
 実施の形態の説明及び図面において、同じ要素及び対応する要素には同じ符号を付している。同じ符号が付された要素の説明は、適宜に省略又は簡略化する。図中の矢印はデータの流れ又は処理の流れを主に示している。
 実施の形態1.
 以下、本実施の形態について、図面を参照しながら詳細に説明する。
***構成の説明***
 図1は、本実施の形態に係る管理システム90の構成例を示している。管理システム90は、管理装置100と、ユーザ端末200と、サービス提供装置300と、分散型台帳ネットワーク群400とを備える。分散型台帳ネットワーク群400は、1つ以上の分散型台帳ネットワーク410を備える。
 管理システム90は、本図に示すように、管理装置100と、ユーザ端末200と、サービス提供装置300と、分散型台帳ネットワーク410とを、それぞれ複数個備えても良い。本図中の管理装置100_1と、管理装置100_N1とは、それぞれ複数の管理装置100を区別するための表記である。ユーザ端末200と、サービス提供装置300と、分散型台帳ネットワーク410とについても、管理装置100と同様に表記されている。ここで、N1と、N2と、N3と、N4とは、それぞれ2以上の整数である。
 管理装置100と、ユーザ端末200と、サービス提供装置300と、分散型台帳ネットワーク410とは、ネットワークを介して相互に接続されている。ネットワークは、具体例として、インターネット、イントラネット、又はこれらの組み合わせである。管理システム90の全ての構成要素が相互に接続されていなくても良い。
 分散型台帳ネットワーク410は、1つ以上のノード411から構成される。分散型台帳ネットワーク410が複数のノード411から構成される場合、複数のノード411は、ネットワークを介して相互に接続される。
 管理装置100は、1つ以上の分散型台帳ネットワーク410を管理する。管理装置100は、具体例として、サービス提供装置300を介したユーザ端末200からの要求に応じて、分散型台帳にデータを記録し、分散型台帳のデータを参照し、分散型台帳のデータを削除し、又は、分散型台帳の運用方法を設定する。分散型台帳の運用方法は、台帳ステータスに示されていても良い。台帳ステータスは、分散型台帳の状態を示す情報である。台帳ステータスは、分散型台帳の制御制限を示す。
 ユーザ端末200は、ユーザが分散型台帳にアクセスする際に用いる端末である。ユーザは、特に断りがない限り、分散型台帳を用いる主体である。ユーザは、コンピュータ等、人でなくても良い。
 サービス提供装置300は、ユーザに対してサービスを提供するサーバである。サービスは、データを記憶する領域として分散型台帳を利用することに関連する。サービスは、具体例として、業務アプリケーション、又はWebアプリケーションを用いて提供される。アプリケーションは、特に断りがない限り、アプリケーションプログラムのことである。
 分散型台帳ネットワーク410は、1台以上のノード411を備えるネットワークである。ノード411は、分散型台帳を運用する。1台のノード411が複数の分散型台帳を運用しても良い。分散型台帳は、分散された電子データを記録する。分散型台帳には、制御制限がかけられている。制御制限は、ユーザが分散型台帳を制御することに対する制限を示す。電子データは、どのように分散されていても良い。
 また、管理システム90は、具体例として、ユーザがいない場合又はユーザにサービスを提供しない場合において、ユーザ端末200と、サービス提供装置300とを、それぞれ1つも備えなくても良い。
 図2は、本実施の形態に係る管理システム90のハードウェア構成例を示している。本例において、管理システム90は、管理装置100と、ユーザ端末200と、サービス提供装置300と、分散型台帳ネットワーク410とをそれぞれ1つ備える。また、分散型台帳ネットワーク410を構成するノードは1台である。
 管理装置100は、典型的には、コンピュータから成る。管理装置100は、複数のコンピュータから成っても良い。
 管理装置100は、プロセッサ11と、メモリ12と、補助記憶装置13と、通信装置16と等のハードウェアを備える。これらのハードウェアは、信号線19を介して互いに接続されている。
 プロセッサ11は、演算処理を行うIC(Integrated Circuit)であり、かつ、コンピュータが備えるハードウェアを制御する。プロセッサ11は、具体例として、CPU(Central Processing Unit)、DSP(Digital Signal Processor)、又はGPU(Graphics Processing Unit)である。
 管理装置100は、プロセッサ11を代替する複数のプロセッサを備えてもよい。複数のプロセッサは、プロセッサ11の役割を分担する。
 メモリ12は、典型的には、揮発性の記憶装置である。メモリ12は、主記憶装置又はメインメモリとも呼ばれる。メモリ12は、具体例として、RAM(Random Access Memory)である。メモリ12に記憶されたデータは、必要に応じて補助記憶装置13に保存される。
 補助記憶装置13は、典型的には、不揮発性の記憶装置である。補助記憶装置13は、具体例として、ROM(Read Only Memory)、HDD(Hard Disk Drive)、又はフラッシュメモリである。補助記憶装置13に記憶されたデータは、必要に応じてメモリ12にロードされる。
 メモリ12と、補助記憶装置13とは、一体的に構成されていても良い。
 通信装置16は、レシーバ及びトランスミッタである。通信装置16は、具体例として、通信チップ又はNIC(Network Interface Card)である。
 管理装置100の各部は、他の装置等と通信する際に通信装置16を用いても良い。
 補助記憶装置13は、管理プログラムを記憶している。管理プログラムは、管理装置100が備える各部の機能をコンピュータに実現させるプログラムである。管理プログラムは、複数のファイルから成っても良い。管理プログラムは、メモリ12にロードされて、プロセッサ11によって実行される。管理装置100が備える各部の機能は、ソフトウェアにより実現される。
 管理装置100の各部がデータを送受信する場合、管理装置100の各部は、通信装置16を介してデータを用いる。
 管理プログラムを実行する際に用いられるデータと、管理プログラムを実行することによって得られるデータとは、管理装置100が備える記憶装置に適宜記憶される。管理装置100が備える記憶装置は、具体例として、メモリ12と、補助記憶装置13と、プロセッサ11内のレジスタと、プロセッサ11内のキャッシュメモリとの少なくとも1つから成る。なお、本明細書において、データと、情報とは、同等の意味を持つこともある。
 メモリ12の機能と、補助記憶装置13の機能とのそれぞれは、いずれか1つ以上の記憶装置によって実現されても良い。
 本明細書に記載されているいずれのプログラムも、コンピュータが読み取り可能な不揮発性の記録媒体に記録されていても良い。不揮発性の記録媒体は、具体例として、光ディスク又はフラッシュメモリである。本明細書に記載されているいずれのプログラムも、プログラムプロダクトとして提供されても良い。
 サービス提供装置300の構成は、管理装置100の構成と同様である。サービス提供装置300は、管理プログラムの代わりにサービス提供プログラムを記憶している。
 ノード411の構成は、管理装置100の構成と同様である。分散型台帳ネットワーク410は、管理プログラムの代わりに台帳プログラムを記憶している。
 ユーザ端末200は、プロセッサ11と、メモリ12と、補助記憶装置13と、入力インタフェース14と、出力インタフェース15と、通信装置16とを備える。
 入力インタフェース14は、入力装置が接続されるポートである。入力装置は、具体例として、キーボード又はマウス等、管理装置100を操作する装置である。入力インタフェース14は、具体例として、USB(Universal Serial Bus)端子である。
 出力インタフェース15は、出力装置が接続されるポートである。出力装置は、具体例として、ディスプレイである。出力インタフェース15は、具体例として、HDMI(登録商標、High-Definition Multimedia Interface)端子である。
 タッチパネルが、入力インタフェース14と、出力インタフェース15とを備えても良い。
 図3は、管理システム90のソフトウェア構成例を示している。本例に示す管理装置100は、典型的には、1つの組織が1つの管理システム90を運用する場合に用いられる。
 管理装置100は、本図に示すように、台帳管理部110と、選択部120と、制御部140と、設定部150とを備える。
 台帳管理部110は、ユーザが入力した操作命令と、操作対象データとを読み取る。操作命令は、分散型台帳を操作する命令である。操作命令は、具体例として、分散型台帳へのデータの登録、並びに、分散型台帳に登録されているデータの更新又は参照に関する命令である。操作対象データは、操作命令に対応するデータである。
 一般ユーザは、一般ユーザ端末200を介して一般サービス提供装置310に対して操作命令を入力する。一般ユーザは、操作命令と併せて、操作対象データを入力しても良い。
 台帳管理部110は、台帳ステータスを管理する。台帳管理部110は、操作命令を用いて分散型台帳候補を選定する。分散型台帳候補は、管理装置100が制御する分散型台帳の候補を示す。台帳管理部110は、分散型台帳候補を選定する際に、操作対象データを用いても良い。
 台帳管理部110は、分散型台帳候補を選択部120に渡す。
 台帳管理部110は、少なくとも1つの分散型台帳それぞれに対応する台帳ステータスを含む台帳ステータス情報D12を記録している。
 台帳管理部110は、台帳ステータス情報D12を含む設定情報を記録していても良い。台帳管理部110は、複数の分散型台帳を管理しても良い。
 選択部120は、分散型台帳候補から、選択分散型台帳を選択する。選択分散型台帳は、管理装置100が対象とする分散型台帳である。
 選択分散型台帳となり得る分散型台帳が複数存在する場合、選択部120は、選択ルールに従って、分散型台帳候補から1つの分散型台帳を選択する。選択ルールは、分散型台帳を選択する規則を示す。なお、本明細書に記載されているいずれのルールも、複数存在しても良い。
 選択ルールは、優先度と関連付けられていても良い。優先度は、選択部120が選択ルールをする際の優先順位を示す。
 選択部120は、選択ルール情報D21を記録している。選択ルール情報D21は、選択ルールを含む。選択ルールは、複数の分散型台帳候補が存在する場合に、複数の分散型台帳候補から分散型台帳を一意に選択する規則を示す。選択ルールは、複数の分散型台帳候補から1つの分散型台帳を選択する規則を示しても良い。複数の分散型台帳候補は、制御部140が制御する分散型台帳の候補であり、かつ、台帳ネットワーク410が備える複数の分散型台帳に含まれる2つ以上の分散型台帳から成る。
 選択部120は、複数の分散型台帳候補が存在する場合に、選択ルールに従って複数の分散型台帳候補から分散型台帳を一意に選択する。
 選択ルール情報D21は、複数の選択ルールと、複数の選択ルールそれぞれに対応する優先度とを含んでも良い。選択部120は、複数の選択ルールそれぞれに対応する優先度を考慮して、複数の選択ルールから優先ルールを選択しても良い。
 選択部120は、選択ルール情報を含む設定情報を記録していても良い。
 制御部140は、選択部120が選択したノード411に対して、登録要求、更新要求、又は、参照要求に従う処理を実行する。ノード411は、要求に対応する処理を実行し、かつ、結果情報を制御部140に送信する。制御部140は、分散型台帳から受信した結果情報をサービス提供装置300に送る。結果情報は、実行結果を示す情報である。
 登録要求は、分散型台帳に対する要求であって、新規データを分散型台帳に新規に登録する要求である。新規データは、一般ユーザが分散型台帳に新規に登録することを希望するデータである。
 更新要求は、分散型台帳に対する要求であって、更新データを用いることによって分散型台帳に登録されているデータを更新する要求である。更新データは、分散型台帳に登録されているデータを更新することに用いられるデータである。
 参照要求は、分散型台帳に対する要求であって、分散型台帳に登録されている参照データを参照する要求である。参照データは、分散型台帳に登録されているデータを参照することに用いられるデータである。参照データは、参照データに対応するデータであっても良い。新規データと、更新データとは、それぞれ参照データと同様である。
 制御部140は、管理装置100が管理する分散型台帳の内、運用が終了した分散型台帳を削除する。制御部140が分散型台帳を削除することは、管理装置100が分散型台帳を管理対象から除外することである。削除された分散型台帳は、典型的には、台帳ネットワーク410を構成する分散型台帳ではなくなる。制御部140は、管理ユーザからの削除要求に従って、分散型台帳を削除する。削除要求は、分散型台帳を削除する要求である。制御部140は、台帳管理部110を参照することによって、運用が終了した分散型台帳を特定する。
 制御部140は、運用中ではない分散型台帳を削除しても良い。運用中の分散型台帳は、分散型台帳の機能を発揮している。運用中の分散型台帳は、スマートコントラクトに対応する分散型台帳であっても良い。
 制御部140は、少なくとも1つの分散型台帳それぞれを、少なくとも1つの分散型台帳それぞれに対応する台帳ステータスに従って制御する。
 制御部140は、台帳ステータスが台帳ステータスに対応する分散型台帳の運用を終了することを示す場合に、分散型台帳を削除しても良い。制御部140は、複数の分散型台帳のいずれかを制御しても良い。
 なお、結果情報を含む情報を結果情報と呼ぶこともある。また、結果情報という名称の情報の内容が、常に同じとは限らない。結果情報は、結果を示す情報の総称でもある。
 本明細書に示されている他の情報についても、結果情報と同様である。本明細書に示されているいずれの情報も、所定の内容を示す情報を含む情報の総称であっても良い。
 設定部150は、設定情報を受信し、かつ、受信した設定情報を台帳管理部110又は選択部120に記録する。設定情報は、ステータス設定情報と、選択ルール設定情報とに分類される。設定情報は、自動更新ルールの情報を含んでも良い。自動更新ルールの情報は、台帳ステータスを更新する規則を示す。
 ステータス設定情報は、典型的には、台帳ネットワーク情報D11と、台帳ステータス情報D12と、ステータスルール情報D13と、自動更新ルール情報D14とのいずれかを設定することに用いられる情報の総称である。
 台帳ネットワーク情報D11は、管理装置100が分散型台帳と通信する際に用いられる。台帳ネットワーク情報D11は、具体例として、分散型台帳ネットワーク410の構成を示す情報、ノード411の構成を示す情報、又は、ノード411のアドレスを示す情報である。
 台帳ステータス情報D12は、台帳ステータスを含む。台帳ステータスは、具体例として、分散型台帳にデータを新規に登録することを許可することと、分散型台帳に登録されたデータを更新することを許可することと、分散型台帳に登録されたデータを参照することを許可することとのいずれか1つを示す、又は、少なくとも2つの組み合わせを示す。台帳ステータスは、分散型台帳にデータを新規に登録することを受け付けないことと、分散型台帳に登録されたデータの更新及び参照を許可していることとを示す情報であっても良い。台帳ステータス情報D12は、分散型台帳の運用を終了することを示す台帳ステータスを含んでも良い。
 ステータスルール情報D13は、ステータスルールを示す。ステータスルールは、分散型台帳の台帳ステータスを更新する規則を示す。ステータスルール情報D13は、具体例として、ステータスT1、ステータスT2、ステータスT3、ステータスT4の順に台帳ステータスを更新するルールである。本例において、ステータス自動更新部115は、ステータスT4の次にステータスT1に更新しても良い。なお、ステータスT1からステータスT4までの内容については、後述する。
 自動更新ルール情報D14は、自動更新ルールを示す。自動更新ルールは、台帳管理部110が台帳ステータスを自動的に更新する規則を示す。自動更新ルールは、更新タイミングを示す規則であっても良い。更新タイミングは、台帳ステータスを更新するタイミングである。更新タイミングは、日時を示すものであっても良く、台帳ステータスを更新する更新条件を示すものであっても良い。更新条件は、具体例として、分散型台帳の状態である。自動更新ルールは、具体例として、指定日時に台帳ステータスを更新する規則、指定期間毎に台帳ステータスを更新する規則、又は、分散型台帳のデータ使用量が一定値を超過することを契機として台帳ステータスを遷移させる規則である。別の具体例として、自動更新ルール情報D14は、毎日0:00にステータスルール情報D13を確認し、かつ、ステータスルール情報D13に従って台帳ステータスを更新するというルールである。自動更新ルールは、複数の規則から成っても良い。自動更新ルール情報D14には、台帳ステータスを更新する分散型台帳を示す情報が含まれていても良い。
 なお、管理システム90は、管理ユーザが管理ユーザ端末220を操作することによって台帳ステータスを変更することができる構成であっても良い。
 選択ルール情報D21は、選択ルールを示す。選択ルールは、選択部120が分散型台帳を選択する際に用いる規則である。
 選択ルールは、具体例として、新規にデータを登録することが可能である分散型台帳が複数存在する場合に最も現在時刻に近い時刻に生成された分散型台帳を選択する規則、データの更新が可能である分散型台帳が複数存在する場合に更新元のデータが存在する分散型台帳を選択する規則、又は、新規にデータを登録することが可能である分散型台帳が複数存在する場合に分散型台帳に記録されているデータの量が最も少ない分散型台帳を選択する規則である。また、選択ルールは、時間に関する情報に基づいて分散型台帳を選択する規則であっても良く、データに関する情報に基づいて分散型台帳を選択する規則であっても良い。時間に関する情報は、具体例として、現在時刻、又は分散型台帳が生成された時刻である。データに関する情報は、具体例として、分散型台帳と関係があるデータに含まれている情報である。分散型台帳と関係があるデータは、具体例として、分散型台帳に登録されているデータである。
 設定部150がステータス設定情報を受信した場合、設定部150は、台帳管理部110を設定する。設定部150が選択ルール設定情報を受信した場合、設定部150は、選択部120を設定する。
 管理ユーザは、管理サービス提供装置320を介して設定部150に設定情報を送信する。管理ユーザは、分散型台帳を管理する権限を有するユーザである。一般ユーザは、管理ユーザ以外のユーザである。管理ユーザは、一般ユーザと同じ権限を有しても良い。ユーザは、一般ユーザと、管理ユーザとの総称である。
 ユーザ端末200は、一般ユーザ端末210と、管理ユーザ端末220とに分類される。
 一般ユーザ端末210は、一般ユーザが扱う端末である。一般ユーザ端末210は、ブラウザ部211を備える。
 一般ユーザは、ブラウザ部211を操作することによって、分散型台帳に新規にデータを登録すること、又は分散型台帳に登録されているデータを参照することができる。
 管理ユーザ端末220は、管理ユーザが扱う端末である。管理ユーザ端末220は、ブラウザ部221を備える。管理ユーザ端末220は、一般ユーザ端末210と同じ機能を備えても良い。
 管理ユーザは、ブラウザ部221を操作することによって、管理装置100を設定すること、又は分散型台帳を削除することができる。
 一般ユーザ又は管理ユーザは、管理装置100を介して分散型台帳を制御する。
 ブラウザ部211は、情報表示アプリケーションである。情報表示アプリケーションは、情報を表示する機能を有する。情報表示アプリケーションは、具体例として、Webブラウザ又は専用のアプリケーションである。ブラウザ部211は、ユーザからの情報を受け付ける機能と、装置から受信した情報を出力する機能とを有する。ブラウザ部221は、ブラウザ部211と同様である。
 サービス提供装置300は、一般サービス提供装置310と、管理サービス提供装置320とに分類される。
 一般サービス提供装置310は、一般ユーザ端末210と、管理装置100との通信を仲介する。一般サービス提供装置310は、サーバアプリケーション部311を備える。
 サーバアプリケーション部311は、通信アプリケーションを有する。通信アプリケーションは、通信を仲介する機能を有する。
 管理サービス提供装置320は、管理ユーザ端末220と、管理装置100との通信を仲介する。管理サービス提供装置320は、サーバアプリケーション部321を備える。
 サーバアプリケーション部321は、サーバアプリケーション部311と同様である。
 ノード411は、管理装置100からの要求に従って処理を実行する。
 分散型台帳ネットワーク410は、1まとまりの情報を複数のノード411に分散させて管理しても良い。複数のノード411が、同じデータを重複して管理していても良い。ノード411には、取引データが記録されても良い。
 図4は、台帳管理部110の構成例を示している。台帳管理部110は、本図に示すように、ステータス保存部111と、ステータス読出部113と、ステータス記録部114と、ステータス自動更新部115と、台帳確認部116とを備える。
 台帳管理部110は、台帳管理部110が備える各部の総称でもある。
 ステータス保存部111は、台帳ネットワーク情報D11と、台帳ステータス情報D12と、ステータスルール情報D13と、自動更新ルール情報D14とを保持することができる。
 読出部113は、ステータス保存部111に記録されている情報を読み出す。読出部113は、読み出した台帳ネットワーク情報D11を選択部120へ渡しても良い。
 ステータス記録部114は、ステータス保存部111に台帳ステータスの情報を記録する。
 ステータス自動更新部115は、ステータス保存部111が記録している自動更新ルール情報D14に基づいて、台帳ステータスを自動的に更新する。
 ステータス自動更新部115は、自動更新ルールに従って台帳ステータスを更新する。
 図5は、選択部120の構成例を示している。選択部120は、本図に示すように、選択ルール保存部121と、読出部122と、選択ルール記録部123と、選択ルール処理部124と、台帳選択部125と、雑務部126とを備える。
 選択部120は、選択部120が備える各部の総称でもある。
 選択ルール保存部121は、選択ルール情報D21と、その他情報とを保持している。
 読出部122は、選択ルール保存部121に記録されている情報を読み出す。
 選択ルール記録部123は、選択ルール保存部121に選択ルール情報D21を記録する。
 選択ルール処理部124は、選択ルール情報D21に従って分散型台帳を1つ選択する。選択ルール処理部124は、台帳ネットワーク情報D11を用いても良い。
 選択ルール処理部124は、制御部140に選択した分散型台帳を示す情報を送っても良い。
 台帳選択部125は、分散型台帳を選択する。
 雑務部126は、選択部120の機能を実現するために必要な処理を実行する。
 ステータス保存部111は、入出力手段を備えていれば、どのような記憶領域であっても良い。ステータス保存部111は、管理装置100の他の部と一体的に構成されていなくても良い。ステータス保存部111は、具体例として、ファイルシステム又はデータベースである。
 選択ルール保存部121は、ステータス保存部111と同様である。
 図6は、管理システム90のソフトウェア構成例を示している。本例に示す管理装置100は、典型的には、複数の組織が1つの管理システム90を運用する場合に用いられる。管理システム90は、管理装置100と、管理装置100と同じ機能を有する他の管理装置100とを備える。
 なお、図3と図6との差異は、同期処理部160の存在の有無である。
 図7は、管理システム90を複数の組織において利用する場合における、管理システム90の構成例を示している。本例において、組織Aと、組織Bと、組織Cとの3つの組織が管理システム90を利用する。
 各組織は、ネットワークを経由して相互に接続されている。具体的には、組織Aの管理装置100は、ネットワークを介して、組織Bの管理装置100と、組織Cの管理装置100と接続されている。
 各組織は、管理装置100を1つ備える。各組織は、ユーザ端末200と、サービス提供装置300とをそれぞれ1つ以上備える。組織は、部署等、1つの組織を分割した単位であっても良い。1つの組織が複数の組織とみなされても良い。
 複数の組織が1つの管理システム90を利用する場合、複数の組織は、複数の分散型台帳を同時に運用する。分散型台帳は、複数の組織間でデータを共有することに用いられる。この場合、複数の組織は、典型的には、それぞれの互いに異なる管理装置100を運用する。
 同期処理部160は、他の管理装置100と設定情報を共有する。同期処理部160は、他の管理装置100と設定情報を同期する。
 具体例として、組織Aと、組織Bと、組織Cとの3つの組織が管理システム90を利用している場合において、組織Aが有する管理装置100の設定情報が変更されたものとする。
 本例において、まず、組織Aの同期処理部160は、ネットワークを介して、組織Bと、組織Cとの各々の同期処理部160へと設定情報を送信する。次に、組織Bと、組織Cとの各々の同期処理部160は、各々の組織の台帳管理部110又は選択部120へと設定情報を送信する。
 上述の処理により、ユーザは、組織Aの管理装置100を設定するだけで、組織Bと、組織Cとの各々の管理装置100を設定することができる。
***動作の説明***
 管理装置100の動作手順は、管理方法に相当する。また、管理装置100の動作を実現するプログラムは、管理プログラムに相当する。
 ユーザ端末200の動作手順は、ユーザ端末方法に相当する。また、ユーザ端末200の動作を実現するプログラムは、ユーザ端末プログラムに相当する。
 サービス提供装置300の動作手順は、サービス提供方法に相当する。サービス提供装置300の動作を実現するプログラムは、サービス提供プログラムに相当する。
 以下の例において、特に断りがない限り、運用する各分散型台帳は、ステータスT1と、ステータスT2と、ステータスT3と、ステータスT4との4つの台帳ステータスをとるものとする。ステータスの種類数と、ステータスの内容とは、これらに限られない。
 ステータスT1は、登録と、更新と、参照とを許可することを示す。ステータスT1において、ユーザは、分散型台帳にデータを登録することと、分散型台帳に登録されたデータを更新すること又は参照することとができる。
 ステータスT2は、更新と、参照とを許可することを示す。ステータスT2において、ユーザは、分散型台帳にデータを登録することができない。ステータスT2において、ユーザは、分散型台帳に登録されたデータを更新すること又は参照することができる。
 ステータスT3は、参照を許可することを示す。ステータスT3において、ユーザは、分散型台帳に登録されているデータを参照することのみ可能である。
 ステータスT4は、分散型台帳の運用を終了することを示す。ステータスT4において、一般ユーザは、分散型台帳にデータを登録することと、分散型台帳に登録されているデータを更新すること又は参照することとができない。ステータスT4において、管理ユーザは、分散型台帳を削除することのみ実行することができる。
 図8は、ステータス設定処理の一例を示すフローチャートである。本図を参照して、ステータス設定処理を説明する。ステータス設定処理は、情報をステータス保存部111に記録する処理である。
(ステップS51:情報入力処理)
 まず、管理ユーザは、ブラウザ部221を操作することによって、ステータス設定情報を入力する。ステータス設定情報は、台帳ネットワーク情報D11と、台帳ステータス情報D12と、ステータスルール情報D13と、自動更新ルール情報D14との少なくとも1つに対応する。
 次に、管理ユーザ端末220は、ステータス設定情報をサーバアプリケーション部321に送る。
 次に、管理サービス提供装置320は、ステータス設定情報を設定部150に送る。
(ステップS52:組織数判定処理)
 設定部150は、管理システム90が複数の組織において運用されているか否かを判定する。
 管理システム90が複数の組織において運用されている場合、管理装置100は、ステップS54に進む。それ以外の場合、管理装置100は、ステップS53に進む。
(ステップS53:情報記録処理)
 まず、設定部150は、ステータス設定情報を台帳管理部110に送る。
 次に、ステータス記録部114は、当該ステータス設定情報をステータス保存部111に記録する。
(ステップS54:同期処理)
 同期処理部160は、管理システム90内の他の管理装置100とステータス設定情報を共有する。他の管理装置100は、管理システム90内の管理装置100であって、ステップS51においてステータス設定情報を受信した管理装置100以外の管理装置100である。
 本ステップにおいて、具体例として、まず、設定部150は、ステータス設定情報を同期処理部160に送信する。
 次に、同期処理部160は、全ての他の管理装置100が備える同期処理部160にステータス設定情報を送信する。
 次に、他の管理装置100が備える同期処理部160は、それぞれ、対応する設定部150に受信したステータス設定情報を送信する。
 次に、他の管理装置100は、それぞれステップS53と同様の処理を実行する。
 次に、他の管理装置100が備える設定部150は、それぞれ、ステータス設定情報を送信した管理装置100に、実行結果を示す情報を送信する。
(ステップS55:結果通知処理)
 管理システム90は、管理ユーザにステータス設定処理の実行結果を通知する。
 本ステップにおいて、具体例として、まず、設定部150は、結果情報をサーバアプリケーション部321に送る。
 次に、管理サービス提供装置320は、結果情報をブラウザ部221に送る。
 次に、ブラウザ部221は、結果情報に対応する画像を表示する。
 図9は、選択ルール設定処理の一例を示すフローチャートである。本図を参照して、選択ルール設定処理を説明する。選択ルール設定処理は、情報を選択ルール保存部121に記録する処理である。
(ステップS56:情報入力処理)
 本処理は、ステップS51におけるステータス設定情報を、選択ルール設定情報に読み替えた処理である。選択ルール設定情報は、選択ルール情報D21に対応する。
(ステップS57:組織数判定処理)
 設定部150は、ステップS52と同様の処理を実行する。
 管理システム90が複数の組織において運用されている場合、管理装置100は、ステップS59に進む。それ以外の場合、管理装置100は、ステップS58に進む。
(ステップS58:情報記録処理)
 まず、設定部150は、選択ルール設定情報を選択部120に送る。
 次に、選択ルール記録部123は、当該選択ルール設定情報を選択ルール保存部121に記録する。
(ステップS59:同期処理)
 設定部150は、同期処理部160を利用することによって、組織内の他の管理装置100と選択ルール設定情報を共有する。
 管理装置100は、ステップS54における、ステータス設定情報を選択ルール設定情報に、ステップS51をステップS56に、ステップS53をステップS58に読み替えた処理を実行する。
(ステップS5a:結果通知処理)
 管理システム90は、管理ユーザに選択ルール設定処理の実行結果を通知する。
 本処理は、ステップS55の処理と同様である。
 図10は、ステータス自動更新処理の一例を示すフローチャートである。本図を参照して、ステータス自動更新処理を説明する。ステータス自動更新処理は、ステータス自動更新部115が、台帳ステータスを自動的に更新する処理である。
(ステップS61:起動処理)
 ステータス自動更新部115は、自動更新ルール情報D14に示される更新タイミングに従って起動する。
(ステップS62:自動更新処理)
 ステータス自動更新部115は、更新分散型台帳それぞれの台帳ステータスを更新する。更新分散型台帳は、ステータス自動更新部115から台帳ステータスを更新するよう指示される分散型台帳である。更新分散型台帳は、複数あっても良い。ステータス自動更新部115は、運用中の全ての分散型台帳を更新分散型台帳としても良く、また、自動更新ルール情報D14に示される分散型台帳を更新分散型台帳としても良い。
 本ステップにおいて、具体例として、まず、読出部113は、台帳ネットワーク情報D11と、ステータスルール情報D13とを、ステータス保存部111から読み出す。当該台帳ネットワーク情報D11は、更新分散型台帳に対応する。当該ステータスルール情報D13は、自動更新ルール情報D14に示されるものであっても良い。
 次に、読出部113は、台帳ネットワーク情報D11と、ステータスルール情報D13とをステータス自動更新部115に送る。
 次に、ステータス自動更新部115は、ステータスルール情報D13に基づいてステータス更新要求情報を生成する。ステータス更新要求情報は、分散型台帳に対する要求であって、ステータスを更新する要求を示す。
 次に、ステータス自動更新部115は、台帳ネットワーク情報D11を用いて、更新要求情報を更新分散型台帳に送信する。
 次に、更新分散型台帳は、ステータス更新要求情報に従って台帳ステータスを更新する。
 次に、更新分散型台帳は、結果情報をステータス自動更新部115に送る。
(ステップS63:記録処理)
 次に、ステータス自動更新部115は、結果情報に基づき、ステータス保存部111が記録している台帳ステータス情報D12を更新する。
 なお、ステータス保存部111が記録している自動更新ルール情報D14を管理ユーザが更新した場合、ステータス自動更新部115は、新しい自動更新ルール情報D14を確認する。ステータス自動更新部115は、具体例として、更新タイミングを確認する。
 以下の例において、特に断りがない限り、分散型台帳に登録されているデータ又は分散型台帳に登録されるデータは、データID(Identification)と、データオブジェクトとから構成されるものとする。データIDは、各データを識別する識別子である。データオブジェクトは、データの内容であり、かつ、データID以外の情報である。
 図11は、新規データ登録処理の一例を示すフローチャートである。本図を参照して、新規データ登録処理を説明する。データ登録処理は、分散型台帳にデータを新規に登録する処理である。
(ステップS71:データ入力処理)
 台帳管理部110は、一般ユーザから登録要求情報を受け付ける。登録要求情報は、一般ユーザからの登録要求を示し、かつ、新規データを含む。
 本ステップにおいて、具体例として、まず、一般ユーザは、ブラウザ部211に新規データを入力する。
 次に、一般ユーザ端末210は、登録要求情報をサーバアプリケーション部311へ送る。
 次に、一般サービス提供装置310は、登録要求情報を台帳管理部110に送る。
(ステップS72:ネットワーク情報取得処理)
 読出部113は、ステータス保存部111から、運用中の全ての分散型台帳それぞれに対応する台帳ネットワーク情報D11を取得する。
 具体的には、読出部113は、台帳ステータスがステータスT1、ステータスT2、又は、ステータスT3である全ての分散型台帳それぞれに対応する台帳ネットワーク情報D11を取得する。
 本ステップにおいて取得した台帳ネットワーク情報D11を、取得ネットワーク情報とする。
(ステップS73:重複確認処理)
 台帳確認部116は、重複分散型台帳が存在するか否かを確認する。重複分散型台帳は、新規データに含まれるデータIDと同じデータIDを含むデータを記録している分散型台帳である。
 具体例として、台帳確認部116は、新規データと、取得ネットワーク情報とを用いて、重複分散型台帳を探索する。
 重複分散型台帳が存在しない場合、管理装置100は、ステップS74に進む。それ以外の場合、管理装置100は、ステップS79に進む。
 なお、本ステップの目的は、同一のデータIDを有する複数のデータを分散型台帳ネットワーク410が分散して管理することを防止することである。本ステップの処理を実行することにより、管理装置100は、同一のデータIDを有するデータを、1つ又は複数の分散型台帳に分散して記録することを防ぐことができる。
(ステップS74:探索処理)
 台帳管理部110は、登録を許可することを示す台帳ステータスに対応する分散型台帳を探索する。本開示に係る台帳管理部110が分散型台帳を探索する場合、台帳管理部110は、複数の分散型台帳を探索しても良い。
 具体的には、読出部113は、ステータス保存部111を参照することによって、台帳ステータスがステータスT1である分散型台帳を探索する。
 台帳管理部110が当該分散型台帳を1つ以上発見した場合、管理装置100は、ステップS76に進む。それ以外の場合、管理装置100は、ステップS79に進む。
 本ステップにおいて発見された分散型台帳を、分散型台帳候補とする。
(ステップS76:情報送信処理)
 読出部113は、分散型台帳候補に対応する台帳ネットワーク情報D11をステータス保存部111から取得し、かつ、取得した台帳ネットワーク情報D11を選択部120へ送る。
 複数の分散型台帳候補が存在する場合、かつ、本開示に係る読出部113が台帳ネットワーク情報D11を取得する場合、読出部113は、当該複数の分散型台帳それぞれに対応する台帳ネットワーク情報D11を取得しても良い。
(ステップS77:個数確認処理)
 雑務部126は、分散型台帳候補の個数を確認する。
 複数の分散型台帳候補が存在する場合、管理装置100は、ステップS78に進む。それ以外の場合、管理装置100は、分散型台帳候補を選択分散型台帳とし、かつ、ステップS7aに進む。
(ステップS78:選択処理)
 選択部120は、複数の分散型台帳候補の中から1つの分散型台帳を選択する。
 本ステップにおいて、具体例として、まず、読出部122は、選択ルール保存部121を参照することによって、優先ルールを抽出する。優先ルールは、優先度が最も高い選択ルールである。優先度が最も高い選択ルールが複数ある場合、読出部122は、どのように優先ルールを選択しても良い。
 次に、選択ルール処理部124は、優先ルールに従って、複数の分散型台帳候補の中から分散型台帳を1つ選択する。選択ルール処理部124は、選択した分散型台帳候補を選択分散型台帳とする。
(ステップS79:エラー処理)
 雑務部126は、エラー処理を実行する。雑務部126は、エラーが発生した原因に従って、適宜処理を選択しても良い。
 雑務部126は、エラーが発生したことを示す結果情報を制御部140に送る。
(ステップS7a:個数確認処理)
 雑務部126は、選択分散型台帳の個数を確認する。
 選択分散型台帳の個数が1つである場合、管理装置100は、ステップS7bに進む。それ以外の場合、管理装置100は、ステップS79に進む。
(ステップS7b:登録処理)
 制御部140は、選択分散型台帳に新規データを新規に登録させる。
 本ステップにおいて、具体例として、まず、選択部120は、新規データと、選択分散型台帳を示す情報とを制御部140に送る。
 次に、制御部140は、選択分散型台帳に対して、新規データを新規に登録するよう命令する。
 次に、選択分散型台帳は、新規データを新規に登録した後に、結果情報を制御部140に送る。
(ステップS7c:結果通知処理)
 管理装置100は、一般ユーザに実行結果を通知する。
 本ステップにおいて、具体例として、まず、制御部140は、結果情報をサーバアプリケーション部311に送信する。
 次に、一般サービス提供装置310は、結果情報をブラウザ部211に送信する。
 次に、ブラウザ部211は、結果情報に対応する画像を表示する。
 図12は、更新データ登録処理のフローチャートを示している。本図を参照して、更新データ登録処理を説明する。更新データは、分散型台帳に登録されているデータを更新することに用いられる。管理システム90が更新データ登録処理を実行することに成功した場合、管理システム90が本処理を実行する前に分散型台帳に登録されているデータは、更新データに対応するデータに変更される。
 管理装置100が分散型台帳に登録されているデータを更新する場合、管理装置100は、更新対象データを更新する。更新対象データは、分散型台帳に登録されており、かつ、更新データに含まれるデータIDと同じデータIDを持つ。
(ステップS81:データ入力処理)
 本処理は、ステップS71における、登録要求情報を更新要求情報に、新規データを更新データに読み替えた処理である。更新要求情報は、一般ユーザからの更新要求を示し、かつ、更新データを含む。
(ステップS82:探索処理)
 台帳管理部110は、更新を許可することを示す台帳ステータスに対応する分散型台帳を探索する。
 具体的には、読出部113は、ステータス保存部111を参照することによって、台帳ステータスがステータスT1又はステータスT2である分散型台帳を探索する。
 台帳管理部110が当該分散型台帳を1つ以上発見した場合、管理装置100は、ステップS83に進む。それ以外の場合、管理装置100は、ステップS8bに進む。
(ステップS83:ネットワーク情報取得処理)
 読出部113は、ステップS82において発見された分散型台帳に対応する台帳ネットワーク情報D11をステータス保存部111から取得し、かつ、取得した台帳ネットワーク情報D11を選択部120に送る。ステップS82において複数の分散型台帳が発見された場合、台帳管理部110は、当該複数の分散型台帳それぞれに対応する台帳ネットワーク情報D11を取得する。
 本ステップにおいて取得した台帳ネットワーク情報D11を、取得ネットワーク情報とする。
(ステップS84:選択処理)
 台帳選択部125は、更新分散型台帳を選択する。更新分散型台帳は、台帳選択部125によって更新対象データが記録されているか否かを確認される。選択部120は、ステップS82において発見された分散型台帳を更新分散型台帳としても良い。選択部120は、複数の更新分散型台帳を選択しても良い。本開示に係る選択部120が分散型台帳を選択する場合において、選択部120は、複数の分散型台帳を選択しても良い。
(ステップS85:個数確認処理)
 雑務部126は、更新分散型台帳の個数を確認する。
 更新分散型台帳が複数存在する場合、管理装置100は、ステップS87に進む。それ以外の場合、台帳選択部125は更新分散型台帳を選択分散型台帳とし、かつ、管理装置100はステップS86に進む。
(ステップS86:記録確認処理)
 選択部120は、選択分散型台帳に更新対象データが記録されているか否かを確認する。選択部120は、具体例として、取得ネットワーク情報と、更新データに含まれるデータIDとを用いて、選択分散型台帳を確認する。
 選択分散型台帳に更新対象データが記録されている場合、管理装置100は、ステップS8cに進む。それ以外の場合、管理装置100は、ステップS8bに進む。
 選択部120の代わりに、制御部140が選択分散型台帳に記録されているデータを確認しても良い。
(ステップS87:選択処理)
 台帳選択部125は、本ステップにおいてまだ選択されていない更新分散型台帳を1つ選択とし、かつ、選択した更新分散型台帳を選択分散型台帳とする。
 台帳選択部125が選択する更新分散型台帳は、ステップS89においてマーキングされていない。
(ステップS88:記録確認処理)
 台帳選択部125は、ステップS86と同様の処理を実行する。
 選択分散型台帳が更新対象データを記録している場合、管理装置100は、ステップS8cに進む。それ以外の場合、管理装置100は、ステップS89に進む。
(ステップS89:マーキング処理)
 台帳選択部125は、選択分散型台帳に対して、既に選択されたことを示す印を付与する。
(ステップS8a:台帳確認処理)
 台帳選択部125は、ステップS87においてまだ選択されていない更新分散型台帳が存在するか否かを確認する。
 ステップS87においてまだ選択されていない更新分散型台帳が存在する場合、管理装置100は、ステップS87に進む。それ以外の場合、管理装置100は、ステップS8bに進む。
(ステップS8b:エラー処理)
 雑務部126は、エラー処理を実行する。雑務部126は、エラーを示す結果情報を制御部140に送信する。
(ステップS8c:更新処理)
 制御部140は、選択分散型台帳に更新データを記録する。
 本ステップにおいて、具体例として、まず、台帳選択部125は、更新データと、選択分散型台帳を示す情報とを制御部140に送る。
 次に、制御部140は、選択分散型台帳に対して、更新対象データを更新データに更新するよう命令する。
 次に、選択分散型台帳は、更新対象データを更新データに更新し、かつ、結果情報を制御部140に送信する。
(ステップS8d:結果通知処理)
 本処理は、ステップS7cの処理と同様である。
 図13は、データ参照処理の一例を示すフローチャートである。本図を参照して、データ参照処理を説明する。データ参照処理は、ユーザが分散型台帳に登録されている参照対象データを参照する処理である。参照対象データは、参照データに対応する。参照データは、データIDだけであっても良く、また、データオブジェクトだけであっても良い。参照データは、データの属性又は種類を示す情報であっても良い。参照対象データは、参照データと同様である。
(ステップS91:データ入力処理)
 本処理は、ステップS71における、登録要求情報を参照要求情報に、新規データを参照データに読み替えた処理である。参照要求情報は、一般ユーザからの参照要求を示し、かつ、参照データを含む。
(ステップS92:探索処理)
 台帳管理部110は、参照を許可することを示す台帳ステータスに対応する分散型台帳を探索する。
 具体的には、読出部113は、ステータス保存部111を参照することによって、台帳ステータスが、ステータスT1、ステータスT2、又は、ステータスT3である分散型台帳を探索する。
 台帳管理部110が当該分散型台帳を1つ以上発見した場合、管理装置100は、ステップS93に進む。それ以外の場合、管理装置100は、ステップS9bに進む。
(ステップS93:ネットワーク情報取得処理)
 本処理は、ステップS83の処理において、ステップS82をステップS92に読み替えた処理である。
(ステップS94:選択処理)
 台帳選択部125は、参照分散型台帳を選択する。参照分散型台帳は、台帳選択部125によって、参照データが記録されているか否かを確認される。選択部120は、ステップS92において発見された分散型台帳を参照分散型台帳としても良い。
(ステップS95:個数確認処理)
 雑務部126は、参照分散型台帳の個数を確認する。
 参照分散型台帳が複数存在する場合、管理装置100は、ステップS97に進む。それ以外の場合、台帳選択部125は参照分散型台帳を選択分散型台帳とし、かつ、管理装置100はステップS96に進む。
(ステップS96:記録確認処理)
 選択部120は、選択分散型台帳に参照対象データが記録されているか否かを確認する。選択部120は、ステップS86と同様の処理を実行する。
 選択分散型台帳に参照データが記録されている場合、管理装置100は、ステップS9cに進む。それ以外の場合、管理装置100は、ステップS9bに進む。
(ステップS97:選択処理)
 台帳選択部125は、本ステップにおいてまだ選択されていない参照分散型台帳を1つ選択とし、かつ、選択した参照分散型台帳を選択分散型台帳とする。本処理は、ステップS87の処理と同様である。
(ステップS98:記録確認処理)
 台帳選択部125は、ステップS96と同様の処理を実行する。
 選択分散型台帳が参照対象データを記録している場合、管理装置100は、ステップS9cに進む。それ以外の場合、管理装置100は、ステップS99に進む。
(ステップS99:マーキング処理)
 本処理は、ステップS89の処理と同様である。
(ステップS9a:台帳確認処理)
 本処理は、ステップS8aの処理と同様である。
 ステップS97においてまだ選択されていない参照分散型台帳が存在する場合、管理装置100は、ステップS97に進む。それ以外の場合、管理装置100は、ステップS9bに進む。
(ステップS9b:エラー処理)
 本処理は、ステップS8bの処理と同様である。
(ステップS9c:参照処理)
 制御部140は、選択分散型台帳が記録している参照対象データを参照する。
 本ステップにおいて、具体例として、まず、台帳選択部125は、参照データと、選択分散型台帳を示す情報とを制御部140に送る。
 次に、制御部140は、選択分散型台帳に対して、参照対象データの情報を返すよう命令する。
 次に、選択分散型台帳は、参照対象データと、結果情報とを制御部140へ送信する。
(ステップS9d:結果通知処理)
 本処理は、ステップS7cの処理と同様である。
 図14は、管理装置100による台帳削除処理の一例を示すフローチャートである。本図を参照して、台帳削除処理を説明する。台帳削除処理は、分散型台帳を削除する処理である。
(ステップS501:台帳選択処理)
 管理ユーザは、削除分散型台帳を選択する。削除分散型台帳は、管理ユーザが削除することを希望する分散型台帳である。
 本ステップにおいて、具体例として、管理ユーザは、管理ユーザ端末220のブラウザ部221を利用することによって、削除分散型台帳を選択する。
 次に、管理ユーザ端末220は、削除要求情報をサーバアプリケーション部321へ送る。削除要求情報は、管理ユーザからの削除分散型台帳を削除する要求を示し、かつ、削除分散型台帳の情報を含む。
 次に、管理サービス提供装置320は、削除要求情報を制御部140へ送る。
(ステップS502:ステータス確認処理)
 制御部140は、削除分散型台帳に対応する台帳ステータスが運用終了を示すか否かを確認する。
 本ステップにおいて、具体例として、まず、制御部140は、削除分散型台帳に対応する台帳ステータスを台帳管理部110に問い合わせる。
 次に、台帳管理部110は、ステータス保存部111を参照することによって削除分散型台帳に対応する台帳ステータス情報D12を取得し、かつ、取得した台帳ステータス情報D12を制御部140に送る。
 次に、制御部140は、削除分散型台帳の台帳ステータスがステータスT4であるか否かを確認する。
 削除分散型台帳の台帳ステータスがステータスT4である場合、管理装置100は、ステップS503に進む。それ以外の場合、管理装置100は、ステップS504に進む。
(ステップS503:削除処理)
 制御部140は、削除分散型台帳を削除する。
 本ステップにおいて、具体例として、まず、制御部140は、削除分散型台帳に対応する台帳ネットワーク情報D11を台帳管理部110に問い合わせる。
 次に、制御部140は、台帳管理部110は、ステータス保存部111を参照することによって削除分散型台帳に対応する台帳ネットワーク情報D11を取得し、かつ、取得した台帳ネットワーク情報D11を制御部140に送る。
 次に、制御部140は、台帳ネットワーク情報D11を用いて、削除分散型台帳に削除要求情報を送信する。
 次に、制御部140は、正常に終了したことを示す結果情報をサーバアプリケーション部321に送る。
(ステップS504:エラー通知処理)
 制御部140は、エラーが発生したことを示す結果情報をサーバアプリケーション部321へ送る。
(ステップS505:結果通知処理)
 管理システム90は、台帳削除処理の実行結果を管理ユーザに通知する。
 管理サービス提供装置320は、管理装置100から受信した結果情報をブラウザ部221に送信する。
 ブラウザ部221は、管理サービス提供装置320から受信した結果情報に対応する画像を表示する。
***実施の形態1の効果の説明***
 以上のように、本実施の形態によれば、管理装置100は、1つ以上の分散型台帳それぞれに台帳ステータスを付与する。台帳ステータスは、分散型台帳の状態に対応する。管理装置100は、台帳ステータスに従ってユーザが実行することができる処理を制限する。
 また、管理装置100は、台帳ステータスに従って分散型台帳を適宜削除する。そのため、本実施の形態によれば、管理装置100は、長期運用することに伴い分散型台帳のストレージ使用量が肥大化することを防ぐことができる。
 なお、管理装置100は、分散型台帳のライフサイクルを考慮して分散型台帳を運用することもできる。台帳ステータスは、分散型台帳のライフサイクルを示しても良い。管理装置100は、登録されている全てのデータのライフサイクルが終了している分散型台帳を適宜削除しても良い。
 本実施の形態によれば、管理装置100が制御する分散型台帳の候補が複数存在する場合、選択部120は選択ルールに従って分散型台帳を一意に選択することができる。また、管理ユーザは、選択ルールを設定することができる。
 従って、本実施の形態によれば、ユーザは、台帳ネットワーク410に分散型台帳が複数存在することを気にせずに、台帳ネットワーク410に含まれる分散型台帳にデータを記録すること、又は、台帳ネットワーク410に含まれる分散型台帳が記録しているデータを参照すること等ができる。
***他の構成***
<変形例1>
 選択部120は、複数の分散型台帳から1つの分散型台帳を選択しなくても良い。本変形例において、具体例として、選択部120は、ユーザに対して分散型台帳を選択する機会を提供する。本例において、選択部120は、ユーザが選択した分散型台帳を選択分散型台帳としても良い。
<変形例2>
 ステータス保存部111は、分散型台帳が記録しているデータに対応するデータIDを保持していても良い。
 本変形例において、具体例として、台帳確認部116は、ステップS73において、分散型台帳を確認せず、かつ、ステータス保存部111を参照することによって重複分散型台帳が存在するか否かを判断する。
<変形例3>
 図15は、本変形例に係る管理装置100のハードウェア構成例を示している。
 管理装置100は、本図に示すように、プロセッサ11とメモリ12と補助記憶装置13との少なくとも1つに代えて、処理回路18を備える。
 処理回路18は、管理装置100が備える各部の少なくとも一部を実現するハードウェアである。
 処理回路18は、専用のハードウェアであっても良く、また、メモリ12に格納されるプログラムを実行するプロセッサ11であっても良い。
 処理回路18が専用のハードウェアである場合、処理回路18は、具体例として、単一回路、複合回路、プログラム化したプロセッサ、並列プログラム化したプロセッサ、ASIC(ASICはApplication Specific Integrated Circuit)、FPGA(Field Programmable Gate Array)又はこれらの組み合わせである。
 管理装置100は、処理回路18を代替する複数の処理回路を備えても良い。複数の処理回路は、処理回路18の役割を分担する。
 管理装置100において、一部の機能が専用のハードウェアで実現されて、残りの機能がソフトウェア又はファームウェアで実現されても良い。
 処理回路18は、具体例として、ハードウェア、ソフトウェア、ファームウェア、又はこれらの組み合わせにより実現される。
 プロセッサ11とメモリ12と補助記憶装置13と処理回路18とを、総称して「プロセッシングサーキットリー」という。つまり、管理装置100の各機能構成要素の機能は、プロセッシングサーキットリーにより実現される。
 ユーザ端末200と、サービス提供装置300と、ノード411とについても、図示しないが、管理装置100と同様にそれぞれ処理回路18を備えても良い。
***他の実施の形態***
 実施の形態1について説明したが、本実施の形態のうち、複数の部分を組み合わせて実施しても構わない。あるいは、本実施の形態のうち、1つの部分を実施しても構わない。その他、本実施の形態は、必要に応じて種々の変更がなされても構わず、全体としてあるいは部分的に、どのように組み合わせて実施されても構わない。
 なお、上述した実施の形態は、本質的に好ましい例示であって、本開示と、その適用物と、用途の範囲とを制限することを意図するものではない。フローチャート等を用いて説明した手順は、適宜変更されても良い。
 11 プロセッサ、12 メモリ、13 補助記憶装置、14 入力インタフェース、15 出力インタフェース、16 通信装置、18 処理回路、19 信号線、90 管理システム、100 管理装置、110 台帳管理部、111 ステータス保存部、113 読出部、114 ステータス記録部、115 ステータス自動更新部、116 台帳確認部、120 選択部、121 選択ルール保存部、122 読出部、123 選択ルール記録部、124 選択ルール処理部、125 台帳選択部、126 雑務部、140 制御部、150 設定部、160 同期処理部、200 ユーザ端末、210 一般ユーザ端末、211 ブラウザ部、220 管理ユーザ端末、221 ブラウザ部、300 サービス提供装置、310 一般サービス提供装置、311 サーバアプリケーション部、320 管理サービス提供装置、321 サーバアプリケーション部、400 台帳ネットワーク群、410 台帳ネットワーク、411 ノード、D11 ネットワーク情報、D12 台帳ステータス情報、D13 ステータスルール情報、D14 自動更新ルール情報、D21 選択ルール情報、T1 ステータス、T2 ステータス、T3 ステータス、T4 ステータス。

Claims (8)

  1.  分散された電子データを記録する複数の分散型台帳を管理する台帳管理部と、
     前記複数の分散型台帳のいずれかを制御する制御部と、
     前記制御部が制御する分散型台帳の候補である複数の分散型台帳候補であって、前記複数の分散型台帳に含まれる2つ以上の分散型台帳から成る複数の分散型台帳候補が存在する場合に前記複数の分散型台帳候補から分散型台帳を一意に選択する規則を示す選択ルールを含む選択ルール情報を記録しており、かつ、前記複数の分散型台帳候補が存在する場合に前記選択ルールに従って前記複数の分散型台帳候補から分散型台帳を一意に選択する選択部を備える管理装置。
  2.  前記選択ルールは、前記複数の分散型台帳候補から1つの分散型台帳を選択する規則を示す請求項1に記載の管理装置。
  3.  前記選択ルール情報は、複数の選択ルールと、前記複数の選択ルールそれぞれに対応する優先度とを含み、
     前記選択部は、前記複数の選択ルールそれぞれに対応する優先度を考慮して前記複数の選択ルールから優先ルールを選択する請求項1又は2に記載の管理装置。
  4.  前記複数の分散型台帳それぞれには、ユーザが実行することができる制御に対する制限を示す制御制限がかけられており、
     前記台帳管理部は、前記複数の分散型台帳それぞれに対応する制御制限を示す台帳ステータスを示す台帳ステータス情報を記録しており、
     前記制御部は、前記複数の分散型台帳のいずれかを制御する際に、前記複数の分散型台帳のいずれかに対応する台帳ステータスに従う請求項1から3のいずれか1項に記載の管理装置。
  5.  前記選択部は、前記選択ルール情報を含む設定情報を記録している請求項1から4のいずれか1項に記載の管理装置。
  6.  前記管理装置と同じ機能を有する他の管理装置を備える管理システムが前記管理装置を備え、
     前記他の管理装置と前記設定情報を同期する同期処理部を備える請求項5に記載の管理装置。
  7.  台帳管理部が、分散された電子データを記録する複数の分散型台帳を管理し、
     制御部が、前記複数の分散型台帳のいずれかを制御し、
     選択部が、前記制御部が制御する分散型台帳の候補である複数の分散型台帳候補であって、前記複数の分散型台帳に含まれる2つ以上の分散型台帳から成る複数の分散型台帳候補が存在する場合に前記複数の分散型台帳候補から分散型台帳を一意に選択する規則を示す選択ルールを含む選択ルール情報を記録しており、かつ、前記複数の分散型台帳候補が存在する場合に前記選択ルールに従って前記複数の分散型台帳候補から分散型台帳を一意に選択する管理方法。
  8.  コンピュータに、
     分散された電子データを記録する複数の分散型台帳を管理させ、
     前記複数の分散型台帳のいずれかを制御させ、
     制御する分散型台帳の候補である複数の分散型台帳候補であって、前記複数の分散型台帳に含まれる2つ以上の分散型台帳から成る複数の分散型台帳候補が存在する場合に前記複数の分散型台帳候補から分散型台帳を一意に選択する規則を示す選択ルールを含む選択ルール情報を記録させ、
     前記複数の分散型台帳候補が存在する場合に前記選択ルールに従って前記複数の分散型台帳候補から分散型台帳を一意に選択させる管理プログラム。
PCT/JP2020/009178 2020-03-04 2020-03-04 管理装置、管理方法、及び、管理プログラム WO2021176599A1 (ja)

Priority Applications (4)

Application Number Priority Date Filing Date Title
JP2021572022A JPWO2021176599A1 (ja) 2020-03-04 2020-03-04
PCT/JP2020/009178 WO2021176599A1 (ja) 2020-03-04 2020-03-04 管理装置、管理方法、及び、管理プログラム
CN202080097186.0A CN115151899A (zh) 2020-03-04 2020-03-04 管理装置、管理方法和管理程序
US17/857,415 US20220335038A1 (en) 2020-03-04 2022-07-05 Management device, management method, and non-transitory computer-readable recording medium

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
PCT/JP2020/009178 WO2021176599A1 (ja) 2020-03-04 2020-03-04 管理装置、管理方法、及び、管理プログラム

Related Child Applications (1)

Application Number Title Priority Date Filing Date
US17/857,415 Continuation US20220335038A1 (en) 2020-03-04 2022-07-05 Management device, management method, and non-transitory computer-readable recording medium

Publications (1)

Publication Number Publication Date
WO2021176599A1 true WO2021176599A1 (ja) 2021-09-10

Family

ID=77613223

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/JP2020/009178 WO2021176599A1 (ja) 2020-03-04 2020-03-04 管理装置、管理方法、及び、管理プログラム

Country Status (4)

Country Link
US (1) US20220335038A1 (ja)
JP (1) JPWO2021176599A1 (ja)
CN (1) CN115151899A (ja)
WO (1) WO2021176599A1 (ja)

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2019532419A (ja) * 2016-09-21 2019-11-07 アール−ストール インコーポレイテッド データ処理用の分散型台帳を使用するためのシステム及び方法
JP2019200556A (ja) * 2018-05-16 2019-11-21 株式会社日立製作所 利用管理方法、利用管理システム、および、ノード
JP2019200580A (ja) * 2018-05-16 2019-11-21 株式会社日立製作所 分散台帳システム、分散台帳サブシステム、および、分散台帳ノード

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN107368259B (zh) * 2017-05-25 2020-07-10 创新先进技术有限公司 一种向区块链系统中写入业务数据的方法和装置
US10833844B2 (en) * 2017-12-20 2020-11-10 International Business Machines Corporation Blockchain lifecycle management
US11038676B2 (en) * 2018-05-25 2021-06-15 Incertrust Technologies Corporation Cryptographic systems and methods using distributed ledgers

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2019532419A (ja) * 2016-09-21 2019-11-07 アール−ストール インコーポレイテッド データ処理用の分散型台帳を使用するためのシステム及び方法
JP2019200556A (ja) * 2018-05-16 2019-11-21 株式会社日立製作所 利用管理方法、利用管理システム、および、ノード
JP2019200580A (ja) * 2018-05-16 2019-11-21 株式会社日立製作所 分散台帳システム、分散台帳サブシステム、および、分散台帳ノード

Also Published As

Publication number Publication date
US20220335038A1 (en) 2022-10-20
CN115151899A (zh) 2022-10-04
JPWO2021176599A1 (ja) 2021-09-10

Similar Documents

Publication Publication Date Title
US10262008B2 (en) Filename-based inference of repository actions
US10931748B2 (en) Optimistic concurrency utilizing distributed constraint enforcement
US20110029854A1 (en) Web content management
US20120173511A1 (en) File search system and program
JP2008003846A (ja) 文書利用管理システム及び方法、文書管理サーバ及びそのプログラム
US20060218198A1 (en) Method and computer-readable medium for formula-based document retention
US11715068B2 (en) Data processing apparatus, data processing system, data processing method, and non-transitory computer readable medium
US11080344B2 (en) Cloud-native documents integrated with legacy tools
CN107710189B (zh) 文档间的内容多模式共享
JP6808109B1 (ja) 管理装置、管理方法、及び、管理プログラム
US20230004577A1 (en) Management device, management method, and non-transitory computer-readable recording medium
US10261941B2 (en) Digital aging system and method for operating same
WO2021176599A1 (ja) 管理装置、管理方法、及び、管理プログラム
JP6807239B2 (ja) タイムスタンプ管理システム、タイムスタンプ管理方法、およびタイムスタンプ管理プログラム
JP6015546B2 (ja) 情報処理装置、情報処理方法、プログラム
US20130326324A1 (en) Document management server, document management method, and storage medium
JP2009110241A (ja) 電子ファイル管理装置
JP6398368B2 (ja) 情報処理装置、情報処理システム及びプログラム
KR101865906B1 (ko) 업데이트된 게시정보 제공방법 및 프로그램
JP4261551B2 (ja) アーカイブシステム
US20240211351A1 (en) Resume backup of external storage device using multi-root system
KR20230137512A (ko) 문서편집컴퓨터 및 문서편집방법
CN114610740A (zh) 医疗数据平台的数据版本管理方法及装置
JP2022008318A (ja) 配信管理システムおよび配信管理方法
JP2008033961A (ja) 文書管理方法及び文書管理装置

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

Country of ref document: EP

Kind code of ref document: A1

ENP Entry into the national phase

Ref document number: 2021572022

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

Country of ref document: EP

Kind code of ref document: A1