The present invention relates to monitoring computer system performance and detecting issues that need technician attention.
The approaches described in this section are approaches that could be pursued, but not necessarily approaches that have been previously conceived or pursued. Therefore, unless otherwise indicated, it should not be assumed that any of the approaches described in this section qualify as prior art merely by virtue of their inclusion in this section.
Technicians prefer to detect and begin resolving incidents in which system operations are failing or performing poorly before end-users contact them with complaints. To that end, companies may invest in monitoring software that is capable of collecting hundreds of distinct measurements. A problem that arises when using such monitoring software on a large complex system that may experience a large number of independent problems is that alerts are generated for issues that do not require attention. Such false positive alerts waste precious time as technicians diagnose non-problems, and false positive alerts obscure the alerts that do represent critical problems.
One approach to automated incident detection is to define alerting thresholds for certain individual measurements while leaving other measurements without thresholds even though those other measurements may provide insight into the nature of the incident. One challenge of single-measurement thresholds is that a single incident can, over time, affect the values of multiple measurements, often leading to each such affected measurement independently causing an alert. It may not be obvious how many distinct problems need to be addressed, with the consequent risks of redundant investigation (when a single problem is treated as several) or delayed response (when several problems are present, but one is incorrectly assumed to be the root cause of the others).
Another challenge is that the reliability of the alert depends on choosing the correct thresholds for each of the individual measurements. An incorrectly chosen threshold value can result in either generating false positive alerts or missing important alerts. Even if thresholds for identifying critical problems (referred to herein as a critical threshold) could be accurately chosen, an alert is not generated until the system is already experiencing a critical problem. A goal is to be able to predict that a critical problem is imminent based on a measurement value that is still at a sub-critical level. A sub-critical alert would indicate that the system is not yet experiencing a critical problem, but soon will be if steps are not taken to thwart the impending problem. For example, if a process that is run to generate database table statistics repeatedly fails, the statistics used in generating query execution plans may become outdated over time. Eventually, the performance of some queries may degrade due to relying on outdated statistics information. It may be difficult to set a threshold that accurately predicts a problem before the problem becomes critical and which does not generate too many false positive alerts.
Another limitation of single-measurement thresholds is that it is often necessary to examine multiple measurements in order to identify how many users' operations and which types of operations are failing or executing inefficiently. If a failure or inefficiency impacts only a single user, technicians would usually prefer not to be alerted by the monitoring system. The information conveyed by the occurrence of a single-measurement alert is not by itself sufficient to accurately prioritize the alert. A technician must be assigned to investigate each such alert, by examining the totality of thresholded and un-thresholded measurements, to determine whether it is worthwhile to take action on it. The effort of responding to the alert is wasted in those cases when the alert is not worth taking action on, so technology that reduces the number of false positive alerts would reduce labor costs.
In response to the shortcomings of using single-measurement threshold, an alternative approach is to train a machine learning algorithm to determine a relationship between available measurement values and end-users' subjective evaluations of incidents. Training such a model for incident detection requires a human to label each of a set of monitored measurements for a certain time interval with an indication of the human's subjective perception of system performance. The labels are chosen from a short list (for example, “bad performance”, “normal performance”). The resulting model can be applied to the current monitored measurements to derive an evaluation as to which label should be used to describe the current state.
A challenge in implementing such a machine learning solution is that historical subjective evaluations with precise beginning and ending times of incidents are unlikely to be available. Furthermore, the process of regularly recording such subjective evaluations is an expense end-users are likely to be reluctant to undertake in the absence of evidence that the machine learning algorithm will be successful.
Therefore, even if one seeks to gather subjective evaluations and base alerting on what can be learned from them, it would be helpful to seed those evaluations by soliciting user input for only those time periods during which there is a high probability of user dissatisfaction. The alerts would provide value by increasing end-user goodwill and would identify the time intervals for which subjective feedback is most needed. In addition to reducing the amount of data the end users are asked to look at, directing end users to evaluate particular time intervals also facilitates tracking their progress.
The present invention is illustrated by way of example, and not by way of limitation, in the figures of the accompanying drawings and in which like reference numerals refer to similar elements and in which:
In the following description, for the purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of the present invention. It will be apparent, however, that the present invention may be practiced without these specific details. In other instances, well-known structures and devices are shown in block diagram form in order to avoid unnecessarily obscuring the present invention.
A system health indicator is needed that may be relied upon to determine whether a system is experiencing a problem (or about to experience a problem) that requires human attention. What constitutes a problem for which human attention is required is somewhat subjective. An indicator that best correlates with poor efficiency in SQL execution, for example, is how much time active user sessions spend waiting on events. The system health indicator is based upon the amount of time user sessions spend waiting.
However, even if a system is performing inefficiently, if the poor performance is not impacting any user or large group of users, then it may not be necessary for the source of the poor performance to be diagnosed and fixed. When the overall workload is low and/or the server is responsive overall, there may not be a need to generate an alert because no harm or inconvenience is caused by the inefficiency.
Workloads that are known to be inefficient are often run outside of business hours, and the business conditions of the monitoring service may preclude manually informing the monitoring system of when those business hours are. For example, such workloads may include multiple concurrent batch jobs. If a long-running job that normally takes 2 hours to run is scheduled to run unattended during the night, there is probably no user waiting for the job to finish. Therefore, if that same job takes four hours to complete on a poorly performing system instead of the expected 2 hours, the longer running time would not inconvenience any user. Even when a job experiences a more critical problem, unless that particular job absolutely must run to completion that night, the business might prefer to abort the job in the morning (if necessary) and investigate its poor performance when labor costs are lower instead of having a technician urgently alerted in the middle of the night.
The health indicator not only measures system performance in terms of user wait time, but also takes into account the extent to which users are impacted by a performance problem so that the system health indicator only crosses an alert threshold when the system needs to be fixed.
Some threads of execution may be associated with a user session. The term “user session” is used herein to refer to a thread of execution in the server that performs work requested by an application client on behalf of a user. Each user session may be in one of several execution states: running, scheduled to run, waiting, or idle. Running means that a processor is currently executing instructions to perform work for the user session. Scheduled to run means that the user session is waiting for a processor to start executing the thread's instructions. Waiting means that the user session is blocked while waiting for an event that is generated internal to the server system but external to the thread of execution. Idle means that even though the session exists, the server system is not currently performing work for the application. For example, the application may be waiting for user input or input from some other external interface. An active user session is a user session that is not idle. That is, an active user session is one that is running, scheduled to run, or waiting on an event.
There are several different kinds of events that block an application from making forward progress. For example, an application may wait for data to be read from or written to the disk (I/O wait). Another example is that an application may be blocked while waiting for a response from another software component over the network or an inter-node communication within a multi-node server. Also, an application may wait for a transaction to commit. In addition, an application may be blocked waiting for a lock to be freed such as a lock on a record in a database table. Measurement values indicating time waiting on individual wait events may be aggregated into “wait classes”. The wait classes are grouped by proximate cause. That is, a single problem may impact the wait times for multiple wait events, and the wait times for these similarly impacted wait events may be aggregated into a single wait class wait time value. For example, a disk or memory failure may result in longer user I/O waits, or a deadlock could cause long application locking waits.
In one approach, a server system stores snapshots of fine-grained system performance metrics within a repository at frequent intervals. An example of this approach is Oracle's Automatic Workload Repository storing measurements on behalf of a database server. A management application may retrieve and aggregate samples of data from the repository at intervals less frequent than the data is captured. A management application may analyze the data and determine whether the system is functioning properly or if the data indicates that there is a problem with the system. Analysis of the data requires some a priori knowledge of what values the data should have under normal operating conditions. For effective use, a technician must be able to establish limits or thresholds that determine when the sampled data is outside of the normal range.
When a server thread that is performing work on behalf of an application is blocked while waiting for an event, the application work is not being performed. Thus, wait events that cause the server thread to block instead of making forward progress for the application may be an indicator of server inefficiency and poor performance. A user running an application that spends much time in a wait class will perceive the system as providing poor performance. In an embodiment, the system health indicator measures efficiency of application execution in terms of excessive user I/O, concurrency conflicts, intra-cluster communication, etc. In an embodiment, a system health indicator may be used to identify issues with SQL execution on a database server. In an embodiment, better system performance may be indicated by a low system health indicator value and performance degradation may be indicated by a high system health indicator value.
Several measurement values are retrieved from the repository and used to determine the system health metric:
the percentage of active user sessions' server-side time spent waiting for each type of wait event: The percentage of active user sessions' server-side time spent waiting for each type of wait event is a measure of performance that is based on user session wait times. For each wait class, the wait time for each wait class is aggregated across all sessions. The percentage of time for each wait class is the wait time for that wait class relative to the total time user sessions spend in any processing state.
the average number of user sessions waiting for an event in each wait class: For each wait class, the average number of user sessions waiting for an event in that wait class is determined by averaging the number of sessions counted in each wait class across snapshots of data that is captured more frequently than the aggregation time interval. Because the measurement used in the calculation is an aggregation of multiple individually collected data points, the average number might not have the same value as the latest collected data point. Nevertheless, for simplicity of expression, the present tense is used herein to describe the average number of user sessions that are waiting rather than the more accurate but cumbersome expression of “have been waiting during the interval.” This use of present tense is similarly use for all aggregated measurements over the time interval.
the total number of active user sessions currently running on the system: The total number of active user sessions is a count of all of the user sessions waiting for any wait event in addition to the running and scheduled to run user sessions.
the average number of active user sessions typically found on the system: This baseline number is acquired during a machine learning phase.
Although user session wait time is a good indication of server efficiency, relying only on that measure may not be fine-grained enough to consider the impact of the inefficiency on users. A single session that is blocked for an atypically long time can skew the measurement to a large extent. Typical waits last a small fraction of a second, but a poorly written application or a non-responsive resource can cause a session to wait for minutes or longer. It is quite possible for a single session to be responsible for the majority of time spent waiting in the server, even if there are a large number of sessions and the other sessions are executing efficiently. The system health indicator should alert the presence of overall system problems, and not that an individual user is running an inefficient application.
Another example of how a pure efficiency metric may not consider user impact is that the network might be exceptionally slow, but if only a few user sessions are waiting for a network response, the overall impact to users may not justify an alert even if the network is experiencing a problem. The system health indicator can be made more useful by considering the overall impact of the variations of the performance impact from one wait class to another. A weighting factor that reflects the amount of work waiting for a wait class may be used so as to quantify the user impact of a particular proximate cause.
To address the need for a finer grained, system-centric measure, an alternate measurement may be used: the average number of active sessions waiting for a particular class of wait events. The challenge with using the average number of sessions by itself as a measure of efficiency is that all sessions do not represent the same amount of work. There can be a large variation, even within the same customer's workloads, as to how much work is submitted to the database by each session. However, the count of sessions waiting for each class of wait events may be used to determine a user impact weighting factor in the determination of the system health indicator value, rather than a stand-alone indicator. To avoid alerting technicians of inefficiencies or failures that are specific to a single session, the percentage of time spent waiting on a particular wait class should be discounted if the count of sessions waiting on that particular wait class does not suggest that there are multiple sessions impacted by the same root cause.
Defining the system health indicator for database efficiency requires combining the above-mentioned measurements values. In order to make the system health indicator reflect the impact to users and priority to fix a problem, the absolute performance measurements are weighted.
In an embodiment, the system health indicator is a scaled sum of scaled waiting times for each wait class where the sum is scaled by the amount of overall activity in the system and the waiting times are scaled by the user impact of each wait class. The system health indicator is computed as:
This equation is explained in pieces herein.
In Step 210, an activity weighting function is constructed. In an embodiment, the activity weighting function has this form:
The activity weighting function is a scaling function (in this embodiment, a logistic function) that takes as input the computer system's average number of active user sessions at time t on whose behalf a server application performs work (activity(t)). The activity weighting function is designed to return an activity weighting factor that is a value between 0 and 1. The function returns a value of 0.5 when the current active session count is 80% of the baseline average for the system (baselineactivity) as determined during the learning phase as described above. For example, if the baseline average number of active sessions was determined to be 95 during the learning phase, then the scaling function would return 0.5 when there are 76 active sessions in operation (i.e. 0.8*95). When there are more than 76 active sessions, the activity weighting factor will be a number close to 1, and when there are less than 76 active sessions, the activity weighting factor will be a number close to 0.
The system health indicator value for a time interval is determined based on the number of active sessions during that interval along with fined grained time measurement values for each wait class. In Step 220, the time performance measurement values are retrieved from a repository. In an embodiment, each measurement value activity(t), timewaitingi(t), worki(t)) is a rolling average of the corresponding measurement over the hour preceding time t. In an embodiment intended to provide real-time monitoring, time t is the most recent time for which measurements are available.
In the system health indicator computation, wait classes are partitioned by proximate cause into i number of wait classes. In an embodiment, the waiting time measurement (timewaiting) is the percentage of time that user sessions collectively spend waiting on a particular wait class. In Step 230, the total time that work is spent waiting on each of the i wait classes is determined. Thus, the timewaitingi measurement is an aggregation of time that all user sessions spent in wait class i in relation to time spent in other states.
Each wait class time aggregation is also weighted based on the amount of work waiting due to that wait class, where the amount of work indicates the user impact of waiting for a particular wait class and is a measure whose value distinguishes cases where a single operation or sequence of operations is waiting from cases where multiple, independent operations are waiting. In an embodiment, the user impact weighting factor, workweighti, is a function of the average number of user sessions that are waiting on wait class i (worki). In Step 240, a work impact weighting factor for the wait time measurement for each particular wait class is determined. In an embodiment, workweighti is a logistic function of worki. A logistic function is a sigmoidal function that returns a value between 0 and 1. In an embodiment, the logistic function is derived so that the function returns 0.5 when the average number of sessions waiting in a wait class is 1.5. Thus, when the average number of sessions waiting on a wait class is more than 2, the impacted work weighting factor for the time spent in that wait class will be close to 1, so that the time spent in that wait class is fully reflected in the system health indicator value. If the average number of sessions waiting on a wait class is 1 or less, then the logistics function will return a number close to 0, and the contribution to the system health indicator of the time spent in that wait class is greatly diminished. In an embodiment, the following instantiation of the logistic function is used to give a slope that is not too steep, enhancing the continuity of the system health indicator:
In Step 250, the contribution towards the system health indicator from a particular wait class i is determined by multiplying the percentage of time spent in each wait class across active sessions by the work impact of each wait class: workweighti*timewaitingi.
In Step 260, the contribution towards the system health indicator from each of the wait classes is added together:
In Step 270, the activity weight factor is determined based on the weighting function constructed in Step 210. The activity weight factor, activityweight, is a function of the overall active session count. Thus, the activity weight factor is a weighting factor that dramatically lowers the overall system health indicator when the server is processing a less than average work load.
In Step 280, the system health indicator is determined by applying the activity weight factor to the not-yet-weighted system health indicator of the system determined in Step 260.
In an embodiment, the flow described in
In an embodiment, the flow repeats from Step 200 every two weeks to keep the baseline activity variable consistent with observed workloads.
Here is an example calculation of the system health indicator value for a scenario in which the historical average (baseline) number of active sessions on a host is 95 and there were an average of 100 active sessions being serviced in the previous hour. Table 300 in
The weight applied to the amount of work waiting in each weight class is a number close to 1 for any wait class where there has been an average of 2 or more sessions waiting and a number close to 0 when there has only been an average of 1 session waiting. Thus, in this example, the impact for all wait classes except for transaction commits will receive full weight, and any inefficiency created by waiting for transaction commits will contribute a diminished amount to the system health indicator. For example, the weighting factor applied to time spent waiting for a transaction to commit is determined as:
The contribution to the system health indicator of each wait class is the product of the number of sessions waiting and the percentage of time all sessions spend waiting on a wait class. For example, the contribution of each of the wait classes is shown in the table below:
Calculating to 3 significant digits, the sum of the contributions to the system health indicator for all the individual wait classes is (1.19+40.0+30.0+20.0) or 91.2. As noted above the average number of active sessions in the past hour was 100 and the baseline average for the number of active sessions is 95, so the activityweight is computed as:
Thus, the activityweight is 1.00 for this example. Thus, the system health indicator value for this example is 1.00*91.2=91.2.
A system may be in a critical state when the system is currently experiencing a problem that requires attention. The system health indicator may indicate that the system is in a critical state when the system health indicator value crosses a critical threshold. In an embodiment, the system health indicator is tracked for a training period of two weeks, and then the critical threshold is set to the 95th percentile of the system health indicator during the training period. In an embodiment, the critical threshold is configurable per user preference.
A system may be in a sub-critical state when there are signs that performance is degrading, but the system is not yet experiencing problems. The smooth, continuous nature of the function that determines the system health indicator values allows for a warning threshold to warn technicians that the system is in a sub-critical state so that problems may be identified and fixed before users notice the problem. In an embodiment, the system health indicator is tracked for a training period of two weeks, and then the warning threshold is set to the 90th percentile of the system health indicator during the training period. In an embodiment, the warning threshold is configurable per user preference.
According to an embodiment, the techniques described herein are implemented by one or more special-purpose computing devices. The special-purpose computing devices may be hard-wired to perform the techniques, or may include digital electronic devices such as one or more application-specific integrated circuits (ASICs) or field programmable gate arrays (FPGAs) that are persistently programmed to perform the techniques, or may include one or more general purpose hardware processors programmed to perform the techniques pursuant to program instructions in firmware, memory, other storage, or a combination. Such special-purpose computing devices may also combine custom hard-wired logic, ASICs, or FPGAs with custom programming to accomplish the techniques. The special-purpose computing devices may be desktop computer systems, portable computer systems, handheld devices, networking devices or any other device that incorporates hard-wired and/or program logic to implement the techniques.
For example,
Computer system 400 also includes a main memory 406, such as a random access memory (RAM) or other dynamic storage device, coupled to bus 402 for storing information and instructions to be executed by processor 404. Main memory 406 also may be used for storing temporary variables or other intermediate information during execution of instructions to be executed by processor 404. Such instructions, when stored in storage media accessible to processor 404, render computer system 400 into a special-purpose machine that is customized to perform the operations specified in the instructions.
Computer system 400 further includes a read only memory (ROM) 408 or other static storage device coupled to bus 402 for storing static information and instructions for processor 404. A storage device 410, such as a magnetic disk or optical disk, is provided and coupled to bus 402 for storing information and instructions.
Computer system 400 may be coupled via bus 402 to a display 412, such as a cathode ray tube (CRT), for displaying information to a computer user. An input device 414, including alphanumeric and other keys, is coupled to bus 402 for communicating information and command selections to processor 404. Another type of user input device is cursor control 416, such as a mouse, a trackball, or cursor direction keys for communicating direction information and command selections to processor 404 and for controlling cursor movement on display 412. This input device typically has two degrees of freedom in two axes, a first axis (e.g., x) and a second axis (e.g., y), that allows the device to specify positions in a plane.
Computer system 400 may implement the techniques described herein using customized hard-wired logic, one or more ASICs or FPGAs, firmware and/or program logic which in combination with the computer system causes or programs computer system 400 to be a special-purpose machine. According to one embodiment, the techniques herein are performed by computer system 400 in response to processor 404 executing one or more sequences of one or more instructions contained in main memory 406. Such instructions may be read into main memory 406 from another storage medium, such as storage device 410. Execution of the sequences of instructions contained in main memory 406 causes processor 404 to perform the process steps described herein. In alternative embodiments, hard-wired circuitry may be used in place of or in combination with software instructions.
The term “storage media” as used herein refers to any media that store data and/or instructions that cause a machine to operate in a specific fashion. Such storage media may comprise non-volatile media and/or volatile media. Non-volatile media includes, for example, optical or magnetic disks, such as storage device 410. Volatile media includes dynamic memory, such as main memory 406. Common forms of storage media include, for example, a floppy disk, a flexible disk, hard disk, solid state drive, magnetic tape, or any other magnetic data storage medium, a CD-ROM, any other optical data storage medium, any physical medium with patterns of holes, a RAM, a PROM, and EPROM, a FLASH-EPROM, NVRAM, any other memory chip or cartridge.
Storage media is distinct from but may be used in conjunction with transmission media. Transmission media participates in transferring information between storage media. For example, transmission media includes coaxial cables, copper wire and fiber optics, including the wires that comprise bus 402. Transmission media can also take the form of acoustic or light waves, such as those generated during radio-wave and infra-red data communications.
Various forms of media may be involved in carrying one or more sequences of one or more instructions to processor 404 for execution. For example, the instructions may initially be carried on a magnetic disk or solid state drive of a remote computer. The remote computer can load the instructions into its dynamic memory and send the instructions over a telephone line using a modem. A modem local to computer system 400 can receive the data on the telephone line and use an infra-red transmitter to convert the data to an infra-red signal. An infra-red detector can receive the data carried in the infra-red signal and appropriate circuitry can place the data on bus 402. Bus 402 carries the data to main memory 406, from which processor 404 retrieves and executes the instructions. The instructions received by main memory 406 may optionally be stored on storage device 410 either before or after execution by processor 404.
Computer system 400 also includes a communication interface 418 coupled to bus 402. Communication interface 418 provides a two-way data communication coupling to a network link 420 that is connected to a local network 422. For example, communication interface 418 may be an integrated services digital network (ISDN) card, cable modem, satellite modem, or a modem to provide a data communication connection to a corresponding type of telephone line. As another example, communication interface 418 may be a local area network (LAN) card to provide a data communication connection to a compatible LAN. Wireless links may also be implemented. In any such implementation, communication interface 418 sends and receives electrical, electromagnetic or optical signals that carry digital data streams representing various types of information.
Network link 420 typically provides data communication through one or more networks to other data devices. For example, network link 420 may provide a connection through local network 422 to a host computer 424 or to data equipment operated by an Internet Service Provider (ISP) 426. ISP 426 in turn provides data communication services through the world wide packet data communication network now commonly referred to as the “Internet” 428. Local network 422 and Internet 428 both use electrical, electromagnetic or optical signals that carry digital data streams. The signals through the various networks and the signals on network link 420 and through communication interface 418, which carry the digital data to and from computer system 400, are example forms of transmission media.
Computer system 400 can send messages and receive data, including program code, through the network(s), network link 420 and communication interface 418. In the Internet example, a server 430 might transmit a requested code for an application program through Internet 428, ISP 426, local network 422 and communication interface 418.
The received code may be executed by processor 404 as it is received, and/or stored in storage device 410, or other non-volatile storage for later execution.
In the foregoing specification, embodiments of the invention have been described with reference to numerous specific details that may vary from implementation to implementation. The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense. The sole and exclusive indicator of the scope of the invention, and what is intended by the applicants to be the scope of the invention, is the literal and equivalent scope of the set of claims that issue from this application, in the specific form in which such claims issue, including any subsequent correction.
Number | Name | Date | Kind |
---|---|---|---|
4318182 | Bachman et al. | Mar 1982 | A |
5113522 | Dinwiddie et al. | May 1992 | A |
5222217 | Blount et al. | Jun 1993 | A |
5283856 | Gross et al. | Feb 1994 | A |
5347632 | Filepp et al. | Sep 1994 | A |
5357612 | Alaiwan | Oct 1994 | A |
5465328 | Dievendorff et al. | Nov 1995 | A |
5627764 | Schutzman et al. | May 1997 | A |
5649102 | Yamauchi et al. | Jul 1997 | A |
5721825 | Lawson et al. | Feb 1998 | A |
5754841 | Carino, Jr. | May 1998 | A |
5774668 | Choquier et al. | Jun 1998 | A |
5790807 | Fishler et al. | Aug 1998 | A |
5802253 | Gross et al. | Sep 1998 | A |
5828835 | Isfeld et al. | Oct 1998 | A |
5852818 | Guay et al. | Dec 1998 | A |
5862325 | Reed et al. | Jan 1999 | A |
5867665 | Butman et al. | Feb 1999 | A |
5867667 | Butman et al. | Feb 1999 | A |
5870562 | Butman et al. | Feb 1999 | A |
5878056 | Black et al. | Mar 1999 | A |
5884035 | Butman et al. | Mar 1999 | A |
5890167 | Bridge, Jr. et al. | Mar 1999 | A |
5918059 | Tavallaei et al. | Jun 1999 | A |
5933604 | Inakoshi | Aug 1999 | A |
5940839 | Chen et al. | Aug 1999 | A |
5951694 | Choquier et al. | Sep 1999 | A |
5970439 | Levine et al. | Oct 1999 | A |
5995980 | Olson et al. | Nov 1999 | A |
5999931 | Breitbart et al. | Dec 1999 | A |
6026430 | Butman et al. | Feb 2000 | A |
6029205 | Alferness et al. | Feb 2000 | A |
6035379 | Raju et al. | Mar 2000 | A |
6041357 | Kunzelman et al. | Mar 2000 | A |
6058389 | Chandra et al. | May 2000 | A |
6067540 | Hyde | May 2000 | A |
6073129 | Levine et al. | Jun 2000 | A |
6088728 | Bellemore et al. | Jul 2000 | A |
6178529 | Short et al. | Jan 2001 | B1 |
6182086 | Lomet et al. | Jan 2001 | B1 |
6185555 | Sprenger et al. | Feb 2001 | B1 |
6188699 | Lang et al. | Feb 2001 | B1 |
6192378 | Abrams et al. | Feb 2001 | B1 |
6222840 | Walker et al. | Apr 2001 | B1 |
6243751 | Chatterjee et al. | Jun 2001 | B1 |
6247017 | Martin | Jun 2001 | B1 |
6304882 | Strellis et al. | Oct 2001 | B1 |
6327622 | Jindal et al. | Dec 2001 | B1 |
6334114 | Jacobs et al. | Dec 2001 | B1 |
6338074 | Poindexter et al. | Jan 2002 | B1 |
6393423 | Goedken | May 2002 | B1 |
6427146 | Chu | Jul 2002 | B1 |
6442568 | Velasco et al. | Aug 2002 | B1 |
6466950 | Ono | Oct 2002 | B1 |
6473794 | Guheen et al. | Oct 2002 | B1 |
6490574 | Bennett et al. | Dec 2002 | B1 |
6493826 | Schofield et al. | Dec 2002 | B1 |
6515968 | Combar et al. | Feb 2003 | B1 |
6519571 | Guheen et al. | Feb 2003 | B1 |
6529932 | Dadiomov et al. | Mar 2003 | B1 |
6536037 | Guheen et al. | Mar 2003 | B1 |
6539381 | Prasad et al. | Mar 2003 | B1 |
6556659 | Bowman-Amuah | Apr 2003 | B1 |
6560592 | Reid et al. | May 2003 | B1 |
6587866 | Modi et al. | Jul 2003 | B1 |
6601101 | Lee et al. | Jul 2003 | B1 |
6651012 | Bechhoefer | Nov 2003 | B1 |
6654907 | Stanfill et al. | Nov 2003 | B2 |
6658596 | Owen | Dec 2003 | B1 |
6691155 | Gottfried | Feb 2004 | B2 |
6697791 | Hellerstein et al. | Feb 2004 | B2 |
6704831 | Avery | Mar 2004 | B1 |
6704886 | Gill et al. | Mar 2004 | B1 |
6728748 | Mangipudi et al. | Apr 2004 | B1 |
6757710 | Reed | Jun 2004 | B2 |
6769074 | Vaitzblit | Jul 2004 | B2 |
6793625 | Cavallaro et al. | Sep 2004 | B2 |
6802003 | Gross et al. | Oct 2004 | B1 |
6816907 | Mei et al. | Nov 2004 | B1 |
6826182 | Parthasarathy | Nov 2004 | B1 |
6826579 | Leymann et al. | Nov 2004 | B1 |
6850893 | Lipkin et al. | Feb 2005 | B2 |
6868413 | Grindrod et al. | Mar 2005 | B1 |
6882994 | Yoshimura et al. | Apr 2005 | B2 |
6889231 | Souder et al. | May 2005 | B1 |
6917946 | Corl, Jr. et al. | Jul 2005 | B2 |
6925476 | Multer et al. | Aug 2005 | B1 |
6980988 | Demers et al. | Dec 2005 | B1 |
7003531 | Holenstein et al. | Feb 2006 | B2 |
7031974 | Subramaniam | Apr 2006 | B1 |
7058957 | Nguyen | Jun 2006 | B1 |
7065537 | Cha et al. | Jun 2006 | B2 |
7080382 | Sexton et al. | Jul 2006 | B2 |
7089228 | Arnold et al. | Aug 2006 | B2 |
7095871 | Jones et al. | Aug 2006 | B2 |
7149738 | Kumar et al. | Dec 2006 | B2 |
7174379 | Agarwal et al. | Feb 2007 | B2 |
7177866 | Holenstein et al. | Feb 2007 | B2 |
7178050 | Fung et al. | Feb 2007 | B2 |
7243256 | Kaiya et al. | Jul 2007 | B2 |
7263590 | Todd et al. | Aug 2007 | B1 |
7269157 | Klinker et al. | Sep 2007 | B2 |
7424396 | Dodeja et al. | Sep 2008 | B2 |
7506215 | Maw et al. | Mar 2009 | B1 |
20010032137 | Bennett et al. | Oct 2001 | A1 |
20010047270 | Gusick et al. | Nov 2001 | A1 |
20010052137 | Klein | Dec 2001 | A1 |
20010056493 | Mineo | Dec 2001 | A1 |
20020049845 | Sreenivasan et al. | Apr 2002 | A1 |
20020052885 | Levy | May 2002 | A1 |
20020073019 | Deaton | Jun 2002 | A1 |
20020073139 | Hawkins et al. | Jun 2002 | A1 |
20020091685 | Feldman et al. | Jul 2002 | A1 |
20020112008 | Christenson et al. | Aug 2002 | A1 |
20020116457 | Eshleman et al. | Aug 2002 | A1 |
20020129157 | Varsano | Sep 2002 | A1 |
20020133507 | Holenstein et al. | Sep 2002 | A1 |
20020138582 | Chandra et al. | Sep 2002 | A1 |
20020144010 | Younis et al. | Oct 2002 | A1 |
20020161896 | Wen et al. | Oct 2002 | A1 |
20020194015 | Gordon et al. | Dec 2002 | A1 |
20020194081 | Perkowski | Dec 2002 | A1 |
20030005028 | Dritschler et al. | Jan 2003 | A1 |
20030007497 | March et al. | Jan 2003 | A1 |
20030014523 | Teloh et al. | Jan 2003 | A1 |
20030037029 | Holenstein et al. | Feb 2003 | A1 |
20030037146 | O'Neill | Feb 2003 | A1 |
20030039212 | Lloyd et al. | Feb 2003 | A1 |
20030046421 | Horvitz et al. | Mar 2003 | A1 |
20030088671 | Klinker et al. | May 2003 | A1 |
20030108052 | Inoue et al. | Jun 2003 | A1 |
20030110085 | Murren et al. | Jun 2003 | A1 |
20030135523 | Brodersen et al. | Jul 2003 | A1 |
20030135609 | Carlson et al. | Jul 2003 | A1 |
20030161468 | Iwagaki et al. | Aug 2003 | A1 |
20030177187 | Levine et al. | Sep 2003 | A1 |
20030208523 | Gopalan et al. | Nov 2003 | A1 |
20030212657 | Kaluskar et al. | Nov 2003 | A1 |
20030212670 | Yalamanchi et al. | Nov 2003 | A1 |
20030229804 | Srivastava et al. | Dec 2003 | A1 |
20030236834 | Gottfried | Dec 2003 | A1 |
20040024771 | Jain et al. | Feb 2004 | A1 |
20040024774 | Jain et al. | Feb 2004 | A1 |
20040024794 | Jain et al. | Feb 2004 | A1 |
20040024979 | Kaminsky et al. | Feb 2004 | A1 |
20040034640 | Jain et al. | Feb 2004 | A1 |
20040034664 | Jain et al. | Feb 2004 | A1 |
20040064548 | Adams et al. | Apr 2004 | A1 |
20040093512 | Sample | May 2004 | A1 |
20040103195 | Chalasani et al. | May 2004 | A1 |
20040107125 | Guheen et al. | Jun 2004 | A1 |
20040111506 | Kundu et al. | Jun 2004 | A1 |
20040117794 | Kundu | Jun 2004 | A1 |
20040133591 | Holenstein et al. | Jul 2004 | A1 |
20040176996 | Powers et al. | Sep 2004 | A1 |
20040181476 | Smith et al. | Sep 2004 | A1 |
20040268357 | Joy et al. | Dec 2004 | A1 |
20050010545 | Joseph | Jan 2005 | A1 |
20050021567 | Holenstein et al. | Jan 2005 | A1 |
20050021771 | Kaehn et al. | Jan 2005 | A1 |
20050033809 | McCarthy et al. | Feb 2005 | A1 |
20050125371 | Bhide et al. | Jun 2005 | A1 |
20050165925 | Dan et al. | Jul 2005 | A1 |
20050183072 | Horning et al. | Aug 2005 | A1 |
20050193024 | Beyer et al. | Sep 2005 | A1 |
20050239476 | Betrabet et al. | Oct 2005 | A1 |
20050240649 | Elkington et al. | Oct 2005 | A1 |
20050262205 | Nikolov et al. | Nov 2005 | A1 |
20050267965 | Heller | Dec 2005 | A1 |
20060036617 | Bastawala et al. | Feb 2006 | A1 |
20060112135 | Warshawsky | May 2006 | A1 |
20070162260 | Nordstrom | Jul 2007 | A1 |
20070226323 | Halpern | Sep 2007 | A1 |
20090112809 | Wolff et al. | Apr 2009 | A1 |
20120271594 | Yan et al. | Oct 2012 | A1 |
Entry |
---|
Ravi Kokku et al., “Half-pipe Anchoring: An Efficient Technique for Multiple Connection Handoff,” Proceedings 10th International Conference on Network Protocols, Nov. 12, 2002, XP010632563, 10 pages. |
Ying-Dar Lin et al., “Direct Web Switch Routing with State Migration, TCP Masquerade, and Cookie Name Rewriting,” Globecom 2003, IEEE Global Telecommunications Conference, Dec. 12003, IEEE, CP010677300, pp. 3663-3667. |
Chase, Jeffrey S., et al., “Dynamic Virtual Clusters in a Grid Site Manager,” Proceedings of the 12th IEEE International Symposium on High Performance Distributed Computing, 2003, XP-010643715, 12 pgs. |
Shiva, S.G., et al., “Modular Description/Simulation/Synthesis Using DDL,” 19th Design Automation Conference 1982, IEEE Press, pp. 321-329. |
Skow, Eric, et al., “A Security Architecture for Application Session Handoff,” 2002, IEEE International Conference Proceedings, Apr. 28-May 2, 2002, vol. 1 of 5, pp. 2058-2063, XP010589848. |
Song, Henry, et al., “Browser State Repository Service,” Lecture Notes in Computer Science, vol. 2414, 2002, pp. 1-14, XP002904339. |
Spiegler, Israel, “Automating Database Construction,” ACM SIGMIS Database, vol. 14, Issue 3, Spring 1983, pp. 21-29. |
Kei Kurakawa et al., “Life Cycle Design Support Based on Environmental Information Sharing,” IEEE, Feb. 1-3, 1999, Proceedings EcoDesign '99, First International Symposium, pp. 138-142. |
Gunther, Oliver et al., “MMM: A Web-Based System for Sharing Statistical Computing Modules,” IEEE, May-Jun. 1997, vol. 1, Issue 3, pp. 59-68. |
Number | Date | Country | |
---|---|---|---|
20120072780 A1 | Mar 2012 | US |