Not Applicable
Not Applicable
A portion of the material in this patent document is subject to copyright protection under the copyright laws of the United States and of other countries. The owner of the copyright rights has no objection to the facsimile reproduction by anyone of the patent document or the patent disclosure, as it appears in the United States Patent and Trademark Office publicly available file or records, but otherwise reserves all copyright rights whatsoever. The copyright owner does not hereby waive any of its rights to have this patent document maintained in secrecy, including without limitation its rights pursuant to 37 C.F.R. § 1.14.
This invention pertains generally to enterprise computer systems, computer networks, embedded computer systems, wireless devices such as cell phones, computer systems, and more particularly to methods, systems and procedures (i.e., programming) for providing application isolation for multiple applications running on a host operating system and live migration of applications within and between isolated environments.
In many environments one of the most important features is to ensure that one running application doesn't affect other running applications, and that the crash of one application doesn't compromise other running applications. In many environments applications share system resources, libraries and hardware, which exposes subtle interconnects between seemingly unrelated applications.
Several approaches have been developed addressing this fundamental problem. The first level of application isolation is provided by the operating system. Modern operating systems such as Linux, UNIX, Windows2000, NT, XP and Vista provide some level of application isolation through the use of processes, and the underlying hardware memory management unit. The use of processes generally ensure than one running application process cannot address memory owned and used by other processes. This first level of isolation does not address the use of shared resources, such as files, file systems, shared memory, and libraries, so other approaches have been developed
In U.S. Pat. No. 6,496,847 Bugnion et al. teach the use of a virtual machine monitor (VMM) with a protected host operating system (HOS). This invention partially solves the isolation problem by placing every application into its own VMM. The solution requires the use of a VMM subsystem and in some cases a customized operating system. U.S. Pat. No. 6,496,847 does not provide isolation at the level of individual applications, but for entire operating systems with all the applications within it. It does not address the problem of application isolation with multiple natively running applications on one host computer.
In U.S. Pat. No. 6,601,081 Provino et al. teach the use of a virtual machine for a plurality of application programs. As with U.S. Pat. No. 6,496,847 the use of a VM subsystem simply moves the problem to a different layer, and does not address the fundamental issue of application isolation with several natively running applications on one host computer.
In U.S. Pat. No. 7,028,305 Schaefer teaches a system for creating an application protection layer to separate an application from the host operating system. Shaefer primarily teaches how to intercept the Windows registry to capture configuration information for Windows application and how to create a virtual operating environment for the application. Access to files is provided via a virtual file system, access to registry information via the virtual registry etc. For Unix and MacOS few specific teachings are presented.
A related challenge to deployment of applications is that a running application generally cannot be moved without first shutting down the application and re-starting it on a new server. The terminate-restart cycle disconnects all users, terminates all sessions, and generally leaves the application services unavailable for some period of time. With the move to “Software as a Service (SaaS)”, “Cloud Computing” or “Hosted Services” software services must be available at all times; anything else is considered unacceptable by customers. Today, service agreements for hosted services generally have penalties associated with any amount of downtime and application being unavailable.
In U.S. Pat. No. 7,213,246 Rietshote et al teach “Failing over a virtual machine” (VM) to a second system. Applications within the VM are failed over along with the entire VM. The failover requires a VM subsystem and does not address the issue of failing over the application without the presence of a virtual machine infrastructure.
In U.S. Ser. No. 11/567,983 Travostino et al teach “seamless live migration of virtual machines across optical networks”. The live migration requires a virtual machine and does not address live migration of the individual applications within the virtual machine or between virtual machines.
In U.S. patent application Ser. Nos. 12/334,654, 12/334,655 and 12/334,657 Havemose et. al (“Havemose”) teach checkpointing of application groups on Linux and the use of checkpointing for failover and live migration. In U.S. patent application Ser. Nos. 12/334,660, 12/334,663, 12/334,666 and 12/334,671Backensto et. al. (“Backensto”) teach checkpointing of application groups on Windows operating systems and the use of checkpointing for failover and live migration. Both of Havemose and Backensto, included by reference above, teach application checkpointing and live migration that work transparently over the underlying operating system without the need of a virtual machine subsystem.
The present invention provides a system and methods to create an application isolation environment where applications can run unmodified, on un-modified operating systems without requiring any virtual environments, virtual machines or virtual machine monitors. The present invention also teaches how to manage and handle applications that share libraries and resources, and how to handle complex multi-process applications. In one embodiment an implementation in the Linux environment is disclosed, in another embodiment an implementation on Windows is disclosed.
Another aspect of the present invention is a system and methods to perform live migration of applications within and between isolated environments without requiring virtual machines, virtual machine monitors or other additional infrastructure.
A method, system, apparatus and/or computer program are disclosed for achieving application isolation and application live migration for single and multi-process applications and their associated resources. The application isolation and application live migration is provided without requiring any changes to the host operating system kernel or requiring any changes to the applications. The application isolation and application live migration is fully transparent to both operating system and application and automatically adjusts for resources such as memory, storage, and CPUs being allocated and released. The application isolation is provided in an interception layer interposed between the individual applications and the operating system and an interception database. Additionally, the application live migration is provided in s shared library pre-loaded into each application during loading and initialization of the application. Preferably, any functional changes to system calls are done exclusively within the interception layer and interception database, and only in the context of the calling application.
Another aspect of the present invention relates to a computer readable medium comprising instructions for application and application group isolation and for application live migration The instructions are for installing the applications into the isolated environment, running the application in the isolated environment, un-installing applications from the isolated environment, configuring the isolated environments, live migrating applications within and between isolated environments, deploying the isolated environments and configuring the isolated environments and live migration
The terms “Windows” and “Microsoft Windows” is utilized herein interchangeably to designate any and all versions of the Microsoft Windows operating systems. By example, and not limitation, this includes Windows XP, Windows Server 2003, Windows NT, Windows Vista, Windows Server 2008, Windows Mobile, and Windows Embedded.
The terms “Linux” and “UNIX” is utilized herein to designate any and all variants of Linux and UNIX. By example, and not limitation, this includes RedHat Linux, Suse Linux, Ubuntu Linux, HPUX (HP UNIX), and Solaris (Sun UNIX).
The term “node” and “host” are utilized herein interchangeably to designate one or more processors running a single instance of an operating system. A virtual machine, such as VMWare or XEN VM instance, is also considered a “node”. Using VM technology, it is possible to have multiple nodes on one physical server.
The terms “application” is utilized to designate a grouping of one or more processes, where each process can consist of one or more threads. Operating systems generally launch an application by creating the application's initial process and letting that initial process run/execute. In the following teachings we often identify the application at launch time with that initial process.
The term “application group” is utilized to designate a grouping of one or more applications.
The terms “checkpointer”, “checkpointing” and “checkpointing service” are utilized herein interchangeably to designate a set of services which 1) capture the entire state of an application and store all or some of the application state locally or remotely, and 2) restore the entire state of the application from said stored application state. The checkpointer may include the following components: dynamic link library (“checkpoint library”), loadable kernel module (“checkpointer kernel module”), a control process to monitor and coordinate an application group, and a merge utility to merge full and incremental checkpoints. The checkpointing services run on all nodes where the application groups run or are configured to run
The terms “checkpoint”, “taking a checkpoint”, and “checkpoint file” are utilized herein interchangeably to describe the data captured by the checkpointing service. Generally, the checkpoint files are written to local disk, remote disk or memory. The terms “checkpoint restore” and “restore from checkpoint” are used interchangeably to describe the process of restoring an application from a checkpoint. The term “checkpoint-terminate” is used to describe the process of taking a checkpoint immediately followed termination of the application by the checkpointer before the application is allowed to run again.
The terms “live migration”, “application live migration”, and “migration” are utilized herein to describe the process of moving a running application from one isolated environment to another, including the isolated environment as necessary. Any clients connected to the running application are preferably unaware that the application is being moved, and are preferably unaffected by the application migration.
The term “fork( )” is used to designate the operating system mechanism used to create a new running process. On Linux, Solaris, and other UNIX variants, a family of fork( ) calls is provided. On Windows, one of the equivalent calls is “CreateProcess( )”. Throughout the rest of this document we use the term “fork” to designate the functionality across all operating systems, not just on Linux/Unix. In general fork( ) makes a copy of the process making the fork( ) call. This means that the newly created process has a copy of the entire address space, including all variables, I/O etc of the parent process.
The term “exec( )” is used to designate the operating system mechanism used to overlay a new image on top of an already existing process. On Linux, Solaris, and other UNIX a family of exec( ) calls is provided. On Windows, the equivalent functionality is provided by e.g. “CreateProcess( )” via parameters. Throughout the rest of this document we use the term “exec” to designate the functionality across all operating systems, not just Linux/Unix. In general, exec( ) overwrites the entire address space of the process calling exec( ). A new process is not created and data, heap and stacks of the calling process are replaced by those of the new process. A few elements are preserved, including but not limited to process-ID, UID, open file descriptors and user-limits.
The term “Barrier” and “Barrier Synchronization” is used herein to designate a type of synchronization method. A Barrier for a group of processes and threads is a point in the execution where all threads and processes must stop at before being allowed to proceed. Barriers are typically implemented using semaphores, mutexes, Locks, Event Objects, or other equivalent system functionality. Barriers are well known in the art and will not be described further here.
In the following we use commonly known terms including but not limited to “process”, “process ID (PID)”, “thread”, “thread ID (TID)”, “thread local storage (TLS)”, “instruction pointer”, “stack”, “kernel”, “kernel module”, “loadable kernel module”, “heap”, “stack”, “files”, “disk”, “CPU”, “CPU registers”, “storage”, “memory”, “memory segments”, “address space”, “semaphore”, “loader”, “system loader”, “system path”, “sockets”, “TCP/IP”, “Inter-process communication (IPC), “Asynchronous Procedure Calls (APC)” and “signal”. These terms are well known in the art and thus will not be described in detail herein.
The term “transport” is utilized to designate the connection, mechanism and/or protocols used for communicating across the distributed application. Examples of transport include TCP/IP, Message Passing Interface (MPI), Myrinet, Fibre Channel, ATM, shared memory, DMA, RDMA, system buses, and custom backplanes. In the following, the term “transport driver” is utilized to designate the implementation of the transport. By way of example, the transport driver for TCP/IP would be the local TCP/IP stack running on the host.
The term “interception” is used to designate the mechanism by which an application re-directs a system call or library call to a new implementation. On Linux and other UNIX variants interception is generally achieved by a combination of LD_PRELOAD, wrapper functions, identically named functions resolved earlier in the load process, and changes to the kernel sys_call_table. On Windows, interception can be achieved by modifying a process' Import Address Table and creating Trampoline functions, as documented by “Detours: Binary Interception of Win32 Functions” by Galen Hunt and Doug Brubacher, Microsoft Research July 1999″. Throughout the rest of this document we use the term interception to designate the functionality across all operating systems.
The term “file context” or “context” is used in relation with file operations to designate all relevant file information. By way of example, and not limitation, this includes file name, directory, read/write/append/execute attributes, buffers and other relevant data as required by the operating system.
The term “transparent” is used herein to designate that no modification to the application is required. In other words, the present invention works directly on the application binary without needing any application customization, source code modifications, recompilation, re-linking, special installation, custom agents, or other extensions.
The terms “private and isolated environment” and “isolated environment” are used herein interchangeably to designate the private area set aside for application isolation, as described in further detail below.
The present invention provides application isolation at several levels: 1) during installation, all installation and registration information is intercepted and installation is re-directed to a private and isolated environment, 2) during launch of an application the installation information is retrieved and provided to the application again via interception, and 3) during access to external resources interception of all access is re-directed as necessary. The combination of all levels of isolation provides for fully transparent application isolation. Thus at all times, access to resources, configuration and run-time information is intercepted and redirected.
By way of example, and not limitation, for embodiments within Windows operating systems, access to the Windows Registry is intercepted and included in the application isolation.
Further aspects of the invention will be brought out in the following portions of the specification, wherein the detailed description is for the purpose of fully disclosing preferred embodiments of the invention without placing limitations thereon.
The invention will be more fully understood by reference to the following drawings which are for illustrative purposes only:
Referring more specifically to the drawings, for illustrative purposes the present invention will be disclosed in relation to
The context in which this invention is disclosed is one or more applications being installed, running and accessing local and remote resources. Without affecting the general case of multiple applications, the following scenarios often depict and describe one or two applications as applicable. Multiple applications are handled in a similar manner.
In a preferred embodiment the interception layer is implemented in a shared library and preloaded as part of the load process.
At times it may be desirable to store some user-data outside the isolated environment, such as on a central file server. In a preferred embodiment, this is supported by specifying which resource locations should remain fixed and public in the global exceptions 64. Such public resources are not translated into the isolated environment.
The Interception Database (IDB) is a system wide database containing mappings between the resources as the application requests them, and their private values inside the isolated environment.
The resource mapping 132 maintains mapping between public resources 134 and the corresponding private and isolated resources 136. The resource mapping 132 also consults the global exceptions 138 prior to translating any public to private or private to public resource requests.
Resources take many forms including but not limited to files, fonts, shared libraries, shared devices, and storage. On Microsoft Windows the Registry is an important component and contains system wide configuration information used by most applications. Some resources, such as data files, tend to be local to the individual applications, while e.g. fonts tend to be shared between multiple applications.
Access to files is handled by the IL (
File, paths and other resource names can be specified both as absolute values or relative values. By way of example, and not limitation, an absolute path for a document file may be “C:\MyDocuments\myfile.doc”, while a relative reference may be “..\docs\myfile.doc”. Absolute references are resolved as previously disclosed by consulting the public resources 134, private resources 136 and global exceptions 138. Relative addresses are resolved in a multi-step process: First relative names are converted to absolute names and then the absolute name is converted as previously disclosed. This mechanism ensures fully transparent support of both absolute and relative naming of all resources.
Fonts pose particular problems, as fonts reside both in application-specific directories and global system directories, such as “C:\Windows\Fonts” on Windows and “/usr/X11R6/lib/X11/fonts/” and “/usr/share/fonts/” on Linux. An application may install font both into one or more global font directories as well as application-specific directories. All shared-fonts directories are included in the Global Exceptions 138 as they should be accessed directly. If during installation additional fonts are installed, they are installed according to the policy chosen by the administrator 126. Prior to installation, the administrator chooses if application-installed fonts are allowed to be placed in the global fonts directory or if they should be placed in the isolated environment. The rules engine 130 consults this administrative choice and upon receiving a request to enumerate the font directory will include isolated-environment fonts if so configured. If the application installs its fonts into its own file structure, the fonts are treated as normal files and are not subject to the automatic enumeration as the application knows where to look for its application-specific fonts.
Modern operating systems share components across multiple applications. Such shared libraries also pose a special case. On Windows Dynamic Link Libraries (DLLs) and on Linux/UNIX shared objects (.so files) are examples of such shared components. On Window shared libraries primarily reside in C:\Windows and C:\Windows\System32, but can sit anywhere. On Linux/Unix the primary locations are ‘/usr/lib’, ‘/usr/X11/lib’ and the entire /usr/lib/directory structure. The loader of the operating system traverses the system PATH to find any requested shared library, but this can be manually or programmatically changed as part of the load process. The PATH is set using environment variables both on Windows and Linux. In order to intercept loading of shares libraries the present invention loads the application in stead of using the system loader directly. This enables interception of library loading done by the loader. If during installation additional shared libraries are installed, they are installed according to the policy chosen by the administrator 126. Prior to installation, the administrator chooses if application-installed libraries are allowed to be placed in a global directory or if they should be placed in the private and isolated environment. If the libraries are placed into the private and isolated environment, the load PATH is adjusted to search the private location.
As with files, libraries can be loaded with both absolute and relative addresses. The load process handles the resource mapping as disclosed above. In all cases, the loading must follow the same path and address resolution as the system loader provides.
If the application installs its shared libraries into its own file structure, the libraries are treated as normal files and are not subject to an adjusted PATH or load-order as the application knows where to look for its application-specific libraries. In the preferred embodiment, if the application installs new shared libraries, they are installed into the isolated environment
One of the most significant sources of application incompatibilities, and one of the motivators for the present invention, is shared library conflict. By way of example, and not limitation, if a shared library is loaded on the system, and a new application installs an older version of the library, the older version may overwrite the newer version and render other applications non-functional based on having their shared library replaced by an incompatible older version. This is a common problem on both the Windows and Linux platforms. Using the preferred embodiment disclosed above, the application would install the older library into its isolated environment and therefore not affect other applications. The application would load and use the older library without ever being aware that it was provided from the isolated environment, and other applications running on the system would be unaffected by the installation of the older library.
Microsoft Windows uses a special configuration system generally referred to as “the Registry”. The registry contains configuration, installation and un-installation information for applications on the system. When an application installs on a Windows system, it uses the registry to store values such as “home directory”, “recent files”, etc. The preferred embodiment on Windows systems additionally include interception of all registry information, and ensures that installation and runtime information that would normally go into the registry, in stead is stored and maintained in the IDB. During installation of a Windows application all registry information is thus stored in the IDB and not the registry. When an application requests registry information, the information is provided from the IDB, and not the registry. This ensures complete application isolation from the registry.
The isolated environment contains all application files and shared resources and their respective mappings. These are all preserved persistently on local or remote storage and can be archived, copied and restored as any other set of files. Specifically, the isolated environment directory structure can be copied to a different node, and used directly to start the application on that node.
So far the Interception database has been described as a “database”. Based on the teachings above, it's readily apparent to anyone skilled in the art, that the only requirement is that updates to the resource tables 134, 136 and 138 be atomic at the record level. This functionality can be readily implemented in a variety of ways, including using Java's ConcurrentHashMap( ), the Windows .NET equivalents, or by custom programming the data structures and locking. Furthermore, preferably concurrent access to the Interception Database translations is provided. In an alternate implementation such a custom interception database is used in stead of a full database.
By way of example, and not limitation, consider an environment with the present invention active. An application 252 calls a write( ) 253 operation. As disclosed in above, the write( ) is intercepted 254 by the interception layer 262. Parameters to the write( ) call are translated by the Interception Database 264 and the rules for the isolated environment 266 and the file context and parameters of the calling write are adjusted to point to the isolated environment. The write call is then forwarded 268 to the system libraries 258 and operating system 260 as were the case with the present invention inactive. The return value 266 from the write is returned to the IL 262 which, using the IDB 264, maps the result back into the original context and returns the value 256 to the caller 253. The application 252 issuing the write 253 operating is thus unaware that the write is being intercepted and re-directed to the isolated environment. All translation and isolation is performed outside the application 252, and before the write operation ever reaches the system libraries 258 or operating system 260.
A specific example, using ANSI C, further illustrates the IL 262 and IDB 264 translations. Consider an example where a file is opened for writing, a small text is written, and the file is closed using the following code
int main(void)
{
char const *pStr=“small text”;
FILE *fp=fopen(“/home/user/newfile.txt”, “w”)
if (fp !=null)
fclose(fp)
}
The call to fopen( ) returns a file pointer, which the fwrite( ) operation uses to write data to the file. The call to fopen( ) includes the file name “/home/user/newfile.txt” as the first parameter. The Interception Layer 262 intercepts the call to fopen( ) and changes the actual filename to the corresponding location in the isolated environment before passing 268 the call on to the system library implementation 258. The following fwrite( ) operation is unaware that the file pointer points to the isolated environment and simply writes the data. Finally, fclose( ) is called to close the file. The file pointer still points to the isolated environment and the close proceeds as a close would without the present invention active.
In a preferred implementation the interception layer is implemented as a shared library and pre-loaded into each application process' address space as part of loading the application. Shared libraries are implemented in such as way that each instance of the interception layer share the same code, but have their own private data, where said private data corresponds to the interception and resource translations undertaken on behalf of the particular application process and its threads. In a multi-process application the interception layer is therefore comprised of one interception layer per application process, and together the process-level interception layers comprise the interception layer. On most diagrams within these disclosures we therefore show one interception layer corresponding to the fact that only one shared library has been loaded, and where necessary point out that each process is being intercepted separately. The application process interception layers are generally referred to as “application process interception layer” on the diagrams.
A related issue with interception is that intercepted functions may call other intercepted functions. As long as said calls are performed using public intercepted names, the previous teachings fully describe the interception. At times shared library developers take shortcuts and don't use the public names, but refer directly to the implementation using a private name. In such cases, the interceptor must overlay a copy of the intercepted shared library code using fully resolved public function names.
In an alternate implementation, a separate application interception layer process is created, and the individual application process interception layers communicate with the application interception layer using sockets, TCP/IP, pipes or other inter-process communication (IPC). This is generally less attractive, as it requires the creation of a separate process and additional communication overhead.
At times multiple applications share data, libraries and work in combination. By way of example, and not limitation, a Microsoft Word document may include or require a Microsoft Excel spreadsheet. In general any number of applications may need to collaborate and share data. So far the approach has been to isolate applications so that, to continue the example, if Word and Excel were installed separately, they would both be isolated and not able to work together. To enable sharing between pre-designated applications, the applications need to be grouped together in an application group and installed inside the same isolated environment.
As taught, the interception layer for an application and the interception layer for an application group work in a similar manner using the same preloaded shared library; hence there is no need to distinguish between the two. In the following, the nomenclature “Interception Layer” is used to designate the interception functionality across both applications and application groups.
The administrator 152 commits the application group to the IDB 150. The IDB uses the same mechanisms as disclosed above for individual applications, and structures the isolated environment 154 so that the individual applications share resources and file system. By installing the applications together they automatically use the same isolated environment and sharing is fully automatic without requiring any additional information. The interception layer 148 intercepts, as previously disclosed, and requires no special configuration; all application group information is contained within the IDB 150 and the settings for the isolated environment 154.
The administrator 176 commits all administrative settings to the IDB 174, which is reflected in the database tables for the isolated environment 178.
At times it may be desirable to run multiple instances of the same application or application group, but in separate isolated environments. Referring again to
The Backensto and Havemose references cited above teach checkpointing of multi-process multi-threaded application groups on Windows and Linux respectively without an isolated environment. The general approach taken include:
Checkpointing of application groups within the isolated environment is complicated by the addition of two new functional components: the interception layer (including the application process interception layers), and the interception database. Generally, the interception layer is contained within the application processes, while the interception database is external. The following teachings incorporate the cited checkpointing references into the present invention.
Application isolation utilizes interception to redirect resource access to the isolated environment. To provide checkpointing in the context of application isolation, the previously disclosed interception mechanism is enhanced to first pass all intercepted functions through the checkpointing library. The checkpointing library operates on the running program on the host operating system, and utilizes interception to capture fork( ) exec( ) memory operations and other resources as disclosed in the two cited references. This is followed by the interception handling for resource mapping related to the isolated environment as disclosed previously.
The checkpointing library is pre-loaded along with the interception layer into the address space of each application process. To keep multiple independent processes coordinated a new component is introduced: the Application Group Control Process (AGCP) responsible for launching the application group, preloading the libraries, initializing and starting the application group. In summary the following additional steps and components are added:
The AGCP furthermore assumes the full functionality of the loader and the custom symbol resolution as disclosed above. AGCP is responsible for all aspects of application launch, termination, installation of interception, loading of checkpointing library, and triggering of checkpointing.
In an embodiment on Linux and UNIX, AGCP triggers the asynchronous checkpoints using signals. In an embodiment on Window, Asynchronous Procedure Calls (APC) are used to trigger the checkpoints.
As part of loading and initializing the application A1, AGCP 284 further creates a dedicated checkpointing thread for each process in the application group.
The Interception database IDB 301 is global to all application groups within the isolated environment. If the IDB 301 has not been loaded, the AGCP 284 launches the IDB 301 prior to the performing the load process disclosed above.
The checkpointer and the isolated environment both need access to all intercepted functions. In general, the checkpointer operates on the running application and utilizes interception to capture resource and their usage. The isolated environment utilizes the interception to re-direct resource usage to the isolated environment. By way of example, and not limitation, when application A1286 reaches function ifunc( ) 293, which is subject the interception, the previously disclosed control flow is adjusted to account for the presence and requirements of the checkpointer. The function ifunc( ) 293 is intercepted 294 and re-directed to the application process interception library 288. At this point ifunc( ) its context and parameters reflect the actual running application process. The intercepted call is first forwarded 296 to the checkpointing library 289, where all relevant stack information is saved, as disclosed in the two cited references. If ifunc( ) changes the process hierarchy, the change is communicated 302 to AGCP 284 in order to have AGCP 284 preload or remove the interceptors as previously disclosed. Control is then returned 297 to the application process interception layer 288. The application process interception layer calls 290 to the Interception Layer (IL) 300. The IL 300 remaps resources using the Interception Database 301 as previously disclosed. Adjusted resources or data are returned 292 to the interceptor and sent back 295 to the calling application process via the return of ifunc( ).
In continuation of the example in section 5 above,
Continuing the example from section 5:
int main(void)
{
char const *pStr=“small text”;
FILE *fp=fopen(“/home/user/newfile.txt”, “w”)
if (fp !=null)
fclose(fp)
}
The call to fopen( ) is intercepted by the application interception layer 330, and passed to the checkpointing library 332. The checkpoint library 332 captures the real resource name (“/home/user/newfile.txt”) and attributes (“w”), as disclosed in the two cited references, and the call returns to the application process interception layer 330 and forwarded to the Interception Layer 338. The interception layer 338 then, as previously disclosed, translates using the IDB 340, the public resource into the corresponding resource in the isolated environment 342. The call to fopen( ) is finally forwarded 344 to the actual implementation in the system libraries 346 and operating system 348. Return values 345 from fopen( ) is returned to the IL 338, translated 340 back into the host environment as appropriate, forwarded 336 to the application process interception layer 330, and ultimately returned to the calling application process 326. The file pointer (FILE *fp) has been created in the host environment by the application 326, intercepted for checkpointing with host-environment settings, and re-directed to the isolated environment by the IL 338 and IDB 340. This ensures that the checkpointer works on the actual executing program, while resource access is redirected under both the application 326 and the checkpointer 332.
The call to fopen( ) is followed by a call to fwrite( ) writing data to disk. Contrary to fopen( ) fwrite( ) operates on a file pointer, and appears host-native to the application and the checkpointer, but was translated by the isolated environment as just disclosed. The checkpointer intercepts the fopen( ) call, but does not need to do modify anything. Likewise, the interception for the isolated environment does not need to modify any of the parameters and lets the fwrite( ) simply write the data.
By way of example, and not limitation, the teachings so far describe two-layer interception: first interception by the application process interception layer followed by interception by the checkpointer. In general, any number of interceptions can be layered in a similar manner. Similarly, a hierarchy of interception is supported by traversing the hierarchy and each time passing arguments and results down and up the hierarchy, as disclosed for the two-layer interception. Most applications use multiple system libraries or other shared libraries all of which are loaded as part of the load process. As previously disclosed, the Application Group Control Process (AGCP) is responsible for loading the application group. The AGCP includes the operating system loader logic, and therefore has access to and knowledge of references to external libraries and is responsible for loading them. The AGCP automatically intercepts all functions in said libraries, building the interception hierarchy automatically without requiring any manual intervention.
Checkpoints are taken in a synchronized manner across all application processes. The synchronization is accomplished using the checkpointing barrier 387. The detailed teachings of checkpointing multi process application groups are provided in the Havemose and Backensto references previously cited. The general checkpointing process is
The checkpoint includes all data within the address space of the application processes, including the application process interception layer, the interception layer and the checkpointing library. This ensures that any in-process interception or resource mapping is fully captured and included in the checkpoint.
By way of example, and not limitation: A1 has intercepted an open( ) call, processed it in the application process interception layer and the checkpointing layer, and is in the middle of processing the resource mapping in the interception layer at the time the barrier is entered. With the entire address space included in the checkpoint, the exact state of all shared library data is captured, including the incomplete resource mappings. If at a later time a restore from checkpoint is issued, everything is brought back in the same state, including the incomplete resource mapping.
In a preferred embodiment, the application checkpoints are stored within the isolated environment. In an alternate embodiment, the application checkpoints are stored outside the environment in a shared location.
In a preferred embodiment, the Interception database 392 is not included in the checkpoints for the individual applications, but is runs as a separate entity. As part of the checkpointing barrier 387 a signal 395 is sent from the barrier to the interception database 392 to persistently store 393 the settings for the application group's isolated environment.
In an alternate implementation where only one application group uses the interception database 392, the interception database is added to the application group, launched by the AGCP 382 and included in the barrier 387 and the checkpoints
The teachings for restoring multi-process, multi-threaded application groups running without an isolated environment are disclosed in the Havemose and Backensto references cited above and included by reference.
The checkpoints for the application group contain all the process and thread hierarchy information, including all environmental information.
All processes and threads within the application A1386, A2388 and A3390 are halted at the barrier 387, corresponding to checkpoint from which they are being restored. All threads and processes are then released from the barrier and the application group proceeds to run.
As the interception layer and the application process interception layer are included in the checkpoint, any in-process resource translation resumes at the exact point where the checkpointing occurred. This ensures consistency across checkpoint and restore.
In a preferred embodiment, the application checkpoints are stored within the isolated environment. When restoring, the checkpoint is available within the isolated environment.
In an alternate embodiment, the application checkpoints are stored outside the environment in a shared storage, typically on networked storage. When restoring, the checkpoint file is first retrieved from the shared storage then used to restore from.
In a preferred embodiment where the interception database 392 is external to the application group, the interception database 392 is reloaded with the settings for the isolated environment 393 while the application group is in the barrier. The settings for the isolated environment were persistently stored 393 as part of the checkpointing barrier.
In an alternate embodiment where the interception database is included in the application group, the interception database is restored along with the application group.
Checkpointing and Live Migration can be triggered in a variety of ways. In general, the trigger can fire at any time and is, from the application group's perspective, therefore asynchronous.
Example triggers include but at not limited to:
One of the major problems with application deployment is the actual installation and the associated risks as disclosed previously. Using the present invention, a pre-created isolated environment can be used in place of performing an actual installation. The isolated environment contains all application files, shared libraries, and installation data and can be moved, copied and run from anywhere the present invention is present.
In an alternate embodiment, the environment 188 is stored on shared storage, and is accessed directly from the shared storage. In this embodiment, the isolated environment is loaded directly from shared storage, and only local data, such as temporary files, are kept locally.
In another embodiment, the environment 188 is saved to storage and shipped to a remote site. The remote site loads the environment and runs the applications directly from within the environment without any installations. In this embodiment the present invention may be used for disaster recovery.
Installation free deployment can be enhanced using the checkpointer to provide “live migration” of running application groups. A “Live Migration” is the process of moving a running application from one environment to another without restarting the application and losing session data. The isolated environment and checkpointing are configured such that the checkpoints are included within the isolated environment. A live migration of an application group is performed with the following steps:
The net effect of checkpoint-terminate followed by a restore from checkpoint, is that the application execution is moved from one isolated environment to another without loss of data. There is no loss of application data, as the application is precluded from running between the checkpoint and the restore, and therefore has not executed any instructions.
In a preferred embodiment, Live Migration may also be used for scale-out. In stead of terminating a just check pointed application group, said application group is left running while a second copy is created using the checkpoint on a new host. After creating the second application group using the modified live migrate, there are two running copies of the same application with identical configuration. Using a front-end load-balancer, incoming traffic is divided between the two application groups with each copy handling approximately half of all sessions. Inactive sessions generally automatically expire.
The administrator 202 provides general configuration information applicable to all isolated environments and applications 203, unless explicitly changed for a particular isolated environment 205. Examples of administrator-provided global configuration information 203 includes, but is not limited to
Each setting can be changed, i.e. replaced, on an application by application basis, and on an application-group by application basis. As determined by the administrator, examples of administrator-provided application-level configuration information 205 include, but is not limited to
The combination of the global configuration information 203 with the rules engine (
In another embodiment the administrative functions 202 is done programmatically using an Application Programming Interface (API).
In the embodiments described herein, an example programming environment was disclosed for which an embodiment of programming according to the invention was taught. It should be appreciated that the present invention can be implemented by one of ordinary skill in the art using different program organizations and structures, different data structures, and of course any desired naming conventions without departing from the teachings herein. In addition, the invention can be ported, or otherwise configured for, use across a wide-range of operating system environments.
Although the description above contains many details, these should not be construed as limiting the scope of the invention but as merely providing illustrations of some of the exemplary embodiments of this invention. Therefore, it will be appreciated that the scope of the present invention fully encompasses other embodiments which may become obvious to those skilled in the art, and that the scope of the present invention is accordingly to be limited by nothing other than the appended claims, in which reference to an element in the singular is not intended to mean “one and only one” unless explicitly so stated, but rather “one or more.” All structural and functional equivalents to the elements of the above-described preferred embodiment that are known to those of ordinary skill in the art are expressly incorporated herein by reference and are intended to be encompassed by the present claims. Moreover, it is not necessary for a device or method to address each and every problem sought to be solved by the present invention, for it to be encompassed by the present claims. Furthermore, no element, component, or method step in the present disclosure is intended to be dedicated to the public regardless of whether the element, component, or method step is explicitly recited in the claims. No claim element herein 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.”
Number | Name | Date | Kind |
---|---|---|---|
5047928 | Wiedemer | Sep 1991 | A |
5155680 | Wiedemer | Oct 1992 | A |
5325290 | Cauffman et al. | Jun 1994 | A |
5386369 | Christiano | Jan 1995 | A |
5553239 | Heath et al. | Sep 1996 | A |
5708709 | Rose | Jan 1998 | A |
5951650 | Bell et al. | Sep 1999 | A |
5996016 | Thalheimer et al. | Nov 1999 | A |
6026499 | Shirakihara et al. | Feb 2000 | A |
6085086 | Porta et al. | Jul 2000 | A |
6144999 | Khalidi et al. | Nov 2000 | A |
6189111 | Alexander et al. | Feb 2001 | B1 |
6269442 | Oberhauser et al. | Jul 2001 | B1 |
6314567 | Oberhauser et al. | Nov 2001 | B1 |
6321275 | McQuistan et al. | Nov 2001 | B1 |
6496847 | Bugnion et al. | Dec 2002 | B1 |
6560626 | Hogle et al. | May 2003 | B1 |
6574618 | Eylon et al. | Jun 2003 | B2 |
6601081 | Provino et al. | Jul 2003 | B1 |
6615217 | Rosensteel, Jr. et al. | Sep 2003 | B2 |
6718538 | Mathiske | Apr 2004 | B1 |
6766314 | Burnett | Jul 2004 | B2 |
6766471 | Meth | Jul 2004 | B2 |
6795966 | Lim et al. | Sep 2004 | B1 |
6918113 | Patel et al. | Jul 2005 | B2 |
6944785 | Gadir et al. | Sep 2005 | B2 |
6954784 | Aiken et al. | Oct 2005 | B2 |
6964034 | Snow | Nov 2005 | B1 |
7028305 | Schaefer | Apr 2006 | B2 |
7043524 | Shah et al. | May 2006 | B2 |
7058696 | Phillips et al. | Jun 2006 | B1 |
7076555 | Orman et al. | Jul 2006 | B1 |
7082551 | Lawrance et al. | Jul 2006 | B2 |
7089294 | Baskey et al. | Aug 2006 | B1 |
7093086 | Rietschote | Aug 2006 | B1 |
7152119 | Na et al. | Dec 2006 | B2 |
7197700 | Honda et al. | Mar 2007 | B2 |
7207039 | Komarla et al. | Apr 2007 | B2 |
7213246 | Rietschote et al. | May 2007 | B1 |
7257811 | Hunt et al. | Aug 2007 | B2 |
7269645 | Goh et al. | Sep 2007 | B2 |
7293200 | Neary et al. | Nov 2007 | B2 |
7363365 | Ocko et al. | Apr 2008 | B2 |
7386855 | Song et al. | Jun 2008 | B2 |
7467370 | Proudler et al. | Dec 2008 | B2 |
7506194 | Appanna et al. | Mar 2009 | B2 |
7509406 | Abdo et al. | Mar 2009 | B2 |
7512815 | Munetoh | Mar 2009 | B1 |
7523344 | Qiao et al. | Apr 2009 | B2 |
7526452 | Agarwal et al. | Apr 2009 | B2 |
7543182 | Branda et al. | Jun 2009 | B2 |
7549042 | Glaum et al. | Jun 2009 | B2 |
7552239 | Jean et al. | Jun 2009 | B2 |
7562220 | Frank et al. | Jul 2009 | B2 |
7613921 | Scaralata | Nov 2009 | B2 |
7627902 | Rive et al. | Dec 2009 | B1 |
7664711 | Agarwal et al. | Feb 2010 | B2 |
7672882 | Agarwal et al. | Mar 2010 | B2 |
7673308 | McMillan et al. | Mar 2010 | B2 |
7680758 | Laborczfalvi et al. | Mar 2010 | B2 |
7681075 | Havemose et al. | Mar 2010 | B2 |
7693835 | Ohta et al. | Apr 2010 | B2 |
7694123 | Prasse et al. | Apr 2010 | B2 |
7711847 | Dhupelia et al. | May 2010 | B2 |
7716240 | Lim | May 2010 | B2 |
7751311 | Ramaiah et al. | Jul 2010 | B2 |
7761573 | Travostino et al. | Jul 2010 | B2 |
7770169 | Fresko et al. | Aug 2010 | B2 |
7774636 | Rao et al. | Aug 2010 | B2 |
7801135 | Appanna et al. | Sep 2010 | B2 |
7877781 | Lim | Jan 2011 | B2 |
7945688 | Lango et al. | May 2011 | B1 |
8019860 | Ivanov et al. | Sep 2011 | B2 |
8024815 | Lorch et al. | Sep 2011 | B2 |
8095662 | Lappas et al. | Jan 2012 | B1 |
8104085 | Fresko et al. | Jan 2012 | B2 |
8108429 | Sim-Tang et al. | Jan 2012 | B2 |
8108722 | Havemose et al. | Jan 2012 | B1 |
8122280 | Ngan et al. | Feb 2012 | B2 |
8171483 | Nord et al. | May 2012 | B2 |
8176364 | Havemose | May 2012 | B1 |
8191001 | Wie et al. | May 2012 | B2 |
8195722 | Havemose et al. | Jun 2012 | B1 |
8281317 | Backensto et al. | Oct 2012 | B1 |
8307177 | Prahlad et al. | Nov 2012 | B2 |
8831995 | Holler et al. | Sep 2014 | B2 |
10212147 | Buendgen et al. | Feb 2019 | B2 |
20020056004 | Smith et al. | May 2002 | A1 |
20020065945 | Calder et al. | May 2002 | A1 |
20020091763 | Shah et al. | Jul 2002 | A1 |
20020109718 | Mansour et al. | Aug 2002 | A1 |
20020111995 | Mansour et al. | Aug 2002 | A1 |
20020129096 | Mansour et al. | Sep 2002 | A1 |
20020152382 | Xiao | Oct 2002 | A1 |
20020157089 | Patel et al. | Oct 2002 | A1 |
20020161826 | Arteaga et al. | Oct 2002 | A1 |
20020161908 | Benitez et al. | Oct 2002 | A1 |
20020174265 | Schmidt | Nov 2002 | A1 |
20030004882 | Holler et al. | Jan 2003 | A1 |
20030009538 | Shah et al. | Jan 2003 | A1 |
20030056200 | Li et al. | Mar 2003 | A1 |
20030074580 | Knouse et al. | Apr 2003 | A1 |
20030120593 | Bansal et al. | Jun 2003 | A1 |
20030236906 | Klemets et al. | Dec 2003 | A1 |
20040003101 | Roth et al. | Jan 2004 | A1 |
20040055004 | Sun et al. | Mar 2004 | A1 |
20040083369 | Erlingsson et al. | Apr 2004 | A1 |
20040153700 | Nixon et al. | Aug 2004 | A1 |
20040167984 | Herrmann | Aug 2004 | A1 |
20040267645 | Pollari | Dec 2004 | A1 |
20050071824 | N. et al. | Mar 2005 | A1 |
20050172082 | Liu et al. | Aug 2005 | A1 |
20050193139 | Vinson et al. | Sep 2005 | A1 |
20050216415 | Stefik et al. | Sep 2005 | A1 |
20060015764 | Ocko et al. | Jan 2006 | A1 |
20060031547 | Tsui et al. | Feb 2006 | A1 |
20060053228 | Rachman et al. | Mar 2006 | A1 |
20060069692 | Pemia | Mar 2006 | A1 |
20060075381 | Laborczfalvi et al. | Apr 2006 | A1 |
20060156403 | Haeffele et al. | Jul 2006 | A1 |
20060177010 | Skakkebaek et al. | Aug 2006 | A1 |
20060177023 | Vaghar et al. | Aug 2006 | A1 |
20060206873 | Argade | Sep 2006 | A1 |
20060277305 | Bernardin et al. | Dec 2006 | A1 |
20060294235 | Joseph | Dec 2006 | A1 |
20070007336 | Kindberg | Jan 2007 | A1 |
20070028110 | Brennan | Feb 2007 | A1 |
20070028302 | Brennan et al. | Feb 2007 | A1 |
20070028303 | Brennan | Feb 2007 | A1 |
20070028304 | Brennan | Feb 2007 | A1 |
20070083501 | Pedersen et al. | Apr 2007 | A1 |
20070083522 | Nord et al. | Apr 2007 | A1 |
20070083610 | Trader et al. | Apr 2007 | A1 |
20070083655 | Pedersen | Apr 2007 | A1 |
20070101124 | Pitts | May 2007 | A1 |
20070150584 | Srinivasan | Jun 2007 | A1 |
20070171921 | Wookey et al. | Jul 2007 | A1 |
20070192518 | Rupanagunta et al. | Aug 2007 | A1 |
20070244987 | Pedersen et al. | Oct 2007 | A1 |
20070245334 | Nieh et al. | Oct 2007 | A1 |
20070248085 | Volpano | Oct 2007 | A1 |
20070277056 | Varadarajan et al. | Nov 2007 | A1 |
20070294578 | Qiao et al. | Dec 2007 | A1 |
20080028086 | Chetuparambil et al. | Jan 2008 | A1 |
20080098006 | Pedersen et al. | Apr 2008 | A1 |
20080133764 | Agarwal et al. | Jun 2008 | A1 |
20080184218 | Largman et al. | Jul 2008 | A1 |
20080195824 | Sadovsky et al. | Aug 2008 | A1 |
20080235119 | Agarwal et al. | Sep 2008 | A1 |
20080295114 | Argade et al. | Nov 2008 | A1 |
20090028576 | Elahmadi et al. | Jan 2009 | A1 |
20090089406 | Roush et al. | Apr 2009 | A1 |
20090100420 | Sapuntzakis et al. | Apr 2009 | A1 |
20090106256 | Safari et al. | Apr 2009 | A1 |
20090106424 | Safari et al. | Apr 2009 | A1 |
20090106780 | Nord et al. | Apr 2009 | A1 |
20090133013 | Criddle et al. | May 2009 | A1 |
20090150885 | Safari et al. | Jun 2009 | A1 |
20090164994 | Vasilevsky et al. | Jun 2009 | A1 |
20090199175 | Keller et al. | Aug 2009 | A1 |
20090199177 | Edwards et al. | Aug 2009 | A1 |
20090228576 | Rosenan et al. | Sep 2009 | A1 |
20090235191 | Garbow et al. | Sep 2009 | A1 |
20090241108 | Edwards et al. | Sep 2009 | A1 |
20090254900 | Nakamura | Oct 2009 | A1 |
20090292654 | Katiyar et al. | Nov 2009 | A1 |
20090300032 | Chirlian et al. | Dec 2009 | A1 |
20090300605 | Edwards et al. | Dec 2009 | A1 |
20090310663 | Menon et al. | Dec 2009 | A1 |
20090313363 | Parsons et al. | Dec 2009 | A1 |
20100023996 | Sabin et al. | Jan 2010 | A1 |
20100031325 | Maigne et al. | Feb 2010 | A1 |
20100037232 | Lee et al. | Feb 2010 | A1 |
20100057833 | DeHaan | Mar 2010 | A1 |
20100057890 | DeHaan | Mar 2010 | A1 |
20100071035 | Budko et al. | Mar 2010 | A1 |
20100088699 | Sasaki | Apr 2010 | A1 |
20100107158 | Chen et al. | Apr 2010 | A1 |
20100118324 | Tagawa | May 2010 | A1 |
20100235433 | Ansari et al. | Sep 2010 | A1 |
20110107406 | Frost et al. | May 2011 | A1 |
20110119748 | Edwards et al. | May 2011 | A1 |
20110126192 | Frost et al. | May 2011 | A1 |
20110191414 | Ma et al. | Aug 2011 | A1 |
20110208908 | Chou et al. | Aug 2011 | A1 |
20120054486 | Lakkavalli et al. | Mar 2012 | A1 |
20120084394 | Yeates et al. | Apr 2012 | A1 |
20120088470 | Raleigh | Apr 2012 | A1 |
20150235015 | Holler et al. | Aug 2015 | A1 |
Entry |
---|
Zhao et al. “Experimental Study of Virtual Machine Migration in Support of Reservation of Cluster Resources”, 2007. |
Number | Date | Country | |
---|---|---|---|
Parent | 16006103 | Jun 2018 | US |
Child | 16709856 | US | |
Parent | 15201956 | Jul 2016 | US |
Child | 16006103 | US | |
Parent | 14606093 | Jan 2015 | US |
Child | 15201956 | US | |
Parent | 13862979 | Apr 2013 | US |
Child | 14606093 | US | |
Parent | 12813618 | Jun 2010 | US |
Child | 13862979 | US | |
Parent | 12421691 | Apr 2009 | US |
Child | 12813618 | US |