Looking for breakthrough ideas for innovation challenges? Try Patsnap Eureka!

Allocating locks in a distributed environment

a distributed environment and lock technology, applied in the field of distributed computing environments, can solve the problems of affecting the availability of resources, affecting the chances of accessing resources, and the method of allocating resources to the next request is unsatisfactory, so as to prevent resource loss, improve client-side polling methods, and alleviate lock starvation

Inactive Publication Date: 2006-06-22
MICROSOFT TECH LICENSING LLC
View PDF98 Cites 32 Cited by
  • Summary
  • Abstract
  • Description
  • Claims
  • Application Information

AI Technical Summary

Benefits of technology

[0012] The present invention relates to a system and method for managing the allocation of locks to clients. The system and method provides server-side control features related to resource requests for locked resources, such as establishing an expected lifetime property so that the sever may notify requesting clients as to the expected lifetime of a lock to improve client-side polling methods. Also, the present invention relates to blocking a resource or otherwise maintaining subscriptions to lock-related events to effectively allow for asynchronous grants of a lock based on the time of the request to alleviate lock starvation. Another feature relates to a server-side lock function of breaking an existing lock or at least modifying / reducing a lock timeout period to prevent lost resources.

Problems solved by technology

Unfortunately however, the DAV protocol is limited in its ability to satisfactorily allocate previously locked resources to requesting clients.
While relatively simple, the method of allocating the resource to the next request is unsatisfactory as it forces clients to repeatedly and almost continuously request a locked resource.
Unfortunately however, choosing a time interval that is too long may jeopardize the chances of accessing a resource as an intervening request by a different client may occur between the time of the unlock event and the next request.
Indeed, since an intervening request may always appear prior to any other request, any particular client may suffer from lock starvation, i.e., a complete failure to gain access to a requested resource.
Therefore, choosing a time interval necessarily requires the client to balance performance issues with the importance of accessing the resource.
Achieving a satisfactory balance is difficult at best, and such guesswork cannot guarantee that a resource will ever be accessed, based on other client request rates.
Unfortunately however, this solution is unsatisfactory since the lock creator typically chooses a timeout period that far outlasts the actual time needed for the resource.
If not, the lock owner risks having a lock expire before the owner is finished with the resource.
Consequently, subsequent clients cannot rely on the timeout period as a means for realistically determining when to retry a request.
Another drawback associated with the timeout period used in DAV, i.e., the time period by which the lock automatically expires, is that the timeout period may actually be set for an infinite duration.
This causes a significant problem, especially when the client does not explicitly release or unlock the resource when the client does not need the lock any longer.
The problem is exacerbated when the client owning the lock orphans the lock and thus cannot explicitly release the resource.

Method used

the structure of the environmentally friendly knitted fabric provided by the present invention; figure 2 Flow chart of the yarn wrapping machine for environmentally friendly knitted fabrics and storage devices; image 3 Is the parameter map of the yarn covering machine
View more

Image

Smart Image Click on the blue labels to locate them in the text.
Viewing Examples
Smart Image
  • Allocating locks in a distributed environment
  • Allocating locks in a distributed environment
  • Allocating locks in a distributed environment

Examples

Experimental program
Comparison scheme
Effect test

Embodiment Construction

[0023] A distributed environment 100 incorporating aspects of the present invention is shown in FIG. 1. The environment 100 has at least one client computer system, such as client computer systems 102, 104 and 106 that interact with at least one server computer system, such as server computer system 108 over a distributed network, such as the Internet 110. The client computer systems 102, 104 and 106 request access to one or more server computer resources 112. Additionally, there may be other client computer systems as indicated by ellipses 114. The resources 112 relate to computer readable files or objects, such as text documents, application program modules, data objects, properties or attributes for data objects, among others. The resources may be HTML, XML, SGML files, or in other embodiments, the resources may be in another format.

[0024] In an embodiment of the invention, the protocol used by the systems 102, 104, 106 and 108 to communicate is the WebDAV (World Wide Web Distri...

the structure of the environmentally friendly knitted fabric provided by the present invention; figure 2 Flow chart of the yarn wrapping machine for environmentally friendly knitted fabrics and storage devices; image 3 Is the parameter map of the yarn covering machine
Login to View More

PUM

No PUM Login to View More

Abstract

A system and method for managing the allocation of resources and locks to client computer systems. The system and method provides server-side control features related to resource requests for locked resources, such as establishing an expected lifetime property so that the sever may notify requesting clients as to the expected lifetime of a lock to improve client-side polling methods. The system and method relates to blocking a resource or otherwise maintaining subscriptions to lock-related events to effectively allow for asynchronous grants of a lock based on the time of the request to alleviate lock starvation. Another feature relates to a server-side lock function of breaking an existing lock or at least modifying / reducing a lock timeout period to prevent lost resources.

Description

RELATED APPLICATION [0001] This application is a continuation of co-pending U.S. Patent Application for “METHOD AND SYSTEM FOR ALLOCATING LOCKS IN A DISTRIBUTED ENVIRONMENT,” filed on Nov. 13, 2001 and assigned Ser. No. 09 / 992,603, the complete disclosure of which is hereby incorporated by reference in its entirety.TECHNICAL FIELD [0002] This invention relates generally to distributed computing environments and particularly to availability management of resources in a distributed environment. More particularly, the present invention relates to methods of “locking” distributed environment resources to prevent inappropriate access to such resources. More particularly still, the present invention relates to server-side allocation of locks in the WebDAV protocol. BACKGROUND OF THE INVENTION [0003] Distributed computer environments, such as computer networks, provide significant advantages to multiple computer clients or users. In particular, distributed environments allow multiple clien...

Claims

the structure of the environmentally friendly knitted fabric provided by the present invention; figure 2 Flow chart of the yarn wrapping machine for environmentally friendly knitted fabrics and storage devices; image 3 Is the parameter map of the yarn covering machine
Login to View More

Application Information

Patent Timeline
no application Login to View More
Patent Type & Authority Applications(United States)
IPC IPC(8): G06F9/46G06F9/00
CPCG06F9/52Y10S707/99931Y10S707/99939Y10S707/99938
Inventor GOLDICK, JONATHAN S.
Owner MICROSOFT TECH LICENSING LLC
Who we serve
  • R&D Engineer
  • R&D Manager
  • IP Professional
Why Patsnap Eureka
  • Industry Leading Data Capabilities
  • Powerful AI technology
  • Patent DNA Extraction
Social media
Patsnap Eureka Blog
Learn More
PatSnap group products