WO2006138168A2 - Techniques for handling lock-related inconsistencies - Google Patents
Techniques for handling lock-related inconsistencies Download PDFInfo
- Publication number
- WO2006138168A2 WO2006138168A2 PCT/US2006/022501 US2006022501W WO2006138168A2 WO 2006138168 A2 WO2006138168 A2 WO 2006138168A2 US 2006022501 W US2006022501 W US 2006022501W WO 2006138168 A2 WO2006138168 A2 WO 2006138168A2
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- lock
- resource
- node
- nodes
- lock information
- Prior art date
Links
- 238000000034 method Methods 0.000 title claims abstract description 69
- 238000012937 correction Methods 0.000 claims description 15
- 230000004044 response Effects 0.000 claims description 7
- 230000000694 effects Effects 0.000 claims description 3
- 238000001514 detection method Methods 0.000 claims description 2
- 230000008859 change Effects 0.000 abstract description 5
- 230000008569 process Effects 0.000 description 41
- 238000004891 communication Methods 0.000 description 19
- 230000007246 mechanism Effects 0.000 description 10
- 238000012545 processing Methods 0.000 description 7
- 238000013459 approach Methods 0.000 description 5
- 230000005540 biological transmission Effects 0.000 description 5
- 238000010586 diagram Methods 0.000 description 5
- 230000003287 optical effect Effects 0.000 description 5
- 230000008901 benefit Effects 0.000 description 2
- 238000004590 computer program Methods 0.000 description 2
- 230000000977 initiatory effect Effects 0.000 description 2
- 230000007480 spreading Effects 0.000 description 2
- 230000003068 static effect Effects 0.000 description 2
- RYGMFSIKBFXOCR-UHFFFAOYSA-N Copper Chemical compound [Cu] RYGMFSIKBFXOCR-UHFFFAOYSA-N 0.000 description 1
- 230000009471 action Effects 0.000 description 1
- 230000006399 behavior Effects 0.000 description 1
- 230000008878 coupling Effects 0.000 description 1
- 238000010168 coupling process Methods 0.000 description 1
- 238000005859 coupling reaction Methods 0.000 description 1
- 230000001627 detrimental effect Effects 0.000 description 1
- 239000000835 fiber Substances 0.000 description 1
- 238000013507 mapping Methods 0.000 description 1
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/46—Multiprogramming arrangements
- G06F9/52—Program synchronisation; Mutual exclusion, e.g. by means of semaphores
- G06F9/526—Mutual exclusion algorithms
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2209/00—Indexing scheme relating to G06F9/00
- G06F2209/52—Indexing scheme relating to G06F9/52
- G06F2209/522—Manager
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y10—TECHNICAL SUBJECTS COVERED BY FORMER USPC
- Y10S—TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y10S707/00—Data processing: database and file management or data structures
- Y10S707/99931—Database or file accessing
- Y10S707/99938—Concurrency, e.g. lock management in shared database
Definitions
- the present invention relates to lock management and, more specifically, to handling lock-related inconsistencies in multiple-node systems.
- Computers use resources, such as memory, modems and printers, during the execution of computer programs. Many of these resources are only used periodically by any given computer program. For example, the amount of time a word processing application requires a printer to print documents is typically small relative to the amount of time that the word processing application is used to create documents. If the only process that had access to the printer was a single word processing application, the printer would remain idle most of the time.
- a lock is a data structure that indicates that a particular process has been granted certain rights with respect to the resource.
- the process Before a process can perform an operation on a resource, the process is required to obtain a lock that grants to the process the right to perform the desired operation on the resource. To obtain a lock, a process transmits a request for the lock to a lock manager.
- a lock manager is a process that is responsible for granting, queuing, and keeping track of locks on one or more resources.
- lock managers are executed on one or more nodes in the network.
- the node that is executing the lock manager that governs access to a particular resource is referred to as the "master node", or simply the "master”, of that resource.
- a lock manager implements two types of objects: a resource object and a lock.
- Resource objects are data structures that correspond to actual resources.
- An application that uses a lock manager establishes a mapping between actual resources and resource objects.
- Each resource object has two queues: a granted queue and a convert queue.
- the granted queue is an unordered list of locks that have been granted.
- the convert queue is a partially ordered list of locks that have been requested, but not yet granted.
- a request for a lock is actually a convert request, where a process holding a lock is requesting that the lock it holds be converted from one mode of lock to a different mode of lock.
- Locks are data structures that identify a process and a lock mode. Lock managers attach locks to the grant queues of resource objects to indicate that the process identified in the lock has been granted a lock of the type indicated in the lock on the resource that corresponds to the resource object to which the lock is attached.
- FIG. 1 is a block diagram illustrating a typical lock manager 106.
- Lock manager 106 is a process that is configured to manage a resource object 100 stored in a memory 108.
- the resource object includes a granted queue 102 and a convert queue 104.
- Lock manager 106 has attached three locks 110, 112 and 114 to the granted queue 102, and one convert request 130 to the convert queue 104.
- All locks and convert requests have a process ID portion and a lock mode portion.
- the process ID portion 116 of lock 110 indicates that a process PROC_1 owns lock 110, and the lock mode portion 118 of lock 110 indicates that lock 110 is an exclusive lock.
- the process ID portion 120 of lock 112 indicates that lock 112 is owned by a process PROC_2, and the lock mode portion 122 of lock 112 indicates that lock 112 is a NULL mode lock.
- the process ID portion 124 of lock 114 indicates that lock 114 is owned by a process PROC_3, and the lock mode portion 126 of lock 114 indicates that lock 114 is a NULL lock.
- the process ID portion 132 of convert request 130 indicates that convert request 130 is associated with process PROC_4, and the lock mode portion 136 of convert request 130 indicates that PROC_4 currently holds a NULL mode lock on the resource.
- convert request 130 has a requested mode portion 134 that indicates that PROC_4 is requesting an exclusive mode lock.
- Lock manager 106 has attached locks 110, 112 and 114 to granted queue 102, indicating that PROC_1 currently has exclusive ownership of the resource that corresponds to resource object 100.
- Lock manager 106 has attached convert request 130 to the convert queue 104, indicating that PROC_4 has requested but has not yet been granted an exclusive mode lock on the resource associated with resource object 100.
- the convert queue of a resource object is a partially ordered list that holds all outstanding (ungranted) lock requests. If any outstanding lock requests have not been granted, one of the ungranted lock requests will be at the "head" of the convert queue. Even if the currently granted locks do not prevent a lock manager from granting a particular lock request, the lock request is placed on the convert queue if the convert queue is not empty. This policy prevents "livelocks", where one process cannot make progress in the system while other processes can.
- some or all of the processes that are holding and requesting locks on a particular resource may be on different nodes than the master node of that resource.
- a lock request must be transmitted between nodes.
- the computational power that must be expended to facilitate such inter-node messages is significant relative to the power required for intra-node communication.
- inter-node communication is generally slower than intra-node communication.
- the inter-node traffic thus generated reduces the throughput available for other types of inter-node traffic, which may be significant when the inter-node traffic is between workstations on a network.
- each of the nodes that has a shadow resource object may be used to perform lock operations related to the resource. Further, because the lock management workload for a resource is distributed, the processing load required to perform lock management for the resource is less likely to overburden a node than in lock management systems in which all lock operations for a resource must be performed at a single node.
- the master resource object for a resource grants locks to shadow resource objects located on the nodes on which are located the processes that desire to access the resource. Each shadow resource object, in turn, grants locks on the resource to the processes that are located on the same node as the shadow resource object.
- the master resource object may also act as a shadow resource object to the processes running on the master node that require access to the resource owned by the master resource object.
- the lock owned by each shadow resource object determines the types of locks the shadow resource object is allowed to grant to processes. If the lock owned by a shadow resource object does not give the shadow resource object the right to grant a lock requested by a process on the same node as the shadow resource object, then the shadow resource object may request for a lock upgrade from the master resource object.
- the amount of inter-node traffic required by the distributed lock management system may be less than that required by lock management systems that employ a single centralized resource object for each resource. Specifically, inter-node traffic is avoided when the shadow resource object owns a lock that allows the shadow resource object to perform a requested lock operation without communicating with the master resource object.
- the lock information related to a single resource may be reflected on multiple nodes. For example, the same lock request may be reflected on both the local shadow resource object and the master resource object. In this case, the master node has "global knowledge" of the request.
- the master node knows which node made the lock request, and what lock mode was requested.
- the local shadow resource object has "local knowledge" of the request. Specifically, the local resource object may identify which local process requested the lock, and what lock mode was requested by that process.
- the information about the locks held and requested on the resource should be consistent across the cluster of nodes that access the resource, except for a small time interval when messages are in transit between the nodes.
- Such inconsistencies are referred to herein as "lock-related inconsistencies”.
- a lock-related inconsistency is a situation in which the master resource object indicates that an exclusive lock has been granted to node A, but the shadow lock resource of node A indicates that node A is still waiting for the grant.
- a node B may be requesting an exclusive mode ("EX mode") lock on a resource, but the master node may not have any knowledge of the request. Inconsistencies such as these may lead to hang a situation.
- EX mode exclusive mode
- FIG. 1 is a block diagram of a resource object that may be used to keep track of requests relating to a resource
- FIG. 2 is a flowchart for handling lock-related inconsistencies, according to an embodiment of the invention.
- FIG. 3 is a block diagram of a computer system upon which the techniques described herein may be implemented.
- the techniques involve causing the locally-stored lock information about a resource to be sent to the master node of the resource.
- the master node of the resource compares the lock information thus received against the lock information maintained by the master node. Based on the comparison, the master node determines how to resolve the lock-related inconsistency, and sends messages to those nodes that need to change their local lock information for the resource. Once all of the lock information has been made consistent, the resource is made available for access. Because the lock-related inconsistency is resolved without restarting nodes, the availability of the resources is improved.
- Lock-related inconsistencies may be caused by a variety of situations. For example, a lock-related inconsistency may be caused when a lock-related message is lost. In this situation, the sender of the lock-related message will typically have updated its lock information based on having sent the message, but the lock information maintained by the intended recipient will not reflect the message.
- lock-related message is merely one example of a situation that will result in a lock-related inconsistency.
- Other situations that result in lock-related inconsistencies include memory corruption, improper resource clean-up operations, etc.
- the techniques described herein for handling lock-related inconsistencies are not limited to any particular cause or set of causes of those inconsistencies.
- messages exchanged between the nodes indicate not only locks that the nodes are requesting and/or granting, but also "current lock state" information.
- Current lock state information sent by a node indicates the current state of the lock information maintained by that node. For example, if the shadow lock object on node Nl for resource Rl indicates that node Nl has been granted an exclusive lock on Rl, then messages sent from node Nl to the master of resource Rl would indicate that Nl believes that it holds an exclusive lock on Rl.
- a node When a node receives a message that contains current lock state information for a resource from another node, the receiving node can compare the lock state information against its own lock information for that resource. For example, assume that the master node N2 for resource Rl receives a message from node Nl that indicates Nl believes it holds an exclusive lock on resource Rl. Master node N2 can then inspect the master resource object for resource Rl. If the master resource object for resource Rl does not indicate that node Nl holds an exclusive lock on resource Rl, then a lock-related inconsistency exists. [0036] The master node for a resource may not be the node that initially detects the inconsistency.
- node Nl receives a message from master node N2 that indicates N2 believes that Nl holds an exclusive lock on resource Rl. Node Nl can then inspect its shadow resource object for resource Rl. If the shadow resource object for resource Rl does not indicate that node Nl holds an exclusive lock on resource Rl, then a lock-related inconsistency exists.
- Another way to automatically detect lock-related inconsistencies is to have each requesting node track how much time passes after sending a lock request, without receiving a response to the request. If more than a threshold amount of time passes without receiving a response, then the requesting node may initiate a hang resolution operation. As part of the hang resolution operation, the lock management system may check whether any lock-related inconsistency exists relative to the requested resource.
- the lock management system includes a mechanism for automatically identifying conditions that indicate possible lock-related inconsistencies, and initiating an operation to handle those inconsistencies without shutting down any node. Techniques for handling lock related inconsistencies shall now be described in greater detail.
- FIG. 2 it is a flowchart for handling lock-related inconsistencies, according to an embodiment of the invention.
- an inconsistency exists between the local lock information maintained by a node Nl about a resource Rl, and the information maintained by the master node N2 for resource Rl.
- the lock-related inconsistency is detected.
- various mechanisms may be used to detect lock-related inconsistencies, and the techniques for handling such consistencies that are described herein are not limit to any particular detection mechanism.
- the node that detects the inconsistency may be the master node N2, or some other node. According to one embodiment, when the node that detects the lock-related inconsistency is not the master node N2, the node that detects the lock-related inconsistency notifies master node N2 of the lock-related inconsistency.
- the master node N2 broadcasts a "freeze" message to all nodes in the system.
- the freeze message informs the nodes that lock-related activity for the resource has been suspended, pending corrective action.
- all nodes send acknowledge messages to the master node N2 to indicate that they received the freeze message.
- the nodes that have local lock information relating to resource Rl (the "involved nodes") send to the master node N2 local-lock-state messages (step 204).
- the local-lock-state message sent by each interested node reflects the local lock information maintained for resource Rl by that node.
- node Nl would send to node N2 a local-lock-state message that indicates the local lock information that node Nl has for resource Rl .
- the local-lock-state messages may be sent separate from the acknowledge messages, or in a combined message that both acknowledges receipt of the freeze message and communicates the local lock information maintained for resource Rl.
- the master node N2 figures out what needs to be changed to resolve the inconsistency. In the present example, assume that the master node N2 had granted node Nl an exclusive lock to resource Rl, but that node Nl still believes that it only holds a shared lock on resource Rl .
- master node N2 may determine that the inconsistency can be corrected by having node Nl change its local lock information to indicate that node Nl has an exclusive lock on resource Rl.
- the master node N2 corrects any lock information that needs to be corrected on the master node N2, and sends correction requests to all nodes that need to change their local lock information ("correction-needed nodes"). In the present example, no changes need to be made to the information on the master resource object. However, the local lock information on node Nl needs to be corrected. Therefore, master node N2 sends to node NI a correction request for node Nl to change its local lock information to indicate that node Nl has an exclusive lock on resource Rl
- the correction-needed nodes receive the correction requests and make the corrections. After making the corrections, the correction-needed nodes send a correction- performed message back to the master node.
- node Nl updates its local lock information to indicate that it holds an exclusive lock on resource Rl, and sends master node N2 a correction-performed message to indicate that node Nl has corrected its local lock information.
- the master node When, at step 212, the master node receives correction-performed messages from all of the correction-needed nodes, the master node broadcasts an "unfreeze" message to all nodes. When the nodes receive the unfreeze message, the nodes know that lock-related operations for resource Rl may resume.
- the master node is responsible for deciding what corrections to make, and coordinating the correction.
- the tasks performed by the master node in that example may instead be performed by one or more other nodes.
- the master node of a resource need not be the "coordinator node" for the operation of resolving lock-related inconsistencies for the resource.
- the node that detects the lock-related inconsistency may be designated as the coordinator for the inconsistency resolution operation.
- the node that detects the lock-related inconsistency would be the one that broadcasts the freeze message, receives the local lock information, determines how to resolve the inconsistency, etc.
- the node detects the lock-related inconsistency would also receive, from the master node, information about the state of the global resource object.
- the coordinator node would determine how to correct the inconsistency based on both the local lock information received from the involved nodes, and the global lock information from the master node.
- the tasks performed by the master node may be spread among several nodes.
- the node that detects a lock-related inconsistency may be responsible for broadcasting the freeze message, while the master node is still responsible for receiving the lock information and determining how to resolve the inconsistency.
- the techniques described herein are not limited to specific nodes being responsible for the performance of specific tasks.
- the lock-related inconsistency correction is performed automatically in response to a process detecting conditions that indicate the possible existence of a lock-related inconsistency.
- a database user may notice behavior that causes the user to believe that there may be a lock-related inconsistency.
- the lock management system is configured to include a mechanism by which a user may manually initiate a lock-related inconsistency correction operation.
- the mechanism may include, for example, controls that allow the user to specify a resource, or set of resources, for which to perform correction operations.
- the controls may be, for example, graphical user interface controls, a command line interpreter, etc.
- the invention is not limited to any particular mechanism for receiving user input to initiate inconsistency correction operations.
- FIG. 3 is a block diagram that illustrates a computer system 300 upon which an embodiment of the invention may be implemented.
- Computer system 300 includes a bus 302 or other communication mechanism for communicating information, and a processor 304 coupled with bus 302 for processing information.
- Computer system 300 also includes a main memory 306, such as a random access memory (RAM) or other dynamic storage device, coupled to bus 302 for storing information and instructions to be executed by processor 304.
- Main memory 306 also may be used for storing temporary variables or other intermediate information during execution of instructions to be executed by processor 304.
- Computer system 300 further includes a read only memory (ROM) 308 or other static storage device coupled to bus 302 for storing static information and instructions for processor 304.
- ROM read only memory
- a storage device 310 such as a magnetic disk or optical disk, is provided and coupled to bus 302 for storing information and instructions.
- Computer system 300 may be coupled via bus 302 to a display 312, such as a cathode ray tube (CRT), for displaying information to a computer user.
- a display 312 such as a cathode ray tube (CRT)
- cursor control 316 is Another type of user input device
- cursor control 316 such as a mouse, a trackball, or cursor direction keys for communicating direction information and command selections to processor 304 and for controlling cursor movement on display 312.
- This input device typically has two degrees of freedom in two axes, a first axis (e.g., x) and a second axis (e.g., y), that allows the device to specify positions in a plane.
- the invention is related to the use of computer system 300 for implementing the techniques described herein. According to one embodiment of the invention, those techniques are performed by computer system 300 in response to processor 304 executing one or more sequences of one or more instructions contained in main memory 306. Such instructions may be read into main memory 306 from another machine-readable medium, such as storage device 310. Execution of the sequences of instructions contained in main memory 306 causes processor 304 to perform the process steps described herein. In alternative embodiments, hard-wired circuitry may be used in place of or in combination with software instructions to implement the invention. Thus, embodiments of the invention are not limited to any specific combination of hardware circuitry and software.
- machine-readable medium refers to any medium that participates in providing data that causes a machine to operation in a specific fashion.
- various machine-readable media are involved, for example, in providing instructions to processor 304 for execution.
- Such a medium may take many forms, including but not limited to, non-volatile media, volatile media, and transmission media.
- Non-volatile media includes, for example, optical or magnetic disks, such as storage device 310.
- Volatile media includes dynamic memory, such as main memory 306.
- Transmission media includes coaxial cables, copper wire and fiber optics, including the wires that comprise bus 302. Transmission media can also take the form of acoustic or light waves, such as those generated during radio-wave and infra-red data communications.
- Machine-readable media include, for example, a floppy disk, a flexible disk, hard disk, magnetic tape, or any other magnetic medium, a CD-ROM, any other optical medium, punchcards, papertape, any other physical medium with patterns of holes, a RAM, a PROM, and EPROM, a FLASH-EPROM, any other memory chip or cartridge, a carrier wave as described hereinafter, or any other medium from which a computer can read.
- Various forms of machine-readable media may be involved in carrying one or more sequences of one or more instructions to processor 304 for execution. For example, the instructions may initially be carried on a magnetic disk of a remote computer.
- the remote computer can load the instructions into its dynamic memory and send the instructions over a telephone line using a modem.
- a modem local to computer system 300 can receive the data on the telephone line and use an infra-red transmitter to convert the data to an infra-red signal.
- An infra-red detector can receive the data carried in the infra-red signal and appropriate circuitry can place the data on bus 302.
- Bus 302 carries the data to main memory 306, from which processor 304 retrieves and executes the instructions.
- the instructions received by main memory 306 may optionally be stored on storage device 310 either before or after execution by processor 304.
- Computer system 300 also includes a communication interface 318 coupled to bus 302.
- Communication interface 318 provides a two-way data communication coupling to a network link 320 that is connected to a local network 322.
- communication interface 318 may be an integrated services digital network (ISDN) card or a modem to provide a data communication connection to a corresponding type of telephone line.
- ISDN integrated services digital network
- communication interface 318 may be a local area network (LAN) card to provide a data communication connection to a compatible LAN.
- LAN local area network
- Wireless links may also be implemented.
- communication interface 318 sends and receives electrical, electromagnetic or optical signals that carry digital data streams representing various types of information.
- Network link 320 typically provides data communication through one or more networks to other data devices.
- network link 320 may provide a connection through local network 322 to a host computer 324 or to data equipment operated by an Internet Service Provider (ISP) 326.
- ISP 326 in turn provides data communication services through the world wide packet data communication network now commonly referred to as the "Internet" 328.
- Internet 328 uses electrical, electromagnetic or optical signals that carry digital data streams.
- the signals through the various networks and the signals on network link 320 and through communication interface 318, which carry the digital data to and from computer system 300, are exemplary forms of carrier waves transporting the information.
- Computer system 300 can send messages and receive data, including program code, through the network(s), network link 320 and communication interface 318.
- a server 330 might transmit a requested code for an application program through Internet 328, ISP 326, local network 322 and communication interface 318.
- the received code may be executed by processor 304 as it is received, and/or stored in storage device 310, or other non-volatile storage for later execution. In this manner, computer system 300 may obtain application code in the form of a carrier wave.
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
- Computer And Data Communications (AREA)
- Mobile Radio Communication Systems (AREA)
Abstract
Description
Claims
Priority Applications (7)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CA2606457A CA2606457C (en) | 2005-06-16 | 2006-06-09 | Techniques for handling inconsistencies in enqueue lock information |
JP2008516952A JP4607999B2 (en) | 2005-06-16 | 2006-06-09 | How to handle lock-related inconsistencies |
EP06772706A EP1891525B1 (en) | 2005-06-16 | 2006-06-09 | Techniques for handling lock-related inconsistencies |
CN200680020071.1A CN101189581B (en) | 2005-06-16 | 2006-06-09 | Techniques for handling lock-related inconsistencies |
DE602006010858T DE602006010858D1 (en) | 2005-06-16 | 2006-06-09 | METHOD FOR HANDLING LOCKING INCONSISTENCES |
AU2006259651A AU2006259651B2 (en) | 2005-06-16 | 2006-06-09 | Techniques for handling lock-related inconsistencies |
HK08104016.4A HK1109939A1 (en) | 2005-06-16 | 2008-04-10 | Techniques for handling lock-related inconsistencies |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US11/156,318 US7315910B2 (en) | 2005-06-16 | 2005-06-16 | Techniques for handling lock-related inconsistencies |
US11/156,318 | 2005-06-16 |
Publications (2)
Publication Number | Publication Date |
---|---|
WO2006138168A2 true WO2006138168A2 (en) | 2006-12-28 |
WO2006138168A3 WO2006138168A3 (en) | 2007-03-08 |
Family
ID=37499647
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/US2006/022501 WO2006138168A2 (en) | 2005-06-16 | 2006-06-09 | Techniques for handling lock-related inconsistencies |
Country Status (9)
Country | Link |
---|---|
US (1) | US7315910B2 (en) |
EP (1) | EP1891525B1 (en) |
JP (1) | JP4607999B2 (en) |
CN (1) | CN101189581B (en) |
AU (1) | AU2006259651B2 (en) |
CA (1) | CA2606457C (en) |
DE (1) | DE602006010858D1 (en) |
HK (1) | HK1109939A1 (en) |
WO (1) | WO2006138168A2 (en) |
Families Citing this family (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7725660B2 (en) * | 2007-07-26 | 2010-05-25 | International Business Machines Corporation | Directory for multi-node coherent bus |
US8429657B2 (en) | 2008-04-28 | 2013-04-23 | Oracle International Corporation | Global avoidance of hang states via priority inheritance in multi-node computing system |
CN101464884B (en) * | 2008-12-31 | 2011-09-28 | 阿里巴巴集团控股有限公司 | Distributed task system and data processing method using the same |
US8868748B2 (en) | 2010-10-11 | 2014-10-21 | International Business Machines Corporation | Two-level management of locks on shared resources |
CN102298539A (en) * | 2011-06-07 | 2011-12-28 | 华东师范大学 | Method and system for scheduling shared resources subjected to distributed parallel treatment |
CN103248667B (en) * | 2012-02-14 | 2016-03-30 | 阿里巴巴集团控股有限公司 | A kind of resource access method of distributed system and system |
Citations (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5339427A (en) | 1992-03-30 | 1994-08-16 | International Business Machines Corporation | Method and apparatus for distributed locking of shared data, employing a central coupling facility |
Family Cites Families (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4949239A (en) * | 1987-05-01 | 1990-08-14 | Digital Equipment Corporation | System for implementing multiple lock indicators on synchronous pended bus in multiprocessor computer system |
US5454108A (en) | 1994-01-26 | 1995-09-26 | International Business Machines Corporation | Distributed lock manager using a passive, state-full control-server |
US6574654B1 (en) | 1996-06-24 | 2003-06-03 | Oracle Corporation | Method and apparatus for lock caching |
US6931430B1 (en) * | 1998-05-13 | 2005-08-16 | Thomas W. Lynch | Maintaining coherency in a symbiotic computing system and method of operation thereof |
US6480918B1 (en) * | 1998-12-22 | 2002-11-12 | International Business Machines Corporation | Lingering locks with fairness control for multi-node computer systems |
US6301676B1 (en) * | 1999-01-22 | 2001-10-09 | Sun Microsystems, Inc. | Robust and recoverable interprocess locks |
US6751616B1 (en) | 2000-01-28 | 2004-06-15 | Oracle International Corp. | Techniques for DLM optimization with re-mapping responsibility for lock management |
US6920454B1 (en) | 2000-01-28 | 2005-07-19 | Oracle International Corporation | Techniques for DLM optimization with transferring lock information |
US6529906B1 (en) | 2000-01-28 | 2003-03-04 | Oracle Corporation | Techniques for DLM optimization with re-mastering events |
US6961865B1 (en) * | 2001-05-24 | 2005-11-01 | Oracle International Corporation | Techniques for resuming a transaction after an error |
US6970872B1 (en) * | 2002-07-23 | 2005-11-29 | Oracle International Corporation | Techniques for reducing latency in a multi-node system when obtaining a resource that does not reside in cache |
US7216346B2 (en) * | 2002-12-31 | 2007-05-08 | International Business Machines Corporation | Method and apparatus for managing thread execution in a multithread application |
-
2005
- 2005-06-16 US US11/156,318 patent/US7315910B2/en active Active
-
2006
- 2006-06-09 AU AU2006259651A patent/AU2006259651B2/en active Active
- 2006-06-09 DE DE602006010858T patent/DE602006010858D1/en active Active
- 2006-06-09 WO PCT/US2006/022501 patent/WO2006138168A2/en active Application Filing
- 2006-06-09 EP EP06772706A patent/EP1891525B1/en active Active
- 2006-06-09 CA CA2606457A patent/CA2606457C/en active Active
- 2006-06-09 JP JP2008516952A patent/JP4607999B2/en active Active
- 2006-06-09 CN CN200680020071.1A patent/CN101189581B/en active Active
-
2008
- 2008-04-10 HK HK08104016.4A patent/HK1109939A1/en unknown
Patent Citations (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5339427A (en) | 1992-03-30 | 1994-08-16 | International Business Machines Corporation | Method and apparatus for distributed locking of shared data, employing a central coupling facility |
Also Published As
Publication number | Publication date |
---|---|
US20060288144A1 (en) | 2006-12-21 |
CA2606457C (en) | 2011-07-26 |
US7315910B2 (en) | 2008-01-01 |
HK1109939A1 (en) | 2008-06-27 |
JP4607999B2 (en) | 2011-01-05 |
AU2006259651A1 (en) | 2006-12-28 |
CA2606457A1 (en) | 2006-12-28 |
WO2006138168A3 (en) | 2007-03-08 |
CN101189581B (en) | 2010-08-18 |
CN101189581A (en) | 2008-05-28 |
EP1891525B1 (en) | 2009-12-02 |
EP1891525A2 (en) | 2008-02-27 |
JP2008544371A (en) | 2008-12-04 |
DE602006010858D1 (en) | 2010-01-14 |
AU2006259651B2 (en) | 2010-01-07 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US7600063B2 (en) | Techniques for improved read-write concurrency | |
US8990179B2 (en) | Time limited lock ownership | |
US6965893B1 (en) | Techniques for granting shared locks more efficiently | |
US7392335B2 (en) | Anticipatory changes to resources managed by locks | |
US6618744B1 (en) | Efficient lock state transitions in a distributed system | |
US9152666B2 (en) | Distributed database system providing data and space management methodology | |
US7493400B2 (en) | Creating and dissolving affinity relationships in a cluster | |
US7814065B2 (en) | Affinity-based recovery/failover in a cluster environment | |
US8037169B2 (en) | Determining affinity in a cluster | |
US20040002974A1 (en) | Thread based lock manager | |
US6697901B1 (en) | Using secondary resource masters in conjunction with a primary resource master for managing resources that are accessible to a plurality of entities | |
CA2606457C (en) | Techniques for handling inconsistencies in enqueue lock information | |
WO2005124547A1 (en) | Techniques for achieving higher availability of resources during reconfiguration of a cluster | |
US11709620B2 (en) | Methods and systems for memory management in a publish and subscribe system | |
US6704767B1 (en) | Using distributed information about lock conversion requests to efficiently manage lock state transitions | |
US20220159070A1 (en) | Methods and systems for enabling publish-subscribe message transmission in a distributed environment | |
JPS62232064A (en) | Deadlock prevention system for distributed data base system |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
WWE | Wipo information: entry into national phase |
Ref document number: 200680020071.1 Country of ref document: CN |
|
DPE1 | Request for preliminary examination filed after expiration of 19th month from priority date (pct application filed from 20040101) | ||
ENP | Entry into the national phase |
Ref document number: 2606457 Country of ref document: CA |
|
WWE | Wipo information: entry into national phase |
Ref document number: 8306/DELNP/2007 Country of ref document: IN |
|
WWE | Wipo information: entry into national phase |
Ref document number: 2006259651 Country of ref document: AU |
|
ENP | Entry into the national phase |
Ref document number: 2008516952 Country of ref document: JP Kind code of ref document: A |
|
WWE | Wipo information: entry into national phase |
Ref document number: 2006772706 Country of ref document: EP |
|
NENP | Non-entry into the national phase |
Ref country code: DE |
|
121 | Ep: the epo has been informed by wipo that ep was designated in this application |
Ref document number: 06772706 Country of ref document: EP Kind code of ref document: A2 |