1. Field of the Invention
The present invention generally relates to a system for monitoring an operating system. More specifically, a monitor mechanism based on a pseudo filesystem, using standard filesystem interfaces and a file tree representation, takes event requests from event consumers and forwards them to the producers, receives event occurrence information from the event producers, and notifies the event consumers of this information, eliminating the need for periodic polling and specialized monitoring APIs.
2. Description of the Related Art
System administrators in large data centers typically monitor the health of an operating system (OS) running on a computer server with centralized monitoring applications. Such a centralized monitoring application typically has an agent that runs in each OS instance and typically does periodic polling to collect OS-health related data. This data is then analyzed by either the central application, or by the agent in the monitored OS itself, which typically relays the information to the central application. Whenever had health in a monitored-OS is detected, the central monitoring application generates an event to the system administrator. In the simple case, this event can cause a notification (e.g. email) to be sent to the administrator, or in a more sophisticated case, a corrective action can be taken (e.g. the execution of a specified program).
There are two major problems with the periodic polling approach of existing OS-health monitoring applications:
To address the above problems, several non-polling event notification methods have been proposed in the past, each requiring the application to use a specialized monitoring API (Application Programming Interface) to register its interest in being notified of an event and to get more details on an event after the event has occurred.
The problem with specialized monitoring APIs are that language bindings have to be developed and maintained for most of the predominant languages used for system management applications, and there are many of these languages, e.g., Perl, C, C++, Java, Python, etc. The complexity of having to maintain a specialized API over multiple versions of the OS, and over multiple languages in an OS version, and over multiple versions of each language that are supported within one OS version, often deters the use of these specialized APIs by existing systems management tools.
Thus, in view of these problems with polling and specialized APIs, a need exists for a more efficient method of monitoring the health of operating systems, preferably using a method that does not require polling and does not use specialized APIs.
In view of the foregoing, and other, exemplary problems, drawbacks, and disadvantages of the conventional systems, it is an exemplary feature of the present invention to provide a method (and structure) for monitoring the health of an operating system without using periodic polling.
It is another exemplary feature of the present invention to provide OS monitoring without using a specialized monitoring API.
Therefore, an exemplary objective of this invention is to provide an event notification mechanism that is efficient and flexible and does not require polling.
Another exemplary objective of the invention is to provide an event notification mechanism that can be used by a wide variety of applications, using standard filesystem APIs, and without introducing a new and additional set of specialized APIs.
To achieve the above exemplary features and objectives, in a first exemplary aspect of the present invention, described herein is an apparatus including a central processing unit (CPU); and a memory including instructions for an event notification mechanism in an operating system (OS) being executed by the CPU, the OS event notification mechanism including a standard filesystem interfaces for event consumers to use for one or more of: registering for an event notification; receiving an event notification when each event occurs; and getting details of an event that has occurred.
In a second exemplary aspect of the present invention, also described herein is a method of notifying operating system events, including providing standard filesystem interfaces for event consumers to use for one or more of: registering for an event notification; receiving an event notification when each event occurs; and getting details of an event that has occurred.
In a third exemplary aspect of the present invention, also described herein is a machine-readable medium tangibly embodying a program of machine-readable instructions executable by a digital processing apparatus to perform the above-described method of notifying operating system events.
In a fourth exemplary aspect of the present invention, also described herein is a network including a first computer operating an operating system including a method of notifying operating system events by the above-described method and a second computer receiving the event notifications.
In a fifth exemplary aspect of the present invention, also described herein is a service including at least one of monitoring a health of an operating system of a computer, debugging a problem of said computer, and developing software solutions for the operating system or a program executed by the operating system, wherein the monitoring, debugging, or developing includes receiving event notifications of said operating system using the notification mechanism based on the above-described method.
As will be clearer from the following description, the present invention provides a number of advantages, including that of providing far more useful information than existing software and being directly usable by any monitoring software that supports fileSystem interfaces, (e.g., open( ), write( ), select( ), read( ), close( ), . . . ). It also more effectively monitors time-critical events so that prompt response-actions can be taken before the system is doomed.
The present invention also achieves low overhead by using select( ) call notification, instead of periodic polling by all the users, as well as providing flexibility because multiple consumers can monitor the same event, each with a different threshold value, without linearly increasing the overhead on the OS. Moreover, multiple applications can benefit from the present invention, including the integration into debugging tools to provide more sophisticated debugging capabilities to software developers.
The foregoing and other exemplary purposes, aspects and advantages will be better understood from the following detailed description of an exemplary embodiment of the invention with reference to the drawings, in which:
Referring now to the drawings, and more particularly to
As mentioned above, this disclosure describes a novel efficient and flexible mechanism and infrastructure to monitor OS events and to notify users asynchronously upon occurrences of their registered events, without requiring polling, and without requiring the need to create a new specialized API. This mechanism is intended to be used in monitoring applications that are written in any of the current predominant system management languages, such as Perl, PHP Python, Java, C, C++, etc.
To eliminate the problems associated with periodic polling and those associated developing a new specialized API, the present invention describes a novel, efficient, and flexible mechanism and infrastructure to monitor OS events and to notify users asynchronously upon occurrences of their registered events, without requiring polling, and without requiring the need to create a new specialized API. This mechanism can be used in monitoring applications that are written in any of the predominant monitoring languages, as listed above.
Specifically, the mechanism of the present invention is exemplarily based on the ubiquitous and standard filesystem APIs (e.g., open( ) write( ) select( ) read( ) close( ) etc.) that are used for accessing files and filesystems.
It is noted that the standard file system interfaces are well defined and well-known. For example, they are part of the POSIX.1 specification (POSIX stands for Portable Operating Systems Interface) developed by the Open Group consortium whose members include IBM, HP and SUN. This specification is also known as IEEE standard 1003.1, although it is noted that this standard covers a lot more Operating System services than just file system related services. One can see this standard at the “single_unix_specification” website.
However, it is also noted that the present invention is not intended as confined to this one operating system specification or the exemplary embodiments described herein. Rather, it is intended that the terminology “standard filesystem interface” refers to filesystem interfaces that are commonly available in the operating system environment of interest without resorting to specialized interfaces developed specifically for the purpose of OS monitoring.
In more details, this invention includes a FileSystem (FS), which is herein referred to as the /aha filesystem (AHAFS for short), to be used by monitoring applications. AHAFS is an acronym for Autonomic Health Advisor FileSystem.
This filesystem will present various system event-producers in the Operating System (OS) as special directories, referred to herein as “monitor factory directories”, under the root directory /aha (e.g., see
The following sequence of actions describes how the event notification exemplarily occurs at a high level:
The above steps and an exemplary applicable environment are described in more details below.
Major components in an exemplary typical operating system (OS) are depicted in the schematic 100 of
These system calls will change the privilege level of the applications from user mode (lower privilege level) to kernel mode (higher privilege level) when they execute the services provided by the kernel. The FS system calls are a set of system calls that are provided by the LFS layer 114. Examples of FS system calls are open( ), close( ), read( ), write( ), select( ), seek( ), etc. It is noted that these FS system calls are well known in the art.
In the present invention, when an application issues a FS system call on a file, the LFS layer will identify the Physical Filesystem (PFS) corresponding to that file and invokes operations on that PFS. The operations are provided by the called virtual node (vnode) operations and Virtual FileSystem (VFS) operations.
It is noted that the terms “vnode operations” and “vfs operations” are part of the standard file system terminology in the Unix operating systems. The term “virtual”, in this context, implies that there is a level of indirection between the applications accessing the physical file system and the kernel/kernel extensions that provide the physical file system. The present invention, as implemented on Unix and like any other file system, will also be accessed via the vnode and vfs operations. The present invention (AHAFS) appears to the operating system as a PFS and presents itself as a file tree to the monitoring applications, as illustrated in
This exemplary implementation is flexible and enables enhanced organization or house-keeping by allowing several intermediate subdirectories to be created between the /aha directory and the monitor factory nodes. Underneath each monitor factory node there can be one or more monitor nodes. Each monitor node represents a unique event that can be monitored by the event producer, which can send notifications to the consumers.
Referring to
The event producers reside in any of various subsystems of the kernel 335: Scheduler 111, VMM 112, I/O subsystem 113, Logical Filesystem 114, etc. Thus, each subsystem can contain zero or more event producers. Though it is not discussed in the current embodiment, the event producers can reside in a kernel extension 335 also. When a kernel extension contains an event producer, it informs the availability of that event producer to the kernel when it is initialized.
The monitoring applications 301, 302, . . . , in the user space 333 will communicate with the AHAFS module 330 via the standard filesystem interfaces 332 available in the form of system call services 310. The system call services will, in turn, invoke the AHAFS services via virtual node (vnode) operations 311 and virtual filesystem (vfs) operations 312. The order of the invocation of services and the specific service invoked in each stage are given in later figures as exemplary flow charts and described in more detail in the following paragraphs.
The AHAFS module 330 communicates with the Event Producers using a separate registration function for each event producer, determined at the time of initializing the AHAFS module. The event producers communicate with the AHAFS module via callback functions given in the registration functions. The details of what information is exchanged between the AHAFS module and the event producers are specific to each event producer.
In step 403, AHAFS' vmount service will check the correctness of the parameters, and performs the initialization of the AHAFS. This initialization involves identifying the event producers in the kernel, allocating memory for the data structures, and setting the function pointers and fields in several data structures. Once the mount operation is successfully completed, the event consumers can use the AHAFS to register for event notifications.
In step 501, a monitoring application registers for an event by issuing an open( ) on the corresponding .mon file.
In step 502, the OS's logical filesystem layer will notify AHAFS about the open request via a vnode operation interface.
In step 503, AHAFS will create the file, if it does not already exist, and increment the reference count.
In step 504, the system call of the logical filesystem will return a file descriptor corresponding to the opened file to the consumer application.
The event consumer then writes an event-specific value into the file using the write( ) system call in step 505. This value can be an integer, floating point, string or a combination, depending on the type of the event.
In step 506, AHAFS gets the contents of the write buffer and interprets the contents according to the event type. For example, if the event is to notify the event consumer whenever a filesystem utilization crosses a threshold, then the value in the write buffer is interpreted as an integer. Once the write buffer is parsed, AHAFS stores the contents into its internal data structures. AHAFS does not pass on the event request to the event producer until the event consumer makes the select( ) system call.
In step 507, the event consumer calls the select( ) interface with the file descriptor it received from the previous open( ) call, to inform AHAFS to start monitoring the event.
In step 508, AHAFS receives the select( ) call and decides whether to forward the event request (step 509) immediately or to keep it in its inventory of event notification requests. AHAFS will not forward the request immediately if it has already sent an event request from another consumer to the event producer. In this exemplary embodiment, at any given point in time, an event producer has at most one event request for a given event instance.
When AHAFS sends an event request to the event producer, it will also pass a callback function address along with the event request, so that, when the event occurs, the event producer can inform AHAFS by invoking the callback function. Some event producers can inform AHAFS if the event condition has already been met, using the return value. If the event condition is already met, then the event consumers will be notified (step 511).
In step 602, the event producer informs AHAFS of the event details using the callback function provided earlier.
When AHAFS receives the event details, it identifies the list of event consumers that need to be notified in step 603. Note that there may be more than one event consumer that needs to be notified. AHAFS forwards only one request to the event producer and keeps the remaining consumers in its own queue. Also, depending on the event type, not all event consumers that have registered for an event need to get notification for a given event occurrence.
As an illustration, if the event producer is utilFs (i.e. triggering an event whenever the utilization of a filesystem crosses a consumer-specified threshold) and the current utilization is 90%, then only those event consumers which have registered for thresholds greater than or equal to 90% should be notified. So, when the event producer invokes the callback function, AHAFS will search through its queue to identify all the consumers that need to be notified as a result of this event occurrence (90% full). For each of the identified consumers, AHAFS prepares the data area so that the next read( ) operation by those consumers will provide them with the event's details.
In step 604, AHAFS then notifies each of the identified event consumers.
In step 605, AHAFS checks its queue to see if there are remaining event consumers, and if there are, AHAFS will re-register the event at the event producer.
Another advantage of using filesystem interfaces between the event consumers and AHAFS is that the cleanup is easy in case of abnormal termination of the event consumers, as exemplarily shown in the flowchart 700 of
When an event consumer terminates abnormally, as shown in step 701, the OS notifies AHAFS via the close( ) vnode operation in step 702 that a file descriptor needs to be closed
In step 703, AHAFS will identify the consumer process and will check if this consumer process has an event registration at the event producer. If it has, and if this process is the only event consumer, then AHAFS will recall that registration. If there are one or more other consumers registered for the event after the current consumer has closed the file descriptor, then AHAFS will re-register the event with the event producer with appropriate parameters.
In step 704, if there are no remaining event consumers for this event after removing the current consumer, then AHAFS will free up its own data areas maintained for the monitor node.
Taking the above descriptions as guidelines, an exemplary embodiment of the present invention might include a method of monitoring an operating system by providing standard filesystem interfaces for event consumers to use for one or more of registering for event notifications of a set of events, receiving vent notification when each event occurs, and getting details of events that have occurred. The embodiment could also include a file tree representation of a list of events available for the event notifications, as illustrated in
The exemplary embodiment could further include providing a registration function and a callback function to the pseudo filesystem from an event producer for event consumers to get notifications when an event occurs.
As shown in the Unix-based example of
In the Unix-based example, the predetermined directory name extension is “.monFactory” and the predetermined filename extension is “.mon”, but other conventions could be used.
In an exemplary embodiment, the standard filesystem interfaces could include one or more of an interface to obtain a handle to a monitor node corresponding to an event instance, an interface to indicate event triggering criteria specific to an event type, an interface to wait until an event occurs, an interface to read an event's specific details after the event has occurred, and an interface to release a handle to the monitor node corresponding to an event instance.
As examples, the interface to obtain a handle to a monitor node corresponding to an event instance could be the open( ) interface, the interface to indicate event triggering criteria specific to an event type could be the write( ) interface, the interface to wait until an event occurs could be the select( ) interface, the interface to read an event's specific details after the event has occurred could be the read( ) interface, and the interface to release a handle to the monitor node corresponding to an event instance could be the close( ) interface.
Even though the system has exemplarily been implemented using the file system interfaces exemplary listed above, this listing and examples are not limiting. Other examples of standard file system interfaces might include, for example, poll( ) instead of select( ), or ioctl( ) instead of read( )/write( ) to achieve the same result. Other file system interfaces might include setattr, getattr, etc.
The pseudo filesystem could also include one or more of a facility to aggregate multiple event requests from multiple event consumers into one request to the event producer, a mechanism to provide non-destructive reads to the event consumers, and a mechanism to provide a stack trace of a program that caused an event to be triggered.
Exemplary Hardware Implementation
The CPUs 811 in
In addition to the hardware/software environment described above, a different aspect of the invention includes a computer-implemented method for performing the above method. As an example, this method may be implemented in the particular environment discussed above.
Such a method may be implemented, for example, by operating a computer, as embodied by a digital data processing apparatus, to execute a sequence of machine-readable instructions. These instructions may reside in various types of signal-bearing media.
Thus, this aspect of the present invention is directed to a programmed product, comprising signal-bearing media tangibly embodying a program of machine-readable instructions executable by a digital data processor incorporating the CPU 411 and hardware above, to perform the method of the invention.
This signal-bearing media may include, for example, a RAM contained within the CPU 811, as represented by the fast-access storage for example. Alternatively, the instructions may be contained in another signal-bearing media, such as a magnetic data storage diskette 900 (
Whether contained in the diskette 900, the computer/CPU 811, or elsewhere, the instructions may be stored on a variety of machine-readable data storage media or other computer program products, such as DASD storage (e.g., a conventional “hard drive” or a RAID array), magnetic tape, electronic read-only memory (e.g., ROM, EPROM, or EEPROM), an optical storage device (e.g. CD-ROM, WORM, DVD, digital optical tape, etc.), paper “punch” cards, or other suitable signal-bearing media including storage devices for transmission by digital and analog and communication links and wireless. In an illustrative embodiment of the invention, the machine-readable instructions may comprise software object code.
Exemplary Software Implementation
The file system part of this invention can be either pre-implemented into the OS or can be added on later after the OS has booted. As mentioned above, currently this invention has been implemented as a kernel extension in the IBM AIX operating system. Kernel extension in AIX is analogous to a dynamically loadable module in other OSs. The event producers part of this invention have to be built into the OS. If there are no event producers available, then adding a file system to expose the OS-events to the applications is of no use.
If not already incorporated into an OS from original development, the present invention has to be implemented for each OS that will be using it. It is noted at this point, that, although the above exemplary description has been restricted to kernel mode event producers, one who is skilled in the art, particularly in operating systems, can easily extend this embodiment to also monitor events occurring in the user space. Therefore, this exemplary embodiment is not intended as limiting the scope of the invention.
However, the invention can also be distributed as a software package that a system administrator can install so that the monitoring applications can use it thereafter. Alternatively, the present invention could be incorporated into debugging tools to provide more sophisticated debugging capabilities to software developers.
It is noted that the software package exemplarily shown in
The Services Aspect
In yet another aspect of the present invention, since the method permits a monitoring of an operating system, or debugging of either the operating system or an application program riding on top of the operating system, or developing software wherein monitoring of the operating system provides a development tool, there is also the opportunity to utilize the present invention as a component in business or providing a service to other entities. Non-limiting examples include, for example, providing an operating system monitoring service on a network, including the potential to intervene in a timely manner, by receiving the event notifications discussed above.
Conclusion
From the above description, it should be clear that there are a number of benefits of the present invention (AHAFS). Several exemplary and non-limiting advantages of AHAFS include:
While the invention has been described in terms of exemplary embodiments, those skilled in the art will recognize that the invention can be practiced with modification within the spirit and scope of the appended claims.
Further, it is noted that, Applicants' intent is to encompass equivalents of all claim elements, even if amended later during prosecution.
This Application is a Continuation Application of U.S. patent application Ser. No. 12/023,185, filed on Jan. 31, 2008, now U.S. Pat. No. 8,201,029.
Number | Name | Date | Kind |
---|---|---|---|
4713656 | Cliff et al. | Dec 1987 | A |
5355484 | Record et al. | Oct 1994 | A |
5805886 | Skarbo et al. | Sep 1998 | A |
5828882 | Hinckley | Oct 1998 | A |
6199179 | Kaufman et al. | Mar 2001 | B1 |
6216132 | Chandra et al. | Apr 2001 | B1 |
6256646 | Starek et al. | Jul 2001 | B1 |
6266716 | Wilson et al. | Jul 2001 | B1 |
6349355 | Draves et al. | Feb 2002 | B1 |
6460107 | Rao et al. | Oct 2002 | B1 |
6505245 | North et al. | Jan 2003 | B1 |
6549916 | Sedlar | Apr 2003 | B1 |
6598169 | Warwick et al. | Jul 2003 | B1 |
6629139 | Kennedy | Sep 2003 | B1 |
6718482 | Sato et al. | Apr 2004 | B2 |
6728715 | Astley et al. | Apr 2004 | B1 |
6754664 | Bush | Jun 2004 | B1 |
6829639 | Lawson et al. | Dec 2004 | B1 |
6910070 | Mishra et al. | Jun 2005 | B1 |
6910160 | Bajoria et al. | Jun 2005 | B2 |
7000150 | Zunino et al. | Feb 2006 | B1 |
7028229 | McGuire et al. | Apr 2006 | B2 |
7099799 | Huard | Aug 2006 | B2 |
7107497 | McGuire et al. | Sep 2006 | B2 |
7117388 | Arimilli et al. | Oct 2006 | B2 |
7117501 | Rosu et al. | Oct 2006 | B2 |
7260752 | Linam et al. | Aug 2007 | B2 |
7263632 | Ritz et al. | Aug 2007 | B2 |
7302613 | Bliss et al. | Nov 2007 | B2 |
7321942 | Flautner et al. | Jan 2008 | B2 |
7437375 | Borthakur et al. | Oct 2008 | B2 |
7472067 | Mathur et al. | Dec 2008 | B2 |
7539986 | Grobman | May 2009 | B2 |
7543187 | Madan | Jun 2009 | B1 |
7558986 | Abe | Jul 2009 | B2 |
7577722 | Khandekar et al. | Aug 2009 | B1 |
7596791 | Wei et al. | Sep 2009 | B2 |
7702693 | Aiyagari et al. | Apr 2010 | B1 |
7730359 | Clarke | Jun 2010 | B2 |
7734945 | Levidow et al. | Jun 2010 | B1 |
7844866 | Austen et al. | Nov 2010 | B2 |
8341648 | Cook | Dec 2012 | B1 |
8341649 | Freericks et al. | Dec 2012 | B2 |
8424002 | Akamatsu et al. | Apr 2013 | B2 |
8694625 | Jennings et al. | Apr 2014 | B2 |
20020035649 | Korn et al. | Mar 2002 | A1 |
20020059380 | Billris et al. | May 2002 | A1 |
20020089526 | Buxton et al. | Jul 2002 | A1 |
20020120884 | Nakamikawa et al. | Aug 2002 | A1 |
20020124165 | Smith et al. | Sep 2002 | A1 |
20020124215 | Austen et al. | Sep 2002 | A1 |
20020129110 | Liu et al. | Sep 2002 | A1 |
20020183972 | Enck et al. | Dec 2002 | A1 |
20030070114 | Yasuda | Apr 2003 | A1 |
20030074601 | Schultz et al. | Apr 2003 | A1 |
20030126202 | Watt | Jul 2003 | A1 |
20030131039 | Bajoria et al. | Jul 2003 | A1 |
20030204780 | Dawkins et al. | Oct 2003 | A1 |
20030225840 | Glassco et al. | Dec 2003 | A1 |
20030233634 | Carrez et al. | Dec 2003 | A1 |
20040064759 | McGuire et al. | Apr 2004 | A1 |
20040088716 | Solter et al. | May 2004 | A1 |
20040119736 | Chen et al. | Jun 2004 | A1 |
20040153834 | Oshima et al. | Aug 2004 | A1 |
20040216137 | Warwick et al. | Oct 2004 | A1 |
20040249853 | Cohen et al. | Dec 2004 | A1 |
20050081212 | Goud et al. | Apr 2005 | A1 |
20050086491 | Haugh et al. | Apr 2005 | A1 |
20050091354 | Lowell et al. | Apr 2005 | A1 |
20050097228 | Flautner et al. | May 2005 | A1 |
20050172279 | Cook et al. | Aug 2005 | A1 |
20050204199 | Harper et al. | Sep 2005 | A1 |
20050235007 | Abali et al. | Oct 2005 | A1 |
20060005085 | Zunino et al. | Jan 2006 | A1 |
20060070083 | Brunswig et al. | Mar 2006 | A1 |
20060075171 | Wei | Apr 2006 | A1 |
20060085792 | Traut | Apr 2006 | A1 |
20060136720 | Armstrong et al. | Jun 2006 | A1 |
20060150203 | Bendapudi et al. | Jul 2006 | A1 |
20060200701 | Callender | Sep 2006 | A1 |
20060242651 | Zielinski et al. | Oct 2006 | A1 |
20060265508 | Angel et al. | Nov 2006 | A1 |
20060271676 | Talayco et al. | Nov 2006 | A1 |
20070016914 | Yeap | Jan 2007 | A1 |
20070073751 | Morris et al. | Mar 2007 | A1 |
20070124729 | Ko et al. | May 2007 | A1 |
20070128899 | Mayer | Jun 2007 | A1 |
20070226182 | Sobotka et al. | Sep 2007 | A1 |
20080115012 | Jann et al. | May 2008 | A1 |
20080126780 | Rajkumari et al. | May 2008 | A1 |
20080222520 | Balakrishnan et al. | Sep 2008 | A1 |
20080235503 | Akpuokwe et al. | Sep 2008 | A1 |
20090113452 | Grigsby et al. | Apr 2009 | A1 |
20090138808 | Moromisato et al. | May 2009 | A1 |
20090172471 | Zimmer et al. | Jul 2009 | A1 |
20090182778 | Tormasov | Jul 2009 | A1 |
20090199051 | Jann et al. | Aug 2009 | A1 |
Number | Date | Country |
---|---|---|
1 970 807 | Sep 2008 | EP |
06-131203 | May 1994 | JP |
2002-215432 | Aug 2002 | JP |
2007-072969 | Mar 2007 | JP |
Entry |
---|
Irving, “Partitioning Implementation for IBM @server p5 Servers” Feb. 2005, IBM, third edition, pp. 1-342. |
Quintero, “HAMP V5-3, Dynamic LPAR, and Virtualization”, 2005, IBM Red Books, pp. 1-60. |
Greg Shultz, Disable Windows XP's Error Reporting notification, Aug. 29, 2007. http://www.techrepublic.com/blog/window-on-windows/disable-windows-xps-error-reporting-notification/507. |
Office Action dated Mar. 23, 2011 (U.S. Appl. No. 12/023,185). |
“Firmware Assisted Dump in a Partitioned Environment using Reserved Partition Memory”, authors et al., IBM, IP.com No. IPCOM000166859D, Original Publication Date: Jan. 25, 2008: IP.com Electronic Publication: Jan. 25, 2005. http://www.ip.com/pubview/IPCOM000166859D. |
Notice of Allowance dated Oct. 20, 2011 (U.S. Appl. No. 12/537,486). |
International Search Report dated Nov. 3, 2011. |
Office Action mailed on Jun. 6, 2011, for co-pending U.S. Appl. No. 12/537,486. |
Office Action dated Jun. 23, 2010 for U.S. Appl. No. 12/023,185. |
Wikipedia, “Concurrent computing” Wikipedia. p. 1-5. |
Written Opinion of the International Searching Authority dated Nov. 8, 2010. |
Huang, “A Case for High Performance Computing with Virtual Machines”, 2006, ACM, p. 1-10. |
Thefreedictionary, “Virtualization Definition” Thefreedictionary, p. 1. |
Cartwright, “What is Concurrent Programming”, Jan. 2000, www.cs.rice.edu, p. 1-5. |
Office Action dated Aug. 30, 2010, for U.S. Appl. No. 11/599,272. |
Japanese Office Action dated Jan. 22, 2013. |
Wikipedia, “Inotify”, Jan. 28, 2008, Retrieved from the Internet on Mar. 26, 2014, http://en.wikipedia.org/w/index.php?title=lnotify&oldid=187504185. |
European Search Report dated Apr. 4, 2014. |
Taiwanese Office Action dated Nov. 12, 2013. |
Number | Date | Country | |
---|---|---|---|
20120198479 A1 | Aug 2012 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 12023185 | Jan 2008 | US |
Child | 13444707 | US |