1. Technical Field
The present invention relates generally to the field of computing. Embodiments of the present invention relate to methods and systems for transparent software license suspension.
2 Background
One form of computing is distributed computing in which a number of interconnected computing nodes are utilized to solve one or more problems in a coordinated fashion. These nodes may be individual desktop computers, servers, processors or similar machines capable of hosting an individual instance of computation. Each instance of computation or “process” can be implemented as an individual process or a thread of execution inside an operating system process. There has been a significant amount of interest in such distributed systems. This has largely been motivated by the availability of high speed network interconnects that allow distributed systems to reach similar levels of efficiency as those observed by traditional custom supercomputers at a fraction of the cost.
The cooperation between the separate processes in a distributed system can be in form of exchanged messages over an interconnection network or through the accessing and modification of shared memory. Some of the nodes may individually or collectively work on some specific software that may require a license to be used. At some instances, one or more groups of nodes may need to access and use certain software presently in use and for which no additional licenses are available. In such situations, it might be desirable to revoke the licenses from certain nodes and assign them to other nodes.
Traditionally, licenses are individually leased to applications by an outside license server that usually resides on a remote host. Existing license suspension solutions tend to be slow because they rely on the use of a command line tool (CLI) distributed by software licensing vendors to manually release each license by communicating with the license server. Efficient mechanisms are needed to assign and revoke licenses. Furthermore, the application of such mechanisms should not be limited to distributed systems. The license revoking mechanisms should work in various types of computing systems.
In one aspect of the disclosure, a method for license sharing in a computing system comprises receiving a request for a license being currently used by a process in execution, pausing the execution of the process, and releasing the license to a shared pool.
In another aspect of the disclosure, a computer-program product for transparent license suspension comprises a machine-readable medium encoded with instructions executable to receive a request for a license being currently used by a process in execution, pause the execution of the process, and release the resources to a shared pool.
In yet another aspect of the disclosure, a system for license sharing in a computing organization comprises a communication channel configured to receive a request for a license being currently used by a process in execution; and a processor configured to pause the execution of the process and release the license being used by the process to a shared memory.
In a further aspect of the disclosure, a system for license sharing in a computing organization comprises means for receiving a request for a license being currently used by a process in execution, means for pausing the execution of the process, and means for releasing the license to a shared pool.
Various aspects of the present disclosure are illustrated by way of example, and not by way of limitation, in the accompanying drawings, wherein:
In accordance with common practice, some of the drawings may be simplified for clarity. Thus, the drawings may not depict all of the components of a given apparatus (e.g., device) or method. Finally, like reference numerals may be used to denote like features throughout the specification and figures.
Various aspects of the invention are described more fully hereinafter with reference to the accompanying drawings. This invention may, however, be embodied in many different forms and should not be construed as limited to any specific structure or function presented throughout this disclosure. Rather, these aspects are provided so that this disclosure will be thorough and complete, and will fully convey the scope of the invention to those skilled in the art. Based on the teachings herein, one skilled in the art should appreciate that the scope of the invention is intended to cover any aspect of the invention disclosed herein, whether implemented independently of or combined with any other aspect of the invention. For example, an apparatus may be implemented or a method may be practiced using any number of the aspects set forth herein. In addition, the scope of the invention is intended to cover such an apparatus or method which is practiced using other structure, functionality, or structure and functionality in addition to or other than the various aspects of the invention set forth herein. It should be understood that any aspect of the invention disclosed herein may be embodied by one or more elements of a claim.
The processing described below may be performed by a computing system which may be a stand alone single or multiple processor computer, or a distributed processing platform. In addition, such processing and functionality can be implemented in the form of special purpose hardware or in the form of software or firmware being run by a general-purpose or network processor. Data handled in such processing or created as a result of such processing can be stored in any type of memory as is conventional in the art. By way of example, such data may be stored in a temporary memory, such as in the RAM of a given computer system or subsystem. In addition, or in the alternative, such data may be stored in longer-term storage devices, for example, magnetic disks, rewritable optical disks, and so on. For purposes of the disclosure herein, a computer-readable media may comprise any form of data storage mechanism, including existing memory technologies as well as hardware or circuit representations of such structures and of such data.
As used herein, the term “distributed system” is intended to include any system which includes two or more components, either computers, machines or other types of processors. Each computer in a distributed system may be, for example, a Symmetric Multiprocessor (SMP) and contain multiple processors. The term “distributed computation” is intended to include any instance of computation that is comprised of two or more processes working in concert to accomplish a computational task. The term “processs” as used herein is intended to include any type of program, instruction, code, or the like which runs on one or more computers or other types of processors in a distributed system.
The processes that comprise a distributed computation may cooperate either through the explicit exchange of messages over an interconnection network, the access and modification of memory regions that are shared by all processes, or some combination thereof. In the present embodiment all processes execute concurrently on distinct separate processors and each process will be illustrated as an OS process. The system and method discussed herein is not limited to such an environment however, and may be utilized regardless of the manner in which instances of computation are realized (e.g., user level threads, kernel level threads, and OS process).
Interconnection network 102 may be, for example, an Internet-based network. One or more processes 120 may be executed on each compute node 104. For example, a process P1 may run on compute node C1, and a process Pn may run on compute node Cn. Each process 120 may be executed, for example, by one or more processors. The compute nodes 104 in the system are also connected to a shared secondary storage facility 110. With respect to secondary storage facility 110, the same file system should be visible to any of the compute nodes 104 that are to be migration targets. In a typical embodiment, shared secondary storage facility 110 is accessible by all compute nodes 104.
Each compute node 104 may include local memory 112 (e.g., dynamic RAM), which may be used, for example, to store user-level applications, communications middleware and an operating system, and may also include local secondary storage device 114 (e.g., a hard drive). Local memory 112 may also be used to store messages, or buffer data. Head node 106 may also include local memory 116 and local secondary storage 118. The compute nodes C1, C2, . . . , Cn may be computers, workstations, or other types of processors, as well as various combinations thereof.
Each of the applications 209 may be any type of computer application program. Each may be adopted to perform a specific function or to perform a variety of functions. Each may be configured to spawn a large number of processes, some or all of which may run simultaneously. Each process may include multiple threads. As used herein, the term “application” may include a plurality of processes or threads. Examples of applications that spawn multiple processes that may run simultaneously include oil and gas simulations, management of enterprise data storage systems, algorithmic trading, automotive crash simulations, and aerodynamic simulations.
The collection of resources 207 may include resources that one or more of the applications 209 use during execution. The collection of resources 207 may also include resources used by the operating systems 206.
The resources may include a memory 213. The memory 213 may be of any type of memory. Random access memory (RAM) is one example. The memory 213 may include caches that are internal to the processors that may be used in the processing systems 203. The memory 213 may be in a single computer or distributed across many computers at separated locations. For example, the memory 213 also includes an alternate medium 215. The alternate medium 215 may include memory in the form of non-volatile memory such as magnetic disc-based media, including hard drives or other mass storage. The alternate medium 215 includes networked-based mass storage as well.
The resources 207 may include support for inter-process communication (IPC) primitives, such as support for open files, network connections, pipes, message queues, shared memory, and semaphores. The resources 207 may be in a single computer or distributed across multiple computer locations.
The runtime libraries 205 may be configured to be linked to one or more of the applications 209 when the applications 209 are executing. The runtime libraries 205 may be of any type, such as I/O libraries and libraries that perform mathematical computations.
The runtime libraries 205 may include one or more libraries 211. Each of the libraries 211 may be configured to intercept calls for resources from a process that is spawned by an application to which the library may be linked, to allocate resources to the process, and to keep track of the resource allocations that are made. The libraries 211 may be configured to perform other functions, including the other functions described herein.
Therefore, referring to
The mechanism of
The mechanism of
The above mechanism has the ability to intercept, record state, and manipulate system calls from the application destined for the operating system as well as handle requests for suspension and resumption. It can manipulate a communication channel at the time of application suspension so that the license server can immediately release the license instance. The license suspension mechanism may use a user level transparent fiamework to record the state of executing jobs. When the license sharing policy dictates that one license is to be suspended and another started or resumed in its place, the embodiment described above may be used to save the states of the executing computations before halting them.
In one aspect of the disclosure, the mechanism of
In another aspect of the disclosure, when a suspend request is received, the application will suspend all threads of executions and all other applicable resources. The mechanism will then close all communication channels between the application and the license server. The remote license server will immediately detect the termination of the communication channel and respond by revoking the licenses leased to the application, freeing them for another application to use. Before finalizing the suspension, the mechanism must ensure that the communication channel stay intact but closed. In most cases, the communication channel refers to a socket so the method must ensure that a valid, yet unconnected, socket remains as a placeholder. This is done by creating a new unconnected socket and placing its file descriptor in the same location as the original socket. Once resumed, the application will detect that this communication channel is an unconnected socket and attempt to reopen communication channel with the license server reacquire the licenses again. The advantage of this method is that the licenses are released on the side of the application and not on that of the license server. The method for suspending the license simulates a temporary network failure that the application has the ability to naturally recover from. This method does not rely on the license vendor's distributed tools or protocol so the limitation on suspending a license immediately after application startup does not apply. This method is transparent to both the application and the license server so it does not require modifications to the environment.
It is understood that any specific order or hierarchy of steps described above is being presented to provide an example of the processes involved. Based upon design preferences, it is understood that the specific order or hierarchy of steps may be rearranged while remaining within the scope of the invention.
The various components that have been described may be comprised of hardware, software, and/or any combination thereof. For example,, the libraries 105, the resource managers 105 system and the applications 109 may be software computer programs containing computer-readable programming instructions and related data files. These software programs may be stored on storage media, such as one or more floppy disks, CDs, DVDs, tapes, hard disks, PROMS, etc. They may also be stored in RAM, including caches, during execution.
One of more of the above components, including the runtime library may be implemented with one or more general purpose processors. A general purpose processor may be a microprocessor, a controller, a microcontroller, a state machine, or any other circuitry that can execute software. Software shall be construed broadly to mean instructions, data, or any combination thereof, whether referred to as software, firmware, middleware, microcode, hardware description language, or otherwise. Software may be stored on machine-readable media which may include being embedded in one or more components such as a DSP or ASIC. Machine-readable media may include various memory components including, by way of example, RAM (Random Access Memory), flash memory, ROM (Read Only Memory), PROM (Programmable Read-Only Memory), EPROM (Erasable Programmable Read-Only Memory), EEPROM (Electrically Erasable Programmable Read-Only Memory), registers, magnetic disks, optical disks, hard drives, or any other suitable storage medium, or any combination thereof. Machine-readable media may also include a transmission line and/or other means for providing software to the computing nodes. The machine readable may be embodied in a computer program product.
Whether the above components are implemented in hardware, software, or a combination thereof will depend upon the particular application and design constraints imposed on the overall system. Skilled artisans may implement the described functionality in varying ways for each particular application, but such implementation decisions should not be interpreted as causing a departure from the scope of the invention.
The previous description is provided to enable any person skilled in the art to practice the various aspects described herein. Various modifications to these aspects will be readily apparent to those skilled in the art, and the generic principles defined herein may be applied to other aspects. Thus, the claims are not intended to be limited to the aspects shown herein, but are to be accorded the full scope consistent with the language of the claims, wherein reference to an element in the singular is not intended to mean “one and only one” unless specifically so stated, but rather “one or more.” Unless specifically stated otherwise, the term “some” refers to one or more. All structural and functional equivalents to the elements of the various aspects described throughout this disclosure that are known or later come to be known to those of ordinary skill in the art are expressly incorporated herein by reference and are intended to be encompassed by the claims. Moreover, nothing disclosed herein is intended to be dedicated to the public regardless of whether such disclosure is explicitly recited in the claims. No claim element is to be construed under the provisions of 35 U.S.C. §112, sixth paragraph, unless the element is expressly recited using the phrase “means for” or, in the case of a method claim, the element is recited using the phrase “step for.”
This application is a non-provisional application claiming benefit under 35 U.S.C. section 119(e) of U.S. Provisional Application Ser. No. 60/987,294, filed Nov. 12, 2007, (titled METHOD FOR TRANSPARENT STATEFUL PREEMPTION OF SOFTWARE SYSTEMS by Varadarajan, et al.), which is hereby incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
60987294 | Nov 2007 | US |