This application is based upon and claims the benefit of priority of the prior Japanese Patent Application No. 2017-228577, filed on Nov. 29, 2017, the entire contents of which are incorporated herein by reference.
The embodiment discussed herein is related to a lock control technique.
A provider that provides a service to users (hereinafter simply referred to as provider as well) constructs, for example, an information processing system using a database that stores data used for the provision of the service to the users (hereinafter referred to as search target data as well).
When search of the search target data is performed in the information processing system explained above, to efficiently perform the search of the search target data, the information processing system performs, for example, search by reference to an index including a data structure configured by a tree structure. Thereafter, the information processing system updates the data structure included in the index to a form reflecting a search result of the search target data.
Related art is disclosed in, for example, Japanese Laid-open Patent Publication Nos. 2010-026689, 9-319642, and 2011-248584.
According to an aspect of the embodiments, a lock control apparatus includes one or more memories, and one or more processors configured to perform setting of, as a target node, each of one or more child nodes other than eldest child nodes among child nodes relating to parent nodes in each of layers of data structure formed by a tree structure, when a first process for first data associated with a first node in the data structure proceeds in a direction from a parent node to a child node, perform determination of whether the first node is the target node, and perform lock of the first node when the first node is the target node.
The object and advantages of the invention will be realized and attained by means of the elements and combinations particularly pointed out in the claims.
It is to be understood that both the foregoing general description and the following detailed description are exemplary and explanatory and are not restrictive of the invention.
In a data structure included in an index, for example, lock has to be performed on an operation target node such that consistency of the data structure is secured even when a plurality of kinds of operation (for example, reference to and update of data) is performed in parallel.
However, the data structure included in the index includes, when a plurality of kinds of operation are performed in parallel, a data structure on which processing performed from a higher-level node toward a lower-level node (hereinafter referred to as first processing as well) is performed and a data structure on which processing performed from a lower-level node toward a higher-level node (hereinafter referred to as second processing as well) is performed. Therefore, in such a data structure, when the first processing and the second processing are simultaneously performed, deadlock is likely to be caused by lock involved in these kinds of processing.
Therefore, when an index including the data structures on which the first processing and the second processing are respectively performed is used, an information processing system is unable to perform a plurality of kinds of operation for the data structure in parallel because of necessity for reducing occurrence of deadlock. Therefore, the information processing system is sometimes unable to efficiently perform the kinds of operation for the data structure.
[Configuration of an Information Processing System]
First, the configuration of an information processing system 10 is explained.
The information processing system 10 illustrated in
When receiving a query to the data DT (a reference query or an update query to the data DT) from the operation terminal 5, the management apparatus 1 transmits the received query to each of the searching apparatuses 2a and 2b.
Specifically, for example, when receiving a query to the data DT from the operation terminal 5, the management apparatus 1 refers to an index 131 stored in a storing unit 130 and determines whether information corresponding to the received query is included in the index 131. When determining that the information corresponding to the received query is not included in the index 131, the management apparatus 1 directly transmits the received query to the searching apparatus 2. When determining that the information corresponding to the received query is included in the index 131, the management apparatus 1 transmits the information (for example, a physical address of search target data) included in the index 131 to the searching apparatus 2.
Consequently, the management apparatus 1 is capable of improving efficiency of execution of processing corresponding to the query and reduce a time required for the execution of the processing corresponding to the query.
The searching apparatus 2 performs, based on the query received from the management apparatus 1, operation for the data DT (reference to and update of the data DT) stored in the database 3.
A specific example of a data structure of the index 131 is explained.
In the data structure configured by the Full Blossom Tree, nodes other than a root node and data (labels) are associated. Specifically, for example, in the data structure illustrated in
In the data structure configured by the Full Blossom Tree, branches among the nodes and the data are associated. Specifically, for example, in the data structure illustrated in
In the data structure configured by the Full Blossom Tree, data associated with branches present between the root node and the nodes are included, in order from the node closest to the root node, in the heads of the data associated with the nodes. Specifically, for example, in the data structure illustrated in
In the data structure configured by the Full Blossom Tree, the data are associated with the nodes to be searched in lexicographic order in depth preferential search. Explanation of the other nodes, data, and branches included in
A specific example of processing for performing insertion of data is explained. In the following explanation, data including “bba” (hereinafter referred to as insertion data as well) is inserted into the data structure explained with reference to
The management apparatus 1 transitions the operation target node from the root node to any one of end nodes (nodes not having a child node) such that data obtained by coupling data associated with branches, through which the operation target node passes, in order from the data closest to the root node coincides with at least data corresponding to a head portion in the insertion data (this processing is hereinafter referred to as phase 1-1 as well).
That is, for example, all of the nodes to which the operation target node is transitioned in the phase 1-1 are nodes that may be associated with the insertion data. Therefore, the management apparatus 1 specifies the nodes to which the operation target nodes are transitioned in the phase 1-1 as nodes with which the insertion data are likely to be associated.
Specifically, for example, in an example illustrated in
Subsequently, the management apparatus 1 transitions the operation target node from the end node, to which the operation target node is transitioned in the phase 1-1, toward the root node until the operation target node reaches a node other than an eldest child node or the insertion data becomes larger than data associated with the parent node in the lexicographic order (this processing is hereinafter referred to as phase 1-2 as well).
That is, for example, among the node to which the operation target node is transitioned in the phase 1-1, nodes associated with data smaller than the insertion data are node less likely to be associated with the insertion data. As explained below, parent nodes of the nodes other than the eldest child node are nodes unlikely to be associated with the insertion data. Therefore, the management apparatus 1 specifies a node to which the operation target node is finally transitioned in the phase 1-2 as a node associated with the insertion data.
Specifically, for example, in an example illustrated in
Subsequently, the management apparatus 1 replaces the insertion data with data associated with the node to which the operation target node is transitioned in the phase 1-2. The management apparatus 1 performs the same processing concerning descendant nodes of the node to which the operation target node is transitioned in the phase 1-2 (this processing is hereinafter referred to as phase 1-3 as well.
Specifically, for example, as illustrated in
Subsequently, as illustrated in
As illustrated in
Thereafter, the management apparatus 1 generates a new node beyond the end node to which the operation target node is transitioned in the phase 1-1 and associates the insertion data with the generated new node (this processing is hereinafter referred to as phase 1-4 as well).
Specifically, for example, as illustrated in
When the end node is the root node in the phase 1-1 or when the insertion data is larger than the data associated with the end node to which the operation target node is transitioned in the phase 1-1, the management apparatus 1 performs the phase 1-4 without performing the phase 1-2 and the phase 1-3.
A specific example of processing for deleting data is explained. In the following explanation, data including “bbac” (hereinafter referred to as deletion data as well) among the data included in the data structure explained with reference to
The management apparatus 1 transitions the operation target node from the root node to any one of end nodes such that data obtained by coupling data associated with branches, through which the operation target node passes, in order from the data closest to the root node coincides with at least data corresponding to a head portion in the insertion data (this processing is hereinafter referred to as phase 2-1 as well).
Specifically, for example, in an example illustrated in
Subsequently, the management apparatus 1 transitions the operation target node from the end node, to which the operation target node is transitioned in the phase 2-1, toward the root node until the operation target node reaches a node associated with the deletion node (this processing is hereinafter referred to as phase 2-2 as well).
Specifically, for example, in an example illustrated in
When data coinciding with the deletion data is absent even if the operation target data reaches a node other than the eldest child node, the management apparatus 1 determines that the deletion data is absent.
Subsequently, the management apparatus 1 associates data associated with a child node of a node to which the operation target node is finally transitioned in the phase 2-2 with the node to which the operation target node is finally transitioned in the phase 2-2. The management apparatus 1 deletes the data associated with the child node of the node to which the operation target node is finally transitioned in the phase 2-2. The management apparatus 1 performs the same processing concerning descendant nodes of the node to which the operation target node is finally transitioned in the phase 2-2 (this processing is hereinafter referred to as phase 2-3 as well).
Specifically, for example, as illustrated in
Thereafter, the management apparatus 1 deletes the end node to which the operation target node is finally transitioned in the phase 2-1 (this processing is hereinafter referred to as phase 2-4 as well).
Specifically, for example, as illustrated in
Processing for searching data is the same as the phase 2-1 and the phase 2-2 in the processing for deleting data. Therefore, explanation of a specific example of the processing for searching data is omitted.
Another specific example of the data structure of the index 131 is explained.
In an example illustrated in
First, another specific example of the processing for inserting data is explained. In the following explanation, insertion data including “bba” is inserted into the data structure explained with reference to
The management apparatus 1 transitions the operation target node from the root node to any one of end nodes such that data obtained by coupling data associated with branches, through which the operation target node passes, in order from the data closest to the root node coincides with at least data corresponding to a head portion in the insertion data (the phase 1-1).
Specifically, for example, in an example illustrated in
Subsequently, the management apparatus 1 transitions the operation target node from the end node, to which the operation target node is transitioned in the phase 1-1, toward the root node until the insertion data becomes larger than data associated with the parent node in the lexicographic order (the phase 1-2).
Specifically, for example, in an example illustrated in
That is, for example, when the node corresponding to “bbab” is a node other than the eldest child node, “b”, which is data associated with a branch between the node corresponding to “bbab” and the parent node, is different from “a”, which is data associated with a branch between the eldest child node (the node corresponding to “bac”) and the parent node. “bab”, which is data associated with a parent node of the node corresponding to “bbab”, is smaller than “bac”, which is data associated with the eldest child node. Therefore, in this case, “bab”, which is data associate with a parent node of the node corresponding to “bbab”, is usually smaller than “bba”, which is the insertion data.
Therefore, in this case, the management apparatus 1 is capable of determining that the insertion data is unlikely to be associated with the data associated with the parent node of the node corresponding to “bbab”. Therefore, when the operation target node reaches a node other than the eldest child node in the phase 1-2, the management apparatus 1 ends the transition of the operation target node.
Subsequently, the management apparatus 1 replaces the insertion data with data associated with a node to which the operation target node is finally transitioned in the phase 1-2. The management apparatus 1 performs the same processing concerning descendant nodes of the node to which the operation target node is finally transitioned in the phase 1-2 (the phase 1-3).
Specifically, for example, as illustrated in
As illustrated in
Thereafter, the management apparatus 1 generates a new node beyond the end node to which the operation target node is transitioned in the phase 1-1 and associates the insertion data with the new node (the phase 1-4).
Specifically, for example, as illustrated in
Another specific example of the processing for deleting data is explained. In the following explanation, data including “bbaa” (hereinafter referred to as deletion data as well) among the data included in the data structure explained with reference to
The management apparatus 1 transitions the operation target node from the root node to any one of end nodes such that data obtained by coupling data associated with branches, through which the operation target node passes, in order from the data closest to the root node coincides with at least data corresponding to a head portion in the insertion data (the phase 2-1).
Specifically, for example, in an example illustrated in
Subsequently, the management apparatus 1 transitions the operation target node from the end node, to which the operation target node is transitioned in the phase 2-1, toward the root node until the operation target node reaches a node associated with the deletion node (the phase 2-2).
Specifically, for example, in an example illustrated in
Subsequently, the management apparatus 1 associates data associated with a child node of the node to which the operation target node is finally transitioned in the phase 2-2 with the node to which the operation target node is finally transitioned in the phase 2-2. The management apparatus 1 deletes the data associated with the child node of the node to which the operation target node is finally transitioned in the phase 2-2. The management apparatus 1 performs the same processing concerning descendant nodes of the node to which the operation target node is finally transitioned in the phase 2-2 (the phase 2-3).
Specifically, for example, as illustrated in
Thereafter, the management apparatus 1 deletes the end node to which the operation target node is finally transitioned in the phase 2-1 (the phase 2-4).
Specifically, for example, as illustrated in
In the index 131 explained above, when a plurality of kinds of operation are performed in parallel for the nodes included in the data structure, lock has to be performed for the nodes on which the operation is performed such that consistency of the data structure is secured.
However, the data structure explained above includes the data structure on which processing performed from a higher-level node toward a lower-level node (the first processing) is performed and the data structure on which processing performed from a lower-level node toward a higher-level node (the second processing) is performed. In such a data structure, when the first processing and the second processing are simultaneously performed, deadlock is likely to be caused by lock involved in these kinds of processing.
Therefore, when the index 131 including the data structures on which the first processing and the second processing are respectively performed is used, the information processing system 10 is unable to perform a plurality of kinds of operation for the data structure in parallel because of necessity for reducing occurrence of deadlock. Therefore, the information processing system 10 is sometimes unable to efficiently perform the kinds of operation for the data structure.
Therefore, the management apparatus 1 in this embodiment sets, as target nodes in performing lock control, child nodes other than an eldest child node among child nodes corresponding to each of parent nodes in layers of a data structure configured by a tree structure. When performing operation on data associated with the nodes in the data structure, the management apparatus 1 performs lock on the target nodes when processing for passing through the target nodes from the parent node to the child nodes is performed. The management apparatus 1 in this embodiment is an example of a lock control apparatus.
That is, for example, when the processing performed from a higher-level node toward a lower-level node (for example, the phase 1-1 explained with reference to
Consequently, the management apparatus 1 is capable of performing a plurality of kinds of operation for data in parallel while reducing occurrence of deadlock. Therefore, the management apparatus 1 is capable of efficiently performing the kinds of operation on the data.
[Hardware Configuration of the Information Processing System]
A hardware configuration of the information processing system 10 is explained.
The management apparatus 1 includes, as illustrated in
The storage medium 104 includes, for example, in a program storage region (not illustrated in
The CPU 101 performs the lock control processing in cooperation with the program 110 loaded from the storage medium 104. The external interface 103 performs communication with, for example, the searching apparatus 2 and the operation terminal 5.
[Functions of the Information Processing System]
Functions of the information processing system 10 are explained.
As illustrated in
The target-node setting unit 111 sets, as target nodes in performing lock control, child nodes other than an eldest child node among child nodes corresponding to each of parent nodes in layers of the data structure of the index 131.
The data operation unit 112 performs operation on the nodes (data associated with the nodes) included in the data structure of the index 131 according to reception of a query from the operation terminal 5. Specifically, for example, the data operation unit 112 performs, for example, insertion, deletion, or search of data included in the data structure of the index 131.
When the data operation unit 112 performs operation on the data included in the data structure of the index 131, the lock executing unit 113 performs lock on the target nodes set by the target-node setting unit 111 when processing for passing through the target nodes from the parent node to the child nodes is performed.
When lock is performed on the target node set by the target-node setting unit 111 (hereinafter referred to as first target node as well), the lock releasing unit 114 releases the lock of the first target node when processing for passing through a second target node, which is a descendant node of the first target node, from the parent node to the child nodes is performed.
An overview of the first embodiment is explained.
As illustrated in
When the data operation timing comes (YES in S1), the management apparatus 1 sets, as target nodes in performing lock control, child nodes other than an eldest child node among child nodes corresponding to each of parent nodes in layers of a data structure configured by a tree structure (S2).
Thereafter, as illustrated in
When the execution of the processing for passing through the target nodes set in the processing in S2 is detected (YES in S11), the management apparatus 1 performs lock on the target nodes on which the processing for passing through the target nodes is executed in the processing in S11 (S12).
That is, for example, when processing performed from a higher-level node to a lower-level node is performed, the management apparatus 1 performs lock for nodes required during execution of the processing. In this case, the management apparatus 1 also performs lock for nodes required during execution of processing performed from a lower-level node toward a higher-level node. When the processing performed from a lower-level node toward a higher-level node is performed, the management apparatus 1 does not perform lock for nodes required during execution of the processing.
Consequently, the management apparatus 1 is capable of performing a plurality of kinds of operation for data in parallel while reducing occurrence of deadlock. Therefore, the management apparatus 1 is capable of efficiently performing the kinds of operation for the data.
Details of the first embodiment are explained.
As illustrated in
When the data operation timing comes (YES in S31), the target-node setting unit 111 sets, as a target node in performing lock control, the root node in the data structure of the index 131 (S32).
Subsequently, the target-node setting unit 111 sets, as target nodes in performing the lock control, child nodes other than an eldest child node among child nodes of each of parent nodes in the data structure of the index 131 (S33).
Thereafter, as illustrated in
When the timing for executing the processing for passing through any nodes included in the data structure of the index 131 comes (YES in S41), the data operation unit 112 determines whether the specific processing is processing for passing through any nodes from the parent node to the child node (S42).
Specifically, for example, the data operation unit 112 determines whether the specific processing is the phase 1-1 or the phase 1-3.
As a result, when determining that the specific processing is not the processing for passing through any nodes from the parent node to the child nodes (NO in S42), the data operation unit 112 performs the processing in S41 and subsequent steps again.
That is, for example, when the specific processing is the phase 1-2, the data operation unit 112 determines that the specific processing is processing in which it is not requested to perform lock during execution.
When determining that the specific processing is the processing for passing through any nodes from the parent node toward the child nodes (YES in S42), the data operation unit 112 determines whether the processing for passing through any nodes from the parent node to the child nodes is executed after the specific processing (S43).
Specifically, for example, the data operation unit 112 determines whether the specific processing is processing for executing the phase 1-2 later.
As a result, when determining that the processing for passing through any nodes from the parent node to the child nodes is executed after the specific processing (YES in S43), the data operation unit 112 determines whether the nodes passed through in the specific processing are the target nodes set in the processing in S32 or S33 (S44).
When determining that the nodes passed through in the specific processing are not the target nodes set in the processing in S32 or S33 (NO in S44), the data operation unit 112 performs the processing in S41 and subsequent steps again.
That is, for example, when the specific processing is the phase 1-1 and the nodes passed through in the specific processing are not the target nodes, the data operation unit 112 determines that the specific processing is processing in which lock does not have to be performed during execution.
When the data operation unit 112 determines that the nodes passed through in the specific processing are the target nodes set in the processing in S32 or S33 (YES in S44), as illustrated in
The lock executing unit 113 performs the processing in S51 in the same manner when the data operation unit 112 determines in the processing in S43 that the processing for passing through any nodes from the parent node to the child nodes is not executed after the specific processing (NO in S43).
That is, for example, when the specific processing is the phase 1-1 (YES in S43), only when the nodes passed through in the specific processing are the target nodes (YES in S44), the lock executing unit 113 performs lock on the node in the specific processing. For example, when the specific processing is the phase 1-3 (NO in S43), irrespective of whether the nodes passed through in the specific processing are the target nodes, the lock executing unit 113 performs lock on the nodes in the specific processing.
Thereafter, the lock releasing unit 114 of the management apparatus 1 determines whether another locked node is present among the nodes included in the data structure of the index 131 (S52).
As a result, when determining that another locked node is present (YES in S52), the lock releasing unit 114 releases the lock for the node determined as being present in the processing in S52 (S53). When determining that another locked node is absent (NO in S52), the lock releasing unit 114 does not perform the processing in S53.
The management apparatus 1 ends the lock control processing. A specific example of the lock control processing in the first embodiment is explained below.
First, a specific example of the target nodes is explained.
As illustrated in
As illustrated in
Specifically, for example, the target-node setting unit 111 sets, as a target node, the node corresponding to “bbaa”, which is a node other than the eldest child node, of the node corresponding to “aab” and the node corresponding to “bbaa”, which are child nodes in the root node. The target-node setting unit 111 sets, as a target node, the node corresponding to “bc”, which is a node other than the eldest child node, of the node corresponding to “bbab” and the node corresponding to “bc”, which are child nodes of the node corresponding to “bbaa”. The target-node setting unit 111 sets, as a target node, the node corresponding to “bbc”, which is a node other than the eldest child node, of the node corresponding to “bbac” and the node corresponding to “bbc”, which are child nodes of the node corresponding to “bbab”.
A specific example of processing for inserting data is explained. In the following explanation, insertion data including “bba” is inserted into the data structure explained with reference to
When the phase 1-1 is performed, as illustrated in
That is, for example, when the phase 1-1 is separately performed according to reception of another query from the operation terminal 5, transition of the operation target node is performed in order from the root node. Therefore, the lock executing unit 113 performs lock for the root node first to thereby perform substantial lock for all the nodes included in the data structure illustrated in
When transition of the operation target node from the root node to the node corresponding to “bbaa” is performed according to the execution of the phase 1-1, as illustrated in
That is, for example, the node corresponding to “bbaa” is a node other than the eldest child node of the root node. Therefore, when the transition from the root node in the phase 1-1 to the node corresponding to “bbaa” is performed, transition to the root node is not performed in processing (for example, the phase 1-2) performed after the phase 1-1. Therefore, when the transition from the root node to the node corresponding to “bbaa” is performed in the phase 1-1, the management apparatus 1 determines that it is not requested to continue the lock for the root node. Therefore, in this case, the management apparatus 1 performs lock on the node corresponding to “bbaa” and releases the lock for the root node.
Consequently, the management apparatus 1 is capable of minimizing a range of lock of a node performed to reduce occurrence of deadlock. Therefore, the management apparatus 1 enables a plurality of kinds of operation to be performed in parallel on the data included in the data structure of the index 131 and is capable of reducing a lock release waiting time that occurs according to the lock for the node.
Subsequently, when transition from the node corresponding to “bbaa” to the node corresponding to “bbab” is performed according to the execution of the phase 1-1, as illustrated in
That is, for example, the node corresponding to “bbab” is an eldest child node of the node corresponding to “bbaa”. Therefore, when the transition from the node corresponding to “bbaa” to the node corresponding to “bbab” is performed in the phase 1-1, in processing (for example, the phase 1-2) performed after the phase 1-1, the transition to “bbaa” is likely to be performed. Therefore, when the transition from the node corresponding to “bbaa” to the node corresponding to “bbab” is performed in the phase 1-1, the management apparatus 1 determines that it is requested to continue the lock for the node corresponding to “bbaa”. Therefore, in this case, the management apparatus 1 does not perform release of the lock for the node corresponding to “bbab” and the lock for the node corresponding to “bbaa”.
When transition from the node corresponding to “bbab” to the node corresponding to “bbac” is performed according to the execution of the phase 1-1, as illustrate in
As illustrated in
That is, for example, the lock executing unit 113 substantially locks all nodes to which the operation target node is likely to be transitioned during the execution of the phase 1-2 according to the execution of the phase 1-1. Therefore, the lock executing unit 113 does not have to perform lock for a new node during execution of the phase 1-2.
Consequently, the management apparatus 1 is capable of stopping lock involved in the execution of the processing (the phase 1-1 or the phase 1-3) for passing through the nodes from the parent node to the child nodes and lock involved in the execution of the processing (the phase 1-2) for passing through the nodes from the child nodes to the parent node from being performed in parallel. Therefore, the management apparatus 1 enables a plurality of kinds of operation to be performed in parallel on the data included in the data structure of the index 131 and is capable of reducing occurrence of deadlock.
Subsequently, as illustrated in
That is, for example, after the phase 1-3, processing for transition to the node corresponding to “bba” is not performed. Therefore, when the transition from the node corresponding to “bba” to the node corresponding to “bbab” is performed in the phase 1-3, the management apparatus 1 determines that it is not requested to continue the lock for the node corresponding to “bba” irrespective of whether the node corresponding to “bbab” is an eldest child node. Therefore, in this case, the lock releasing unit 114 performs lock for the node corresponding to “bbab” and releases the lock for the node corresponding to “bba”.
Consequently, the management apparatus 1 is capable of minimizing a range of lock of nodes performed for reducing occurrence of deadlock. Therefore, the management apparatus 1 enables a plurality of kinds of operation to be performed in parallel for the data included in the data structure of the index 131 and is capable of reducing a lock release waiting time that occurs according to the lock for the node.
As illustrated in
Thereafter, as illustrated in
A specific example of the processing for deleting data is explained. In the following explanation, deletion of deletion data including “bbaa” among the data included in the data structure explained with reference to
When the phase 2-1 is performed, as illustrated in
When transition from the root node to the node corresponding to “bbaa” is performed according to the execution of the phase 2-1, as illustrated in
When transition from the node corresponding to “bbaa” to the node corresponding to “bbab” is performed according to the execution of the phase 2-1, as illustrated in
Subsequently, when transition from the node corresponding to “bbab” to the node corresponding to “bbac” is performed according to the execution of the phase 2-1, as illustrated in
Subsequently, as illustrated in
Thereafter, as illustrated in
Another specific example of the target nodes is explained.
As illustrated in
As illustrated in
Specifically, for example, the target-node setting unit 111 sets, as a target node, the node corresponding to “bab”, which is a node other than the eldest child node, of the node corresponding to “aab” and the node corresponding to “bab”, which are the child nodes of the root node. The target-node setting unit 111 sets, as target nodes, the node corresponding to “bbab” and the node corresponding to “bc”, which are nodes other than the eldest child node, among the node corresponding to “bac”, which is a child node of the node corresponding to “bab”, the node corresponding to “bbab”, and the node corresponding to “bc”. The target-node setting unit 111 sets, as a target node, the node corresponding to “bbc”, which is a node other than the eldest child node, of the node corresponding to the “bbac” and the node corresponding to “bbc”, which are the child nodes of the node corresponding to “bbab”.
A specific example of processing for inserting data is explained. In the following explanation, insertion data including “bba” is inserted into the data structure explained with reference to
When the phase 1-1 is performed, as illustrated in
When transition from the root node to the node corresponding to “bab” is performed according to the execution of the phase 1-1, as illustrated in
Subsequently, when transition from the node corresponding to “bab” to the node corresponding to “bbab” is performed according to the execution of the phase 1-1, as illustrated in
Subsequently, when transition from the node corresponding to “bbab” to the node corresponding to “bbac” is performed according to the execution of the phase 1-1, as illustrated in
As illustrated in
Subsequently, as illustrated in
Thereafter, according to the execution of the processing corresponding to the phase 1-4, as illustrated in
A specific example of the processing for deleting data is explained. In the following explanation, deletion of deletion data including “bbab” among the data included in the data structure explained with reference to
When the phase 2-1 is performed, as illustrated in
When transition from the root node to the node corresponding to “bob” is performed according to the execution of the phase 2-1, since the node corresponding to “bob” is the target node, the lock executing unit 113 performs lock for the node corresponding to “bob” (YES in S43, YES in S44, and S51). In this case, the lock releasing unit 114 releases the lock performed on the root node (YES in S52 and S53).
Subsequently, when transition from the node corresponding to “bab” to the node corresponding to “bbab” is performed according to the execution of the phase 2-1, as illustrated in
When transition from the node corresponding to “bbab” to the node corresponding to “bbac” is performed according to the execution of the phase 2-1, as illustrated in
Subsequently, as illustrated in
Thereafter, according to the execution of the phase 2-3, as illustrated in
In this way, the management apparatus 1 in this embodiment sets, as the target nodes in performing the lock control, the child nodes other than the eldest child node among the child nodes corresponding to each of the parent nodes in the layers of the data structure configured by the tree structure. When operation is performed on the data associated with the nodes in the data structure, the management apparatus 1 performs lock on the target nodes when performing the processing for passing through the target nodes from the parent node to the child nodes.
That is, for example, when the processing performed from data corresponding to a higher-level node toward data corresponding to a lower-level node is performed, the management apparatus 1 performs lock for nodes required during the execution of the processing. In this case, the management apparatus 1 also performs lock for nodes required during the execution of the processing performed from data corresponding to a lower-level node toward data corresponding to a higher-level node. When the processing performed from data corresponding to a lower-level node toward data corresponding to a higher-level node is performed, the management apparatus 1 does not perform lock for nodes required during the execution of the processing.
Consequently, the management apparatus 1 is capable of performing a plurality of kinds of operation for data in parallel while reducing occurrence of deadlock. Therefore, the management apparatus 1 is capable of efficiently performing the kinds of operation for the data.
For example, when search for data included in the data structure of the index 131 is performed according to reception of a query from the operation terminal 5, the lock executing unit 113 may perform reference lock for the nodes. Consequently, the management apparatus 1 is capable of further reducing the lock release waiting time that occurs according to the lock for the nodes.
All examples and conditional language provided herein are intended for the pedagogical purposes of aiding the reader in understanding the invention and the concepts contributed by the inventor to further the art, and are not to be construed as limitations to such specifically recited examples and conditions, nor does the organization of such examples in the specification relate to a showing of the superiority and inferiority of the invention. Although one or more embodiments of the present invention have been described in detail, it should be understood that the various changes, substitutions, and alterations could be made hereto without departing from the spirit and scope of the invention.
Number | Date | Country | Kind |
---|---|---|---|
JP2017-228577 | Nov 2017 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
5430869 | Ishak | Jul 1995 | A |
20050171960 | Lomet | Aug 2005 | A1 |
20100017397 | Koyanagi et al. | Jan 2010 | A1 |
20110246503 | Bender | Oct 2011 | A1 |
20130185271 | Strain | Jul 2013 | A1 |
20140074841 | Majnemer | Mar 2014 | A1 |
20140108435 | Kolesnikov | Apr 2014 | A1 |
20140310317 | Spillane | Oct 2014 | A1 |
20150039575 | Helak | Feb 2015 | A1 |
20150347088 | Bruestle | Dec 2015 | A1 |
20160335299 | Vemulapati | Nov 2016 | A1 |
20170212680 | Waghulde | Jul 2017 | A1 |
20180046387 | Erdmann | Feb 2018 | A1 |
20190130063 | Parida | May 2019 | A1 |
Number | Date | Country |
---|---|---|
9-319642 | Dec 1997 | JP |
2010-026689 | Feb 2010 | JP |
2011-248584 | Dec 2011 | JP |
Entry |
---|
Crain, Tyler et al. “A contention-friendly binary search tree.” Aug. 2013. European Conference on Parallel Processing. Springer, Berlin, Heidelberg. (Year: 2013). |
Number | Date | Country | |
---|---|---|---|
20190163542 A1 | May 2019 | US |