WO2005093607A1 - Method and system to monitor a diverse heterogeneous application environment - Google Patents

Method and system to monitor a diverse heterogeneous application environment Download PDF

Info

Publication number
WO2005093607A1
WO2005093607A1 PCT/US2004/014780 US2004014780W WO2005093607A1 WO 2005093607 A1 WO2005093607 A1 WO 2005093607A1 US 2004014780 W US2004014780 W US 2004014780W WO 2005093607 A1 WO2005093607 A1 WO 2005093607A1
Authority
WO
WIPO (PCT)
Prior art keywords
data
transaction
operations
logged
application
Prior art date
Application number
PCT/US2004/014780
Other languages
French (fr)
Inventor
James Lloyd
Martin Hess
Kostya Vasilyev
Abhinav Kumar
Faye Hall
Michael Eynon
Original Assignee
Ebay Inc.
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Ebay Inc. filed Critical Ebay Inc.
Publication of WO2005093607A1 publication Critical patent/WO2005093607A1/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/34Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
    • G06F11/3466Performance evaluation by tracing or monitoring
    • G06F11/3495Performance evaluation by tracing or monitoring for systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/34Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
    • G06F11/3447Performance evaluation by modeling
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/34Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
    • G06F11/3466Performance evaluation by tracing or monitoring
    • G06F11/3476Data logging
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2201/00Indexing scheme relating to error detection, to error correction, and to monitoring
    • G06F2201/87Monitoring of transactions

Definitions

  • An embodiment relates generally to the field of system monitoring and administration and, more specifically, to a method and system to monitor a diverse heterogeneous application environment.
  • Such an application environment may include hundreds of diverse and heterogeneous applications, and may be required to handle millions of Uniform Resource Location (URL) requests, millions of e- mail messages, and billions of database inquiries (e.g., utilizing SQL statements) in a 24-hour period.
  • URL Uniform Resource Location
  • e-mail messages millions of e- mail messages
  • database inquiries e.g., utilizing SQL statements
  • a failure in such an application environment can be disastrous, particularly where the application environment supports a live and real-time service (e.g., online or network-base commerce).
  • a live and real-time service e.g., online or network-base commerce.
  • the ability to monitor and quickly identify problems that may arise within an application environment is of course important for a number of reasons, and presents a number of technical challenges.
  • a method to monitor a diverse and heterogeneous application environment Each of a plurality of application servers is instrumented to log data pertaining to a respective application server. The logged data is communicated to a central logging system. The logged data is further aggregated so as to provide an aggregate view of the logged data across the plurality of application servers. The logged transaction data is also communicated to the central logging systems utilizing a common syntax so as to facilitate the aggregation of the logged transaction data. [0006] According to a further aspect of the present invention, there is provided a method to detect potential problems within a heterogeneous and diverse application environment.
  • Operations data is received from a plurality of application servers within the application environment, the operations data pertaining to operations performed at the plurality of application servers.
  • the operations data pertaining to operations performed at the plurality of application servers, over a predetermined time interval, is aggregated.
  • the aggregated data is compared to reference data, and a potential problem within the application environment is detected if the aggregated data deviates from the reference data in a predetermined manner.
  • Figures 1-3 are block diagrams illustrating respective exemplary embodiments of systems to monitor a diverse and heterogeneous application environment.
  • Figure 4 is a diagrammatic representation of a data logging message, according to an exemplary embodiment, that may be generated by a monitoring client conforming to a messaging API.
  • Figure 5 is a flowchart depicting a method, according to an exemplary embodiment, to monitor a diverse and heterogeneous application environment.
  • Figure 6 is a flowchart illustrating a method, according to one exemplary embodiment, to perform automatic problem detection within a diverse and heterogeneous application environment.
  • Figure 7 illustrates an exemplary transaction table that includes rows of transaction data, suitable for insertion into an OLAP data structure that may be generated by harvesters, in one exemplary embodiment.
  • Figure 8 illustrates an exemplary summary table that may be generated by a summary node generation algorithm for a dimensional analysis across a
  • Figure 9 is a diagrammatic representation of a dimensional hierarchy, according to an exemplary embodiment.
  • Figures 10-12 illustrates exemplary summary tables that may be presented to a user for analysis, or alternatively utilized by a comparison algorithm to perform a comparison against analysis variable thresholds content, for example, within a reference OLAP data structure for the purpose of detecting problems within a cluster of application servers.
  • Figure 13 is a diagrammatic representation of a machine, an exemplary form of a computer system, within which a set of instructions, for causing the machine to perform any one of the methodologies discussed herein, may be executed.
  • FIGs 1-3 are block diagrams illustrating respective exemplary embodiments of systems to monitor a diverse heterogeneous application environment, according to the present invention.
  • the monitored application environment may, for example, include a large number of applications, each hosted on a respective application server and providing distinct application services.
  • the diverse heterogeneous application environment may, for example, include applications providing, at one end of the spectrum, unrelated and distinct services or may include applications that provide distinct but partially or directly related services (e.g., purchase process and billing services).
  • FIG. 1 is a block diagram illustrating a system 10, according to a first exemplary embodiment, to monitor a diverse and heterogeneous application environment.
  • a cluster 12 of application servers 14 is shown to be coupled to, and in communication with, a cluster 16 of harvesters 18.
  • the cluster 16 of harvesters 18 is then coupled to an extensible collection of data analysis services 20, and a central logging system 22.
  • pools 24 of application servers 14 may be locally networked, and associated with a dedicated load balancer 26 that operates to balance load between the application servers 14 within a particular pool 24.
  • the application servers 14 within a particular pool 24 may provide a common set of application services.
  • Each of the application servers 14 is furthermore instrumented with a monitoring client 28 that, as will be described in further detail below, monitors a predetermined set of activities and parameters of a host application server, and communicates messages reflecting such activities and parameters utilizing a messaging Application Program Interface (API) 30.
  • the messaging API 30 defines a common syntax, which will be described more fully below, to communicate with the cluster 16 of harvesters 18 and the central logging system 22.
  • the common syntax allows a "de-coupling" of the application servers 14 from the harvesters 18 and the central logging system 22.
  • Logging data generated by the monitoring client 28 and communicated by the messaging API 30, may be transmitted from an application server 14 via a local pool network 32, and an application server network 34, to a load balancer 36, which distributes the messages to harvesters 18 included within the cluster 16.
  • the harvesters 18 then operate to write logs, including the logging data received in the logging data messages, to a disk array 38 via a network 40 and a network application server (NAS) 42.
  • NAS network application server
  • the data analysis services 20 may, as will be described in further detail below, include a number of services.
  • a number of reporters 44 operate to generate periodic (e.g., hourly and daily) reports regarding activities and parameters of the application servers 14, utilizing the logs written into the disk array 38.
  • the reporters 44 may retrieve the logs from the disk array 38 via the local network 40 and the network application server 42.
  • the reports generated by the reporters 44 may be so- called "static" reports, in that they present a static view of the logging data for a particular time period.
  • real-time servers 19 operates to aggregate received logging data from the harvesters 18, via the network 40, in near real-time, and to present a number of near real-time views of activities and parameters pertaining to the application servers 14. For example, one or more real-time servers 19 may present aggregated statistics regarding the various parameters pertaining to individual application servers 14, or collections (e.g., pools 24) of application servers, or of all applications across the entire cluster 12 of application servers 14.
  • TCP Transmission Control Protocol
  • NFS Network File System
  • FIG. 2 and 3 The exemplary embodiments illustrated in Figures 2 and 3 are architected utilizing a publish/subscribe messaging communications system 50, which utilizes a publish/subscribe messaging bus to communicate messages between various entities.
  • Figure 2 is a block diagram illustrating a system 50, according to a further exemplary embodiment, to monitor a diverse, heterogeneous application environment.
  • the system 50 includes a number of monitoring clients 28 that are utilized to instrument application servers 14 included within a cluster 12 of application servers.
  • the application servers 14 may also, as illustrated, be arranged in pools 24.
  • the architecture of the system 50 departs from that of the system 10 illustrated in Figure 1 in that a publish/subscribe message bus communications protocol 52 is utilized to communicate logging data messages, generated by the monitoring clients 28 and conforming to the messaging API 30.
  • messages are communicated from the monitoring client 28, utilizing the messaging API 30, to one or more publishers 54, via a load balancer 56.
  • the logging data messages are then published by the publishers 54 onto a publish/subscribe messaging bus 58.
  • the real-time servers 19, the harvesters 18 and one or more further data analysis services e.g., an Automatic Problem Detection (APD) service provided by one or more APD servers 60
  • APD Automatic Problem Detection
  • the harvesters 18 then, in the same manner as described above with reference to Figure 1, communicate logging data to one or more reporters 44, and also write appropriate logs into the disk array 38 via the network application server 42. Communications between the harvesters 18, the reporters 44, and the disk array 38 are shown to be performed utilizing the Network File System (NFS).
  • NFS Network File System
  • Figure 2 illustrates that the collection of real-time servers 19, harvesters 18, Automatic Problem Detection (APD) servers 60, reporters 44, Network Application Server 42, and the disk array 38 may be considered to be a central logging and data analysis service 62.
  • Figure 2 also illustrates that the system 50 may include a production environment of the central logging and data analysis services, as well as a test environment 64.
  • API Automatic Problem Detection
  • the data analysis services 62 are shown to include one or more Application Problem Detection (APD) servers 60, each of which hosts an Automatic Problem Detection (APD) application 66.
  • Each APD application 66 operates, in one exemplary, to analyze logging data messages, received from the monitoring clients 28 via the messaging bus 58, m near real-time to detect actual or potential problems, and to generate alerts. These alerts may, in one embodiment, be connected to appropriate direct or indirect actions.
  • each APD application 66 is shown in Figure 2 to include a summary node generation algo ⁇ thm 68 and a drill-down analysis algorithm 70.
  • Each drill-down analysis algorithm 70 includes a comparison algorithm 71. The functioning of an exemplary embodiment of an APD application 66 will be described in further detail below.
  • FIG. 3 is a block diagram illustrating a system 80, according to yet a further exemplary embodiment, to monitor a diverse and heterogeneous application environment.
  • the system 80 is similar to that shown in Figure 3, but differs in that the monito ⁇ ng clients 28 no longer communicate with publishers 54 utilizing TCP, but publish logging data messages directly onto the publish/subscribe messaging bus 58. To this end, each of the monitoring clients 28 is shown to incorporate a publisher component 82.
  • each of the application servers 14 is instrumented with a monitoring client 28, which communicates logging data messages utilizing a messaging API 30, these logging data messages being reported to a central logging system and to data analysis services.
  • These messages may be communicated utilizing any one, or combination of, a number of well-known communications and messaging protocols (e.g., a transport protocol (e.g., TCP), a messaging protocol (e.g., utilizing a publish/subscribe messaging bus such as the TIB, developed by Tibco Software Inc., of Palo Alto, California), or a network file sharing system (e.g., the NFS developed by Sun Microsystems Inc., of Santa Clara, California)).
  • a transport protocol e.g., TCP
  • a messaging protocol e.g., utilizing a publish/subscribe messaging bus such as the TIB, developed by Tibco Software Inc., of Palo Alto, California
  • a network file sharing system e.g., the NFS developed by Sun Micro
  • va ⁇ ous exemplary embodiments of a system to monitor an application environment show increasingly heavy deployment of a publish/subscribe messaging bus to facilitate communications between various components of a system.
  • the use of a publish/subscribe messaging bus may allow components to broadcast and receive logging data messages in an efficient manner, and to allow components to have the ability to perform work in parallel, rather than in a serial manner. For example, rather than have a single component to receive a message, process the message, and then forward the original messages on to a downstream component, individual components may, utilizing a publish/subscribe message bus, be able to better utilize resources by concentrating solely on the local processing of received messages.
  • a message bus 58 may allow a process or thread located anywhere within a system (e.g., the system 80) to be connected to the publish/subscribe bus, and to communicate with all other processes connected to the same bus.
  • each of the monitoring clients 28, with which the respective application servers 14 of an application environment are instrumented may communicate with a central logging system, and data analysis services, utilizing a generalized messaging API 30.
  • This may provide certain advantages. For example, the unified and extensible logging of a set of diverse and heterogeneous applications may be enabled by instrumenting such application servers 14 utilizing monitoring clients 28 that communicate in a common syntax supported by the messaging API 30. Further, the common syntax supported by the messaging API 30 may provide for the simplified instrumentation of the application servers 14.
  • FIG 4 is a diagrammatic representation of a data logging message 90, according to an exemplary embodiment, that may be generated by a monitoring client 28, conforming to the messaging API 30.
  • a data logging message 90 is generated, by a respective monitoring client 28, for each observed transaction pertaining to a monitored application.
  • Each monitoring client 28 may be adapted to monitor a specific application, or application type, within a diverse and heterogeneous application environment. Regardless of the diversity of applications monitored, each monitoring client 28 may utilize the messaging API 30 to communicate logging data messages conforming to a common syntax, such as that described below with reference to Figure 4.
  • the term "transaction”, to which a particular data logging message 90 may pertain may be regarded as a flow of processing, or unit of work, that takes time to complete (e.g., has a start and an end).
  • a transaction may optionally be regarded as either being successful or unsuccessful.
  • an error code may identify the type of error that has caused the transaction to be unsuccessful.
  • each of the monitoring clients 28 may include a precision timer (not shown), which allows the monitoring client 28 to determine the time taken for a transaction to complete.
  • Transactions, monitored by a respective monitoring client 28, may furthermore be classified as being of a particular transaction type according to a predefined set of transaction types.
  • a predefined set of transaction types may include URL
  • SQL e-mail
  • XSLT XSLT
  • Logic SQLOpen
  • SQLExe SQLFetch transactions
  • Any number of transaction types may be defined.
  • Transactions may furthermore be nested.
  • an SQL transaction may be nested within a URL transaction and an XSLT transaction may be nested in an e-mail transaction, which is in turn nested in a URL transaction.
  • an XSLT transaction may be nested in an e-mail transaction, which is in turn nested in a URL transaction.
  • For each transaction observed by a monitoring client 28, one or more data logging messages 90 may be generated.
  • each message may include a number of fields.
  • An exemplary syntax is provided below.
  • a pool dimension variable 96 may indicate a pool 24 of application servers 14 from which the message 90 originated.
  • a machine dimension variable 98 indicates a specific machine (e.g., an application server 14) from which the relevant message 90 originated.
  • Each message 90 further includes a message class dimension variable 100 that, in the exemplary embodiment, identifies the message as belonging to one of five classes namely: 1. A Transaction Start class 118; 2. A Transaction End class 120; 3. A Transaction Atomic class 122; 4. A Heartbeat class 124; and 5. An Event class 126.
  • Messages of the Transaction Start and the Transaction End classes 118 and 120 identify the start and end of transactions, as may be observed by a monitoring client 28 with respect to a monitored application. Messages of the Transaction Start and Transaction End classes 118 and 120 are normally utilized to report detected transactions or events pertaining to a particular transaction. Exemplary formats for messages of the classes 118 and 120 may be: t ⁇ timestamp> ⁇ type> //... nested messages T ⁇ timestamp> ⁇ type> ⁇ name> ⁇ status> ⁇ duration> ⁇ data>. As will be described below, in the event that no nested transaction messages are generated, a message of the Transaction Atomic class 122 may be generated.
  • Messages belonging to the Transaction Atomic class 122 facilitate optimization of message communication and generation in that, if there are no other messages between a Transaction Start and a Transaction End, only a single message, of the Transaction Atomic class 122, is written. Accordingly, in one exemplary embodiment, the monitoring client 28 may perform a "lazy" evaluation of a transaction start, in that a message of the Transaction Start class 118 is only written if a subsequent event, pertaining to the relevant transaction, is registered prior to the transaction end.
  • An exemplary format for a message of the Transaction Atomic class 122 may be: A ⁇ timestamp> ⁇ type> ⁇ name> ⁇ status> ⁇ duration> ⁇ data>.
  • Messages of the Heartbeat class 124 may report statistical "heartbeats" concerning certain applications, the "heartbeats” being computed internally and logged at regular intervals. It will be appreciated that the statistics may be highly application dependent, or may be more general (e.g., percentage CPU utilization and percentage memory utilization).
  • An exemplary format for a message of the Heartbeat class 124 is: H ⁇ timestamp > ⁇ type> ⁇ name> ⁇ status> ⁇ data>.
  • Event 126 Event Messages
  • Event Messages are "catch all" messages for other types of messages that may not be transaction or heartbeat messages. As such, Event messages are for recording "instantaneous" and "aperiodic" actions.
  • An non-instantaneous "event” may be more appropriately considered to be a Transaction.
  • a periodic action may be more appropriately considered to be a Heartbeat.
  • One exemplary Event in the current embodiment is for acknowledging the detection of service Mark-Down.
  • Information included within a message of the Event class 126 may include warning, error, exception or other types of internal data specific to a particular environment.
  • the format of an exemplary message of the Event class 126 may be: E ⁇ timestamp> ⁇ type> ⁇ name> ⁇ status> ⁇ data>.
  • a data logging message 90 may also include a transaction type dimension variable 101, which is a character string that stores information indicating the type of a particular transaction to which the message pertains.
  • the transaction type may identify the transaction as being of a URL type 128, a SQL statement type 130, an SQL phase type 132, an e-mail type 134, or an XSL instantiation type 136, to name a few examples.
  • a data logging message 90 may also include a transaction name dimension variable 102, which is a character string that further identifies the particular instance of the transaction type (e.g., for a URL transaction type, the specific URL function within an application, e.g. "Viewltem").
  • a transaction name dimension variable 102 is a character string that further identifies the particular instance of the transaction type (e.g., for a URL transaction type, the specific URL function within an application, e.g. "Viewltem").
  • a status code dimension variable 104 may indicate the status of the logged transaction data (e.g., whether a transaction was successful or unsuccessful) and also a specific error that resulted in the transaction being unsuccessful, if this is the case.
  • a duration variable 110 stores information indicating a time (e.g., in milliseconds) that a monitored application spent executing a particular transaction.
  • a timestamp variable 112 contains information indicating a time at which a relevant transaction may have started.
  • dimension variables 92 may, in one embodiment, be utilized to aggregate data in different dimensions.
  • Analysis variables 94 are simply aggregated across data sets determined by a dimensional analysis.
  • the "dimension" variables 92 may be regarded as identifying where in "space" certain data originated, and the analysis 94 variables encode values at points identified by the combination of the dimension variables 92.
  • a mapping e.g., a function
  • the domain may be defined as a vector space made up of the dimension variables (e.g.
  • the range may be defined as the analysis variables 94.
  • the only visible analysis variable 94 may be Transaction duration, although the values in the data variable 114 portion of the message 90 may also include analysis variables 94 (which may require the inclusion of the names from the data as additional dimensional variables 92).
  • An aggregation operation transforms this vector space, so that one or more dimension variables are dropped, but analysis variables are added. For example, aggregation can be performed in the time dimension by dropping the seconds and milliseconds dimensions, and adding analysis variables 94 Transactions per second, Average Transaction duration, Events per second, and Average Value per second for each Heartbeat, for example.
  • FIG. 5 is a flowchart depicting a method 140, according to an exemplary embodiment, to monitor a diverse and heterogeneous application environment.
  • the method 140 is described in the exemplary embodiment as being performed within the context of any one of the architectures described in Figures 1-3.
  • an operator of the diverse and heterogeneous application environment instruments each application server 14 by installing a monitoring client 28 on, or making a monitoring client 28 available to, each application server 14, and also adding additional code to a monitored application to make function calls to a library of functions that may constitute the monitoring client 28.
  • a monitoring client 28 may constitute a library of functions that are linked to a monitored application server 14. If no modifications or changes are made to an application server 14, then the functions within the relevant library are simply unused, and "monitoring" of the application server 14 by the monitoring client 28 may not occur.
  • each monitored application of an application server 14 (and/or the application server 14 itself) may be "instrumented" by the addition of code to the monitored application, in the form of calls to the library of functions that constitute the monitoring client 28.
  • transactions may be regarded as being a particularly significant occurrence (or operations) to instrument. Key transactions to instrument may be so-called "entry point” transactions, and all "exit point” transactions.
  • an application server 14 typically operates to provide a service.
  • External applications e.g., a web browser, or a further application server in a multi-tiered enterprise architecture
  • the application server 14 receives the request, performs an action and returns a response.
  • the performed "action” or ("work") may be regarded as a transaction that can be instrumented.
  • such transactions may be labeled “root” or "level 0" transactions.
  • Other transactions that an application server 14 executes are typically nested inside a “root” transaction.
  • An application log (e.g., for one thread of execution in the application) may be recorded as a sequence of "root” transactions.
  • the "root” transaction may be of the type URL.
  • a billing application server is typically not implemented as a web server and may accordingly not serve URL requests.
  • a billing application server will typically still have a main entry point, where it processes requests that might be called of type "billing."
  • Several different kinds of billing requests may be served by an exemplary billing application server.
  • the billing application server might allow for the collection of payment from a user for the purchase of an item utilizing different payment methods.
  • One billing transaction name might be, for example, "ChargeCreditCard,” while another transaction name might be "ChargeCheckAccount”. Any particular application server may have only one type of "root transaction,” but this is not required.
  • an "exit point” transaction may be where a specific application server 14 utilizes the services of an external server (e.g., it takes on the role of a client in a different client-server transaction).
  • An exemplary case is where an application server 14 makes use of an external database server (e.g., performs an SQL transaction).
  • an application server 14 makes use of an external billing application server
  • the relevant application server 14 will have an "exit point” transaction where it performs a call to the external billing application server 14.
  • an "entry point” transaction was identified as potentially being regarded as a "root” transaction.
  • an "exit point” transaction may be regarded as a "leaf transaction, and may appear in an application log as an atomic transaction.
  • An exemption to this rule may be when a "leaf transaction has an error of some kind that results in multiple "events" being logged. In such cases, the relevant "leaf transaction would be logged as a non-atomic transaction.
  • transactions may be regarded as important occurrences, and application servers 14 may be instrumented at operation 142 accordingly.
  • So-called “events” may, in one embodiment, also be regarded as important to log, and application servers 14 may also be instrumented to facilitate the logging of events.
  • events may be logged whenever there is a significant change of state, or when an error is detected at a location in code of an application server 14 that is not directly related to a particular transaction in progress.
  • an application server 14 may be instrumented to log "heartbeats" when the logging of transactions may be prohibitively expensive. For example, where a number of memory allocations made per second, statistics about the size of memory allocation requests, and even an amount of time (in nanoseconds) that it takes to perform each memory allocation are of interest, it will be appreciated that the logging of each memory allocation would be prohibitively expensive for a resource and bandwidth computational perspective. While it would of course be possible to instrument memory allocation functions, and to perform aggregation and analysis of information so gleaned, the overhead costs associated with doing so may not be justifiable. Accordingly, for certain types of information, there are advantages to generating a "heartbeat" (e.g., once every second or once every minute) to facilitate the logging of this type of information.
  • each of the installed monitoring clients 28 and/or application servers 14 logs transaction data and, utilizing the messaging API 30, and communicates the logging data in a common syntax to the cluster 16 of harvesters 18.
  • the logging data may be communicated as a data logging message 90 to a cluster of harvesters 18.
  • the logging data may be published, as a logging message 90, by a monitoring client 28 utilizing a publisher 82, directly over a publish/subscribe messaging bus 58.
  • each of the monitoring clients 28 may at block 144 monitor and log a wide variety of types of data, including origin information, in the form of pool and machine information, indicating an origin of the message 90, message class information, transaction name and type information, status information, duration information, timestamp information and other miscellaneous data.
  • This data may then be formatted, according to the messaging API 30, as a message 90 conforming to a common syntax.
  • the harvesters 18, having received the data logging messages 90 write logs into the disk array 38 via the network application server 42.
  • the logs written into the disk array 38 are used by the reporters 44 to generate the static reports providing snapshot and historical information pertaining to the cluster 12 of application servers 14.
  • the reporters 44 for example via a network 40, access the log information within the disk array 38, and generate periodic (e.g., hourly or daily) reports utilizing the logging data stored in the disk array 38.
  • the real-time servers 19, at block 150 aggregate statistics in real-time, utilizing messages received from the harvesters 18, as well as historical data retrieved from the disk array 38.
  • the messages communicated from the harvesters 18 typically include the same information as contained in a data logging message 90; however, the formatting of such messages may vary in order to facilitate writing of the logging data into the disk array 38. Nonetheless, the real-time servers 19 are able to receive and process this information to generate the aggregate statistics in near real-time.
  • FIG. 152 is a flowchart illustrating a method 152, according to one exemplary embodiment, for performing automatic problem detection within a diverse and heterogeneous application environment.
  • the method 152 comprises two phases running simultaneously in a pipeline, namely an aggregation phase whereby logged transaction data is aggregated, and an analysis phase wherein the aggregated data is analyzed.
  • the logged transaction data may be aggregated in a current time period (e.g., a current minute), while the analysis is performed on data aggregated with respect to a previous time period (e.g., a previous minute).
  • the method 152 is furthermore performed, as noted above, by an Automatic Problem Detection application 66 executing on each of the APD servers 60, and the harvesters 18.
  • the aggregation of the logged transaction data by the Automatic Problem Detection applications 66 may be viewed as transforming the logged transaction data into "heartbeats".
  • the analysis, in this embodiment, performed by the applications 66 is done on the "heartbeats".
  • a set of statistics may be transferred to a drill-down analysis algorithm 70 to analyze.
  • the data may thus be regarded as "heartbeat” data.
  • the aggregation may therefore be viewed as occurring in the time dimension, in order to do the transfer to "heartbeats".
  • the Automatic Problem Detection application 66 may also operate to aggregate in various "space" dimensions. For example, for each transaction time and for each pool 24, an Automatic Problem Detection application 66 may aggregate over all machines within a cluster 12 and produce "heartbeat" data such as, for example, the rate of transactions per minute per transaction type per pool, or the average transaction duration per type per pool.
  • the heartbeat information may be stored internally within a memory of an APD server 60, and thus not be encoded as "heartbeat messages" that are communicable on the publish/subscribe message bus 58.
  • an APD server 60 may support two tiers: a first tier responsible for the aggregation and the publication of "heartbeat” messages onto the message bus 58, and a second tier listening for "heartbeat” messages on the message bus 58, receiving such "heartbeat” messages, and performing analysis and alert functions utilizing data contained in such "heartbeat” messages.
  • the above-described two-tier architecture may provide certain advantages in that it may provide improved scalability for higher volumes of traffic and, may also facilitate the dissemination of "heartbeat" data to other services beyond Automatic Problem Detection. Concerning the scalability of Automatic Problem Detection functionality, for a large application environment, a number of "aggregators" may be required, each aggregating only a subset of information received from a cluster 12 of application servers. Further, it may also be desirable to split the analysis function among various nodes according to analysis function. Of course, in one embodiment in which the two-tier approach is followed, the analysis may be performed in just one node of the second tier and, this one node performing analysis for all traffic (e.g., log transaction data transfer).
  • an example of such a further service may be the "real-time" analysis services provided by the real-time servers 19 that are shown in Figures 2 and 3 to be coupled to the message bus 58.
  • the real-time servers may be required to also transform transactions (and events) into “heartbeats," thus duplicating operations that are also being performed by the Automatic Problem Detection applications 66.
  • the APD servers 60 support a two-tier architecture
  • the real-time servers 19 described herein wherein all information that is sent to the real-time servers 19 is in the form of one- second "heartbeats."
  • the APD servers 60 are described as generating one-minute "heartbeats," the APD servers 60 may nonetheless be computing a wider range of statistics than the real-time servers 19.
  • the two-tier architecture for the APD servers 60 may be utilized to consolidate certain aggregation operations that are then leveraged for above automatic problem detection purposes and for real-time report generation purposes.
  • any number of other services may also subscribe to aggregate information generated.
  • the method 152 described below provides one example of how the aggregation and analysis operations described above may be performed.
  • the method 152 commences at block 162 with the logging of transaction data at the various applications hosted on the application servers 14, utilizing the monitoring clients 28, as described above.
  • the logged transaction data is then communicated by the monitoring clients 28, utilizing the messaging API 30, to the harvesters 18 and the APD servers 60. This communication of information may occur via any of the systems 10, 50 and/or 80 described above with reference to Figure 3, for example.
  • the harvesters 18 perform data analysis on the incoming logged transaction data. Specifically, the harvesters 18 perform limited real-time analysis on raw messages 90 with a view to transforming the raw data into rows of data that can be inserted into an Online Analytical Processing (OLAP) data structure, which for the purposes of the present specification is conveniently labeled as a "multidimensional cube". As noted above, the data logging messages 90 include both dimension variables 92 and analysis variables 94. Utilizing the messages 90, the harvesters 18 are able to create transaction tables 180. Figure 7 illustrates an exemplary transaction table 180, including rows of transaction data suitable for insertion into an OLAP data structure that may be generated by the harvesters at block 166.
  • OLAP Online Analytical Processing
  • each of the harvesters 18 then creates a new OLAP data structure for regular, predetermined time intervals (e.g., every minute), these data structures being referred to as multidimensional cubes, or more simply as "cubes".
  • a cube is formed as an in-memory data structure optimized for speed. Cubes may be written to disk and then later read back into memory but, in one embodiment, operations are performed on a cube only when in memory.
  • an in-memory data structure it will be appreciated, places a limit on the number of rows that can be inserted into a cube but the cube data structure may take advantage of redundancy in data to achieve a high degree of compression.
  • a batch job forming part of the Automatic Problem Detection application 66, reads all of the cubes, created by the harvesters 18, for a predetermined time interval (e.g., one minute) and combines these cubes into a cluster-wide, unified cube (e.g., into a single cube for all data received from the cluster 12 of application servers 14) for the predetermined time interval.
  • the creation of the unified cube should, in one embodiment, take less than the predetermined time interval for which the cubes are generated in order to prevent the batch job from falling behind in the creation of unified cubes.
  • the batch job proceeds to compare the unified cube with reference OLAP data, in the exemplary embodiment termed a "range cube", so as to detect "out-of-range” deviations between the unified cube and the range cube.
  • the range cube may be drawn from a predetermined number of previous cubes, different numbers of which may have been selected for different time periods.
  • the range cube may be generated utilizing an immediately previous 60 cubes representing activity within the cluster 12 of application servers 14 within the last hour, a second predetermined number of cubes from a prior week, plus a further predetermined number of cubes from two weeks prior etc.
  • the comparison of the unified cube with the reference OLAP data may include identifying analysis variables 94 (e.g., analysis variables that may be included within raw logging data, or analysis variables that are derived from information included within the raw logging data) for multiple dimension variables 92 , or combinations of dimension variables 92 , and determining whether the analysis variables 94 are within an acceptable range.
  • the compa ⁇ son algorithm 71 of the automatic program detection application 66 determines whether any of the analysis variables 94 are out of range. If so, at block 176, the automatic problem detection application 66 may cause the issuing of an appropriate alert and also possibly the initiation of preventative or corrective actions (e.g., human or automated actions).
  • the method 152 proceeds to block 178, where an updated reference OLAP data structure (e.g., a range cube) is generated utilizing selected OLAP data structures.
  • the method 152 then loops back to block 162.
  • raw logging data may include a limited number of raw analysis variable information (e.g., transaction duration information, de ⁇ ved from a duration va ⁇ able 110 of a data logging message 90).
  • the summary node generation algorithm 68 of the automatic problem detection application 66 is able to derive further analysis variables 94, not necessarily included withm a message 90, from the data included within a message 90. To this end, the summary node generation algorithm 68 may generate a collection of derived analysis variables 94.
  • a summary table may be generated in which many transactions are summarized per row, based on a dimension variable.
  • the degree of summarization may depend upon a hierarchy defined with respect to the transaction variables 92. For example, at a highest level of summarization, a simple table could indicate a total for a number of errors detected across an entire cluster 12 of application servers 14.
  • Figure 8 illustrates an exemplary summary table 190 that may be generated by the summary node generation algorithm 68 for a dimensional analysis across the "transaction type" dimension variable 101.
  • the summary table 190 is also shown to include an error column 196, an average duration column 198, and a percentage long column 200, each of the columns 196, 198 and 200 being populated with de ⁇ ved analysis variables 94. It will, however, be appreciated that any number of summary tables may be generated, for different dimensional analyses, and each of these summary tables may include different analysis variables 94, either raw or de ⁇ ved.
  • Figure 9 is a diagrammatic representation of a dimensional hierarchy 210, according to an exemplary embodiment of the present invention.
  • the dimensional hierarchy 210 is, in one embodiment, generated by the drill-down analysis algo ⁇ thm 70 of the automatic problem detection application 66, and stored in memory (e.g., a Random Access Memory (RAM)), of an Automatic Problem Detection server 60.
  • the drill-down analysis algorithm 70 may generate any number of dimensional hierarchies (or trees) 210 to support an appropriate analysis.
  • the transaction name dimension variable 101 may be connected to a root of the hierarchy 210, and any one of the dimensional variables may be regarded as a child of the transaction name dimension variable 101.
  • the hierarchy 210 is shown to support a drill-down analysis through the transaction type dimensional variable 101, the pool dimensional variable 96, the machine dimensional variable 98, and finally the transaction name dimension variable 101.
  • Each of the nodes within the dimensional hierarchy 210 may have one or more summary tables associated therewith, summarizing various analysis variables at that level of the hierarchy 210.
  • the dimensional hierarchy 210, and the summary tables associated with each of the nodes support an effective drill-down analysis of logging data generated by the monitoring clients 28 deployed within the cluster 12 of application servers 14.
  • the summary tables 190 generated by the summary node generation algorithm 68 for each node of a dimensional hierarchy 210, may summarize logging data pertaining to a pre-determined time window or interval (e.g., a minute preceding a current minute in which the summary table 190 is viewable).
  • the unified OLAP data structure may be a "multi-dimensional cube", with all dimensions of the cube being regarded as independent and mathematically equal. Accordingly, an analysis, within the framework of a dimensional hierarchy, could be started utilizing any dimensional variable.
  • the exemplary dimensional hierarchy 210 illustrated in Figure 9 begins utilizing the transaction type dimension variable 101, but any of the dimension variables could be utilized as the start dimension variable.
  • Figures 10-12 illustrates exemplary summary tables, which may be presented to a user for analysis or utilized by the comparison algorithm 71 to perform a comparison against analysis variable thresholds contained, for example, within a reference OLAP data structure (e.g., a range cube) for the purposes of detecting problems within the cluster 12 of application servers 14.
  • the illustrated summary tables are generated by the summary node generation algorithm 68, and may, for example, support a drill-down analysis performed by the drill-down analysis algorithm 70.
  • the count total may be compared to minimum and maximum values within the reference OLAP data structure to determine whether the count is withm an acceptable range.
  • the reference OLAP data structure indicates that a total count of 2,000 errors within the cluster 12, within a mmute, is acceptable, but that if the number of errors exceeds this maximum threshold, a problem may exist.
  • the summary table 220 indicates that the number of errors, across all transaction types, withm the cluster 12 exceeds 4,000.
  • a problem exists for the monitored mmute, and the drill-down analysis algo ⁇ thm 70 will then proceed to perform a drill-down analysis with a view to identifying the specific problem and potentially to initiate a corrective action.
  • the drill-down analysis algorithm 70 may then expand the dimensional analysis by looking at the table 220, which indicates that the bulk of the detected errors occurred with respect to a URL transaction type. A compa ⁇ son may again be performed with respect to the reference OLAP data structure to determine that the number of errors pertaining to URL transactions falls outside of an acceptable range. The drill-down analysis algorithm 70 now continues the analysis to determine more specifically where the problem lies. A drill-down into the URL row of the summary table 220 reveals the summary table 222, which indicates that by far the majo ⁇ ty of the errors pertaining to the URL transaction have a ⁇ sen with respect to machines in pool 1.
  • the drill-down analysis algorithm 70 will utilize the reference OLAP data structure to identify the errors pertaining to the URL transactions within pool 1 as falling outside an acceptable range, and then drill-down on the row for pool 1 within the table 222, to reveal the summary tables 224 and 226.
  • the summary table 224 reveals that the machine "Marcus" in pool 1 is experiencing a hugely disproportionate number of errors for URL transactions. Accordingly, the d ⁇ ll-down analysis algorithm 70, on an analysis of the table 224, may generate an alert to a human administrator, or to an automatic maintenance program.
  • the automatic maintenance program may, responsive to the alert, shut down the errant machine "Marcus", or configure the clusters 12 so that URL transactions are diverted away from the machine "Marcus” (e.g., by appropriate configuration of a load balancer 26).
  • the drill-down analysis algorithm 70 may perform further analysis with respect to the machine "Marcus", to find an even more specific description of the problem. For example, a drill-down into the machine "Marcus” could be performed and an expansion on the status code dimension variable performed to reveal further details. For example, various status codes may provide further information regarding the nature of errors encountered.
  • the drill-down analysis algorithm 70 may then provide a count of the number of status codes of each type received (e.g., 3500 status codes 391 received, 200 status codes 415 received, etc.).
  • Figure 11 illustrates a drill-down analysis, (for example performed by the drill-down analysis algorithm 70 or a human operator) in which the observed errors pertaining to URL transactions are not caused by the machine "Marcus", but instead by a specific URL transaction (i.e., URL 2).
  • the summary table 224 reveals that the errors are uniformly distributed across all machines in the pool 1 , but that the observed problem is entirely specific to URL 1.
  • a further drill-down may be performed and an expansion by status code may be performed to determine if the errors are due to one specific error, associated with a specific status code.
  • Figure 12 illustrates a drill-down analysis, responsive to an observation that the number of URL transactions exceeds a threshold, in which a URL error storm is not specific to any URL transaction type, and is distributed across two machines “Attila” and “Lenin”. In this case, a specific build "E293" is identified as causing the URL storm.
  • the drill-down analyses illustrated in Figures 10-12 may be performed by a human operator, or may be automated and performed by the drill-down analysis algorithm 70.
  • a graphical user interface may present the various summary tables to the human operator, with each of the rows of the tables being selectable (e.g., being a URL) to be expandable to generate a more focused summary table.
  • a human operator by selecting rows within tables, may navigate a dimensional hierarchy 210 such as that shown in Figure 9, to identify the source of an observed problem.
  • the algorithm 70 may similarly navigate through a dimensional hierarchy 210 and perform various dimensional analyses with a view to pinpointing a source and/or cause of an observed problem or issue. For example, considering the drill-down analysis reflected in Figure 11, the algorithm 70 may drill-down to the summary table 224, observe that the errors are somewhat uniformly distributed across all machines within a particular pool, and based on this observation, determine that a further dimensional analysis (e.g., with respect to specific transaction names) is required. The summary node generation algorithm 68 may then generate the further summary table 226 on which a comparison operation, with respect to the reference OLAP data structure, is be performed.
  • a further dimensional analysis e.g., with respect to specific transaction names
  • the automatic problem detection application 66 operates to determine the root cause of an observed problem, and then proceeds to report the problem. Further, the automatic problem detection application 66 may, in one embodiment, determine the cause of a particular problem. For example, the application 66 may make an assessment as to whether the problem is being caused by a hardware failure, or a software bug. If the problem is identified as a hardware problem, the application 66 may furthermore identify the hardware problem as pertaining to RAM, a hard disk, a network interface, etc. This information may be determined based on the status codes pertaining to errors observed by the drill-down analysis algorithm 70, and included in a report (or alert) that is generated. The reports or alerts generated at block 176 may furthermore be sent to an event correlator (not shown), which operates to correlate events with events that may have been observed by other monitoring systems, the event correlator then providing output to a human operator.
  • an event correlator not shown
  • An alert that is presented to a human operator may also identify sources for the error that have been ruled out.
  • an alert may be presented as follows:
  • the alert text may also be hypertext-linked, so that text within the alert is user selectable to provide specific information.
  • the text "Exceeded the acceptable range of URL errors” may be hypertext-linked to generate a summary table that provides a count of the number of URL errors observed on the machine "Marcus”.
  • the text "not present in other machines in pool 1" may be hypertext-linked to present the table 224, illustrated in Figure 10, to a human operator.
  • the text "not a database problem” may be hypertext-linked to present the table 226 to a human operator.
  • the dimensional hierarchy 210 shown in Figure 9 illustrates merely one manner in which a drill-down analysis may be performed. It will be appreciated that other dimensional hierarchies may be generated to support an alternative drill-down analysis.
  • the reference OLAP data structure may be derived from a sample of many older OLAP data structures that provide an historic perspective on a "normal" state for the cluster 12. The reference OLAP data structure enables a determination to be made whether a specific analysis variable is within a "healthy" range, for a specific selection of dimension variable.
  • the reference OLAP data structure also enables an assessment of whether a specific analysis variable is too high or too low.
  • the reference OLAP data structure may be generated to provide context to a given time, day or date. A different reference OLAP data structure may be generated for each of the 160 hours of a week, for example.
  • the reference OLAP data structure may be continually updated so that it is always appropriate for a particular time, day or date.
  • the reference OLAP data structure that is utilized for the comparison operation performed at block 172 of the method 152 shown in Figure 6 should be representative of a "healthy" state for a monitored system, at a particular time, day and/or date.
  • a unique reference OLAP data structure is generated for each of the 160 hours of a week.
  • a 1 -minute reference OLAP data structure for up to one hour in the past (for a particular day) may be representative but an OLAP data structure two hours in the past may not be representative.
  • a 1 -minute reference OLAP data structure for a current hour one or two weeks in the past may be representative, but an OLAP data structure for a current hour one or two days in the past may not be representative.
  • a new reference OLAP data structure e.g., a range cube is created every minute.
  • the reference OLAP data structure may be created by drawing on a prior 60 minutes of activity (e.g., providing a potential sample of 60 OLAP data structures). Further, OLAP data structures for one week in the past, and allowing for plus or minus one hour, increases the potential sample to 121 further OLAP data structures. Going back two or more weeks in the past increases the sample by a further 121 OLAP data structures per week. In one embodiment, one month's worth of reference OLAP data structures may be retained, thus providing more than 858 representative OLAP data structures from which may be sampled.
  • the automatic problem detection application 66 may flag unified OLAP data structures as either being “healthy” or “unhealthy”, depending on whether a problem was detected within the relevant predetermined time interval (e.g., 1 minute).
  • the final flagging of a unified OLAP data structure as "healthy” or "unhealthy” may be subject to human confirmation.
  • the automatic problem detection application 66 may register a problem within a specific minute, but upon further human investigation the problem is determined in fact to represent a false positive.
  • a human operator may flag the relevant unified OLAP data structure as being "healthy", not withstanding that a problem was reported by the automatic problem detection application 66.
  • an assumption may be made that a reference OLAP data structure for one minute only exhibits minor differences from a reference OLAP data structure for the prior minute. This assumption may be factored into the determination of the health of a reference OLAP data structure for a particular minute, utilized to dampen the effects of any abnormal activities present in the other sample data, and also to account for changes with respect to the system over the sample period. For example, where a sample set extends one month into the past, system changes may have occurred that influence what may be regarded as a "healthy" state for a system.
  • the reference OLAP data structure from the preceding minute may be weighted in the calculation of the reference OLAP data structure so as to allow the current state of a system to more strongly influence what is considered to be a "healthy" state.
  • time, date and/or day may be particularly significant where the system being monitored is a website.
  • activity on a particular website may display significant variations, based on time, day and/or date.
  • time, day and/or date For example, where the website supports a commerce system, there may be specific times of the day in which transaction activity displays significant increases, and also specific days on which transaction volume is significantly higher than on other days. Further, transaction activity may increase as a specific calendar event (e.g., the Christmas holiday season) approaches.
  • one embodiment of the present invention seeks to provide a current reference OLAP data structure that provides an accurate representation of a "healthy" state for a monitored system, such as the cluster 12 of application servers 14.
  • the unified OLAP data structure may also be configured to have different resolutions.
  • the reference OLAP data structure may be provided with an error code level resolution, whereas in another embodiment, a reference OLAP data structure may be provided with a higher resolution (e.g., at a pool level).
  • Figure 13 shows a diagrammatic representation of machine in the exemplary form of a computer system 300 within which a set of instructions, for causing the machine to perform any one or more of the methodologies discussed herein, may be executed. In alternative embodiments, the machine operates as a standalone device or may be connected (e.g., networked) to other machines.
  • the machine may operate in the capacity of a server or a client machine in server-client network environment, or as a peer machine in a peer-to-peer (or distributed) network environment.
  • the machine may be a personal computer (PC), a tablet PC, a set-top box (STB), a Personal Digital Assistant (PDA), a cellular telephone, a web appliance, a network router, switch or bridge, or any machine capable of executing a set of instructions (sequential or otherwise) that specify actions to be taken by that machine.
  • the exemplary computer system 300 includes a processor 302 (e.g., a central processing unit (CPU), a graphics processing unit (GPU) or both), a main memory 304 and a static memory 306, which communicate with each other via a bus 308.
  • the computer system 300 may further include a video display unit 310 (e.g., a liquid crystal display (LCD) or a cathode ray tube (CRT)).
  • the computer system 300 also includes an alphanumeric input device 312 (e.g., a keyboard), a user interface (UI) navigation device 314 (e.g., a mouse), a disk drive unit 316, a signal generation device 318 (e.g., a speaker) and a network interface device 320.
  • the disk drive unit 316 includes a machine-readable medium 322 on which is stored one or more sets of instructions and data structures (e.g., software 324) embodying or utilized by any one or more of the methodologies or functions described herein.
  • the software 324 may also reside, completely or at least partially, within the main memory 304 and/or within the processor 302 during execution thereof by the computer system 300, the main memory 304 and the processor 302 also constituting machine-readable media.
  • the software 324 may further be transmitted or received over a network 326 via the network interface device 320 utilizing any one of a number of well-known transfer protocols (e.g., HTTP).
  • HTTP transfer protocol
  • machine-readable medium 392 is shown in an exemplary embodiment to be a single medium, the term “machine-readable medium” should be taken to include a single medium or multiple media (e.g., a centralized or distributed database, and/or associated caches and servers) that store the one or more sets of instructions.
  • the term “machine-readable medium” shall also be taken to include any medium that is capable of storing, encoding or carrying a set of instructions for execution by the machine and that cause the machine to perform any one or more of the methodologies of the present invention, or that is capable of storing, encoding or carrying data structures utilized by or associated with such a set of instructions.
  • machine-readable medium shall accordingly be taken to include, but not be limited to, solid-state memories, optical and magnetic media, and carrier wave signals.

Abstract

A method to monitor a diverse and heterogeneous application environment includes instrumenting each of a plurality of application servers with a monitoring client to log transaction, event and/or heartbeat data pertaining to a respective application server (Figure 2). The logged transaction data is communicated to a central logging system (62). The logged transaction data is then stored at the central logging system and/or published over a messaging bus. The logged transaction data is further aggregated so as to providing an aggregate view of the logged transaction data across the plurality of application servers (12). The logged transaction data is also communicated from each of the monitoring clients (28) to the central logging systems utilizing a common syntax so as to facilitate the aggregation of the logged transaction data.

Description

METHOD AND SYSTEM TO MONITOR A DIVERSE HETEROGENEOUS APPLICATION ENVIRONMENT
[0001] The present application claims the priority benefit of U.S. Provisional Application serial no. 60/548,357 filed February 27, 2004, which is incorporated herein by reference.
FIELD OF THE INVENTION
[0002] An embodiment relates generally to the field of system monitoring and administration and, more specifically, to a method and system to monitor a diverse heterogeneous application environment.
BACKGROUND OF THE INVENTION
[0003] As the complexity and throughput of application environments has increased, the technical challenges present in the monitoring, maintenance and administration of such application environments have also substantially increased. These technical challenges are particularly acute in enterprise application environments and Web-based (e.g., Application Service Provider (ASP)) environments, which may include a large number of applications servicing a large number of users and handling a large number of transactions. Consider, for example, a popular Web site that may be serviced by a rich application environment, including a large number of applications hosted on a collection of respective application servers. Such an application environment may include hundreds of diverse and heterogeneous applications, and may be required to handle millions of Uniform Resource Location (URL) requests, millions of e- mail messages, and billions of database inquiries (e.g., utilizing SQL statements) in a 24-hour period.
[0004] A failure in such an application environment can be disastrous, particularly where the application environment supports a live and real-time service (e.g., online or network-base commerce). The ability to monitor and quickly identify problems that may arise within an application environment is of course important for a number of reasons, and presents a number of technical challenges. SUMMARY OF THE INVENTION
[0005] According to a first aspect of the present invention, there is provided a method to monitor a diverse and heterogeneous application environment. Each of a plurality of application servers is instrumented to log data pertaining to a respective application server. The logged data is communicated to a central logging system. The logged data is further aggregated so as to provide an aggregate view of the logged data across the plurality of application servers. The logged transaction data is also communicated to the central logging systems utilizing a common syntax so as to facilitate the aggregation of the logged transaction data. [0006] According to a further aspect of the present invention, there is provided a method to detect potential problems within a heterogeneous and diverse application environment. Operations data is received from a plurality of application servers within the application environment, the operations data pertaining to operations performed at the plurality of application servers. The operations data pertaining to operations performed at the plurality of application servers, over a predetermined time interval, is aggregated. The aggregated data is compared to reference data, and a potential problem within the application environment is detected if the aggregated data deviates from the reference data in a predetermined manner. [0007] Other features of the present invention will be apparent from the accompanying drawings and from the detailed description that follows.
BRIEF DESCRIPTION OF THE DRAWINGS
[0008] An embodiment is illustrated by way of example and not limitation in the figures of the accompanying drawings, in which like references indicate similar elements and in which:
[0009] Figures 1-3 are block diagrams illustrating respective exemplary embodiments of systems to monitor a diverse and heterogeneous application environment.
[0010] Figure 4 is a diagrammatic representation of a data logging message, according to an exemplary embodiment, that may be generated by a monitoring client conforming to a messaging API.
[0011] Figure 5 is a flowchart depicting a method, according to an exemplary embodiment, to monitor a diverse and heterogeneous application environment. [0012] Figure 6 is a flowchart illustrating a method, according to one exemplary embodiment, to perform automatic problem detection within a diverse and heterogeneous application environment.
[0013] Figure 7 illustrates an exemplary transaction table that includes rows of transaction data, suitable for insertion into an OLAP data structure that may be generated by harvesters, in one exemplary embodiment.
[0014] Figure 8 illustrates an exemplary summary table that may be generated by a summary node generation algorithm for a dimensional analysis across a
"transaction type" dimension variable.
[0015] Figure 9 is a diagrammatic representation of a dimensional hierarchy, according to an exemplary embodiment.
[0016] Figures 10-12 illustrates exemplary summary tables that may be presented to a user for analysis, or alternatively utilized by a comparison algorithm to perform a comparison against analysis variable thresholds content, for example, within a reference OLAP data structure for the purpose of detecting problems within a cluster of application servers.
[0017] Figure 13 is a diagrammatic representation of a machine, an exemplary form of a computer system, within which a set of instructions, for causing the machine to perform any one of the methodologies discussed herein, may be executed.
DETAILED DESCRIPTION
[0018] A method and a system to monitor a diverse heterogeneous application environment are described. In the following description, for purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of the present invention. It will be evident, however, to one skilled in the art that the present invention may be practiced without these specific details.
[0019] Figures 1-3 are block diagrams illustrating respective exemplary embodiments of systems to monitor a diverse heterogeneous application environment, according to the present invention. The monitored application environment may, for example, include a large number of applications, each hosted on a respective application server and providing distinct application services. The diverse heterogeneous application environment may, for example, include applications providing, at one end of the spectrum, unrelated and distinct services or may include applications that provide distinct but partially or directly related services (e.g., purchase process and billing services).
[0020] Figure 1 is a block diagram illustrating a system 10, according to a first exemplary embodiment, to monitor a diverse and heterogeneous application environment. A cluster 12 of application servers 14 is shown to be coupled to, and in communication with, a cluster 16 of harvesters 18. The cluster 16 of harvesters 18 is then coupled to an extensible collection of data analysis services 20, and a central logging system 22.
[0021] Returning to the cluster 12 of application servers 14, pools 24 of application servers 14 may be locally networked, and associated with a dedicated load balancer 26 that operates to balance load between the application servers 14 within a particular pool 24. The application servers 14 within a particular pool 24 may provide a common set of application services. [0022] Each of the application servers 14 is furthermore instrumented with a monitoring client 28 that, as will be described in further detail below, monitors a predetermined set of activities and parameters of a host application server, and communicates messages reflecting such activities and parameters utilizing a messaging Application Program Interface (API) 30. The messaging API 30 defines a common syntax, which will be described more fully below, to communicate with the cluster 16 of harvesters 18 and the central logging system 22. The common syntax allows a "de-coupling" of the application servers 14 from the harvesters 18 and the central logging system 22.
[0023] Logging data, generated by the monitoring client 28 and communicated by the messaging API 30, may be transmitted from an application server 14 via a local pool network 32, and an application server network 34, to a load balancer 36, which distributes the messages to harvesters 18 included within the cluster 16. The harvesters 18 then operate to write logs, including the logging data received in the logging data messages, to a disk array 38 via a network 40 and a network application server (NAS) 42.
[0024] The data analysis services 20 may, as will be described in further detail below, include a number of services. In the exemplary embodiment illustrated in Figure 1, a number of reporters 44 operate to generate periodic (e.g., hourly and daily) reports regarding activities and parameters of the application servers 14, utilizing the logs written into the disk array 38. Specifically, the reporters 44 may retrieve the logs from the disk array 38 via the local network 40 and the network application server 42. The reports generated by the reporters 44 may be so- called "static" reports, in that they present a static view of the logging data for a particular time period. [0025] In contrast to the "static" reports generated by the reporters 44, real-time servers 19 operates to aggregate received logging data from the harvesters 18, via the network 40, in near real-time, and to present a number of near real-time views of activities and parameters pertaining to the application servers 14. For example, one or more real-time servers 19 may present aggregated statistics regarding the various parameters pertaining to individual application servers 14, or collections (e.g., pools 24) of application servers, or of all applications across the entire cluster 12 of application servers 14.
[0026] In the exemplary system 10 illustrating Figure 1, communications between the application servers 14 and the cluster 16 of harvesters 18 are shown to be performed utilizing the Transmission Control Protocol (TCP) 46. Communications between the harvesters 18, the realtime servers 19, the data analysis services 20, and the central logging system 22 are shown to be performed utilizing the Network File System (NFS), which is a client/application communication systems that allows network users to access shared files stored on computers of different types.
[0027] The exemplary embodiments illustrated in Figures 2 and 3 are architected utilizing a publish/subscribe messaging communications system 50, which utilizes a publish/subscribe messaging bus to communicate messages between various entities.
[0028] Specifically, Figure 2 is a block diagram illustrating a system 50, according to a further exemplary embodiment, to monitor a diverse, heterogeneous application environment. As with the system 10, described above with reference to Figure 1, the system 50 includes a number of monitoring clients 28 that are utilized to instrument application servers 14 included within a cluster 12 of application servers. The application servers 14 may also, as illustrated, be arranged in pools 24. The architecture of the system 50 departs from that of the system 10 illustrated in Figure 1 in that a publish/subscribe message bus communications protocol 52 is utilized to communicate logging data messages, generated by the monitoring clients 28 and conforming to the messaging API 30. Specifically, messages are communicated from the monitoring client 28, utilizing the messaging API 30, to one or more publishers 54, via a load balancer 56. The logging data messages are then published by the publishers 54 onto a publish/subscribe messaging bus 58. The real-time servers 19, the harvesters 18 and one or more further data analysis services (e.g., an Automatic Problem Detection (APD) service provided by one or more APD servers 60) are instrumented with subscriber components, and are accordingly able to subscribe to the logging data messages that are published by the publishers 54 onto the publish/subscribe messaging bus 58. The harvesters 18 then, in the same manner as described above with reference to Figure 1, communicate logging data to one or more reporters 44, and also write appropriate logs into the disk array 38 via the network application server 42. Communications between the harvesters 18, the reporters 44, and the disk array 38 are shown to be performed utilizing the Network File System (NFS). Figure 2 illustrates that the collection of real-time servers 19, harvesters 18, Automatic Problem Detection (APD) servers 60, reporters 44, Network Application Server 42, and the disk array 38 may be considered to be a central logging and data analysis service 62. Figure 2 also illustrates that the system 50 may include a production environment of the central logging and data analysis services, as well as a test environment 64.
[0029] As noted above, the data analysis services 62 are shown to include one or more Application Problem Detection (APD) servers 60, each of which hosts an Automatic Problem Detection (APD) application 66. Each APD application 66 operates, in one exemplary, to analyze logging data messages, received from the monitoring clients 28 via the messaging bus 58, m near real-time to detect actual or potential problems, and to generate alerts. These alerts may, in one embodiment, be connected to appropriate direct or indirect actions. To this end, each APD application 66 is shown in Figure 2 to include a summary node generation algoπthm 68 and a drill-down analysis algorithm 70. Each drill-down analysis algorithm 70 includes a comparison algorithm 71. The functioning of an exemplary embodiment of an APD application 66 will be described in further detail below.
[0030] Figure 3 is a block diagram illustrating a system 80, according to yet a further exemplary embodiment, to monitor a diverse and heterogeneous application environment. The system 80 is similar to that shown in Figure 3, but differs in that the monitoπng clients 28 no longer communicate with publishers 54 utilizing TCP, but publish logging data messages directly onto the publish/subscribe messaging bus 58. To this end, each of the monitoring clients 28 is shown to incorporate a publisher component 82.
[0031] As has been descπbed above with reference to Figures 1-3, each of the application servers 14 is instrumented with a monitoring client 28, which communicates logging data messages utilizing a messaging API 30, these logging data messages being reported to a central logging system and to data analysis services. These messages may be communicated utilizing any one, or combination of, a number of well-known communications and messaging protocols (e.g., a transport protocol (e.g., TCP), a messaging protocol (e.g., utilizing a publish/subscribe messaging bus such as the TIB, developed by Tibco Software Inc., of Palo Alto, California), or a network file sharing system (e.g., the NFS developed by Sun Microsystems Inc., of Santa Clara, California)). The vaπous exemplary embodiments of a system to monitor an application environment, and described with reference to Figures 1-3, show increasingly heavy deployment of a publish/subscribe messaging bus to facilitate communications between various components of a system. In certain applications, the use of a publish/subscribe messaging bus may allow components to broadcast and receive logging data messages in an efficient manner, and to allow components to have the ability to perform work in parallel, rather than in a serial manner. For example, rather than have a single component to receive a message, process the message, and then forward the original messages on to a downstream component, individual components may, utilizing a publish/subscribe message bus, be able to better utilize resources by concentrating solely on the local processing of received messages. The utilization of a publish/subscribe messaging bus architecture may also, in certain applications, enable scalability within a system by simplifying the action of adding a new hardware component. In its fullest implementation, a message bus 58 may allow a process or thread located anywhere within a system (e.g., the system 80) to be connected to the publish/subscribe bus, and to communicate with all other processes connected to the same bus.
[0032] Regardless of the messaging/communication protocol utilized to communicate, each of the monitoring clients 28, with which the respective application servers 14 of an application environment are instrumented, may communicate with a central logging system, and data analysis services, utilizing a generalized messaging API 30. This may provide certain advantages. For example, the unified and extensible logging of a set of diverse and heterogeneous applications may be enabled by instrumenting such application servers 14 utilizing monitoring clients 28 that communicate in a common syntax supported by the messaging API 30. Further, the common syntax supported by the messaging API 30 may provide for the simplified instrumentation of the application servers 14.
[0033] Figure 4 is a diagrammatic representation of a data logging message 90, according to an exemplary embodiment, that may be generated by a monitoring client 28, conforming to the messaging API 30. In the exemplary embodiment, a data logging message 90 is generated, by a respective monitoring client 28, for each observed transaction pertaining to a monitored application. Each monitoring client 28 may be adapted to monitor a specific application, or application type, within a diverse and heterogeneous application environment. Regardless of the diversity of applications monitored, each monitoring client 28 may utilize the messaging API 30 to communicate logging data messages conforming to a common syntax, such as that described below with reference to Figure 4. For the purposes of the present specification, the term "transaction", to which a particular data logging message 90 may pertain, may be regarded as a flow of processing, or unit of work, that takes time to complete (e.g., has a start and an end). [0034] Further, a transaction may optionally be regarded as either being successful or unsuccessful. Consider that if a transaction fails, an error code may identify the type of error that has caused the transaction to be unsuccessful. Further, each of the monitoring clients 28 may include a precision timer (not shown), which allows the monitoring client 28 to determine the time taken for a transaction to complete.
[0035] Transactions, monitored by a respective monitoring client 28, may furthermore be classified as being of a particular transaction type according to a predefined set of transaction types. For example, in one embodiment, a predefined set of transaction types may include URL,
SQL, e-mail, XSLT, Logic, SQLOpen, SQLExe, and SQLFetch transactions, for example. Any number of transaction types may be defined.
[0036] Transactions may furthermore be nested. For example, an SQL transaction may be nested within a URL transaction and an XSLT transaction may be nested in an e-mail transaction, which is in turn nested in a URL transaction. For each transaction observed by a monitoring client 28, one or more data logging messages 90 may be generated.
[0037] Turning now specifically to the exemplary message 90 shown in Figure 4, each message may include a number of fields. An exemplary syntax is provided below. A pool dimension variable 96 may indicate a pool 24 of application servers 14 from which the message 90 originated. Similarly, a machine dimension variable 98 indicates a specific machine (e.g., an application server 14) from which the relevant message 90 originated.
[0038] Each message 90 further includes a message class dimension variable 100 that, in the exemplary embodiment, identifies the message as belonging to one of five classes namely: 1. A Transaction Start class 118; 2. A Transaction End class 120; 3. A Transaction Atomic class 122; 4. A Heartbeat class 124; and 5. An Event class 126.
[0039] Messages of the Transaction Start and the Transaction End classes 118 and 120 identify the start and end of transactions, as may be observed by a monitoring client 28 with respect to a monitored application. Messages of the Transaction Start and Transaction End classes 118 and 120 are normally utilized to report detected transactions or events pertaining to a particular transaction. Exemplary formats for messages of the classes 118 and 120 may be: t <timestamp> <type> //... nested messages T <timestamp> <type> <name> <status> <duration> <data>. As will be described below, in the event that no nested transaction messages are generated, a message of the Transaction Atomic class 122 may be generated. Messages belonging to the Transaction Atomic class 122 facilitate optimization of message communication and generation in that, if there are no other messages between a Transaction Start and a Transaction End, only a single message, of the Transaction Atomic class 122, is written. Accordingly, in one exemplary embodiment, the monitoring client 28 may perform a "lazy" evaluation of a transaction start, in that a message of the Transaction Start class 118 is only written if a subsequent event, pertaining to the relevant transaction, is registered prior to the transaction end. An exemplary format for a message of the Transaction Atomic class 122 may be: A <timestamp> <type> <name> <status> <duration> <data>. [0040] Messages of the Heartbeat class 124 may report statistical "heartbeats" concerning certain applications, the "heartbeats" being computed internally and logged at regular intervals. It will be appreciated that the statistics may be highly application dependent, or may be more general (e.g., percentage CPU utilization and percentage memory utilization). An exemplary format for a message of the Heartbeat class 124 is: H <timestamp > <type> <name> <status> <data>. [0041] Messages of the Event class 126 (Event Messages) are "catch all" messages for other types of messages that may not be transaction or heartbeat messages. As such, Event messages are for recording "instantaneous" and "aperiodic" actions. An non-instantaneous "event" may be more appropriately considered to be a Transaction. Likewise, a periodic action may be more appropriately considered to be a Heartbeat. One exemplary Event in the current embodiment is for acknowledging the detection of service Mark-Down. Information included within a message of the Event class 126 may include warning, error, exception or other types of internal data specific to a particular environment. The format of an exemplary message of the Event class 126 may be: E <timestamp> <type> <name> <status> <data>. [0042] A data logging message 90 may also include a transaction type dimension variable 101, which is a character string that stores information indicating the type of a particular transaction to which the message pertains. For example, where the heterogeneous application environment being monitored is supporting a website, the transaction type may identify the transaction as being of a URL type 128, a SQL statement type 130, an SQL phase type 132, an e-mail type 134, or an XSL instantiation type 136, to name a few examples.
[0043] A data logging message 90 may also include a transaction name dimension variable 102, which is a character string that further identifies the particular instance of the transaction type (e.g., for a URL transaction type, the specific URL function within an application, e.g. "Viewltem").
[0044] A status code dimension variable 104 may indicate the status of the logged transaction data (e.g., whether a transaction was successful or unsuccessful) and also a specific error that resulted in the transaction being unsuccessful, if this is the case.
[0045] A duration variable 110 stores information indicating a time (e.g., in milliseconds) that a monitored application spent executing a particular transaction. A timestamp variable 112 contains information indicating a time at which a relevant transaction may have started. Finally, a data variable 114 stores a list of name-value pairs pertinent to a monitored transaction (e.g., name=value & ... & name=value).
[0046] As noted, certain of the variables within a data logging message 90 may be classified as dimension variables 92, whereas others may be classified as analysis variables 94. Specifically, dimension variables 92 may, in one embodiment, be utilized to aggregate data in different dimensions. Analysis variables 94, on the other hand, are simply aggregated across data sets determined by a dimensional analysis. Expressed differently, the "dimension" variables 92 may be regarded as identifying where in "space" certain data originated, and the analysis 94 variables encode values at points identified by the combination of the dimension variables 92. In one embodiment, a mapping (e.g., a function) may map a domain to a range. The domain may be defined as a vector space made up of the dimension variables (e.g. Pool, Machine, Message Class, Message Type, Message Name, Message Status, and also Message Time). The range may be defined as the analysis variables 94. Without any aggregation, the only visible analysis variable 94 may be Transaction duration, although the values in the data variable 114 portion of the message 90 may also include analysis variables 94 (which may require the inclusion of the names from the data as additional dimensional variables 92). An aggregation operation transforms this vector space, so that one or more dimension variables are dropped, but analysis variables are added. For example, aggregation can be performed in the time dimension by dropping the seconds and milliseconds dimensions, and adding analysis variables 94 Transactions per second, Average Transaction duration, Events per second, and Average Value per second for each Heartbeat, for example.
[0047] Figure 5 is a flowchart depicting a method 140, according to an exemplary embodiment, to monitor a diverse and heterogeneous application environment. The method 140 is described in the exemplary embodiment as being performed within the context of any one of the architectures described in Figures 1-3. [0048] At block 142, an operator of the diverse and heterogeneous application environment instruments each application server 14 by installing a monitoring client 28 on, or making a monitoring client 28 available to, each application server 14, and also adding additional code to a monitored application to make function calls to a library of functions that may constitute the monitoring client 28.
[0049] Further details regarding interactions between an application server 14, and a monitoring client 28, according an exemplary embodiment, will now be discussed. In one embodiment, a monitoring client 28 may constitute a library of functions that are linked to a monitored application server 14. If no modifications or changes are made to an application server 14, then the functions within the relevant library are simply unused, and "monitoring" of the application server 14 by the monitoring client 28 may not occur. In one embodiment, each monitored application of an application server 14 (and/or the application server 14 itself) may be "instrumented" by the addition of code to the monitored application, in the form of calls to the library of functions that constitute the monitoring client 28. Calls to the library of functions result in messages being generated, packaged and sent from the monitored application server 14 and/or monitoring client 28 to the central logging and data analysis services 62. [0050] According to an exemplary approach to logging, transactions may be regarded as being a particularly significant occurrence (or operations) to instrument. Key transactions to instrument may be so-called "entry point" transactions, and all "exit point" transactions. Consider that an application server 14 typically operates to provide a service. External applications, (e.g., a web browser, or a further application server in a multi-tiered enterprise architecture) may make requests to a particular application server 14. The application server 14 receives the request, performs an action and returns a response. The performed "action" or ("work") may be regarded as a transaction that can be instrumented. In one embodiment, such transactions may be labeled "root" or "level 0" transactions. Other transactions that an application server 14 executes are typically nested inside a "root" transaction. An application log (e.g., for one thread of execution in the application) may be recorded as a sequence of "root" transactions. Consider that, in a simple web server, the "root" transaction may be of the type URL. A billing application server, on the other hand, is typically not implemented as a web server and may accordingly not serve URL requests. Nonetheless, a billing application server will typically still have a main entry point, where it processes requests that might be called of type "billing." Several different kinds of billing requests may be served by an exemplary billing application server. For example, the billing application server might allow for the collection of payment from a user for the purchase of an item utilizing different payment methods. One billing transaction name might be, for example, "ChargeCreditCard," while another transaction name might be "ChargeCheckAccount". Any particular application server may have only one type of "root transaction," but this is not required.
[0051] In one embodiment, it may be desirable to instrument both an "entry point" transaction and all "exit point" transactions as noted above. An "exit point" transaction may be where a specific application server 14 utilizes the services of an external server (e.g., it takes on the role of a client in a different client-server transaction). An exemplary case is where an application server 14 makes use of an external database server (e.g., performs an SQL transaction). However, there may be many different kinds of "exit point" transactions. Continuing the above example, where an application server 14 makes use of an external billing application server, the relevant application server 14 will have an "exit point" transaction where it performs a call to the external billing application server 14.
[0052] In one embodiment, it may be useful to instrument both ends of a client-server transaction. Earlier, an "entry point" transaction was identified as potentially being regarded as a "root" transaction. Similarly, an "exit point" transaction may be regarded as a "leaf transaction, and may appear in an application log as an atomic transaction. An exemption to this rule may be when a "leaf transaction has an error of some kind that results in multiple "events" being logged. In such cases, the relevant "leaf transaction would be logged as a non-atomic transaction.
[0053] As noted above, in one embodiment, transactions may be regarded as important occurrences, and application servers 14 may be instrumented at operation 142 accordingly. So- called "events" may, in one embodiment, also be regarded as important to log, and application servers 14 may also be instrumented to facilitate the logging of events. In one embodiment, events may be logged whenever there is a significant change of state, or when an error is detected at a location in code of an application server 14 that is not directly related to a particular transaction in progress.
[0054] Further, an application server 14 may be instrumented to log "heartbeats" when the logging of transactions may be prohibitively expensive. For example, where a number of memory allocations made per second, statistics about the size of memory allocation requests, and even an amount of time (in nanoseconds) that it takes to perform each memory allocation are of interest, it will be appreciated that the logging of each memory allocation would be prohibitively expensive for a resource and bandwidth computational perspective. While it would of course be possible to instrument memory allocation functions, and to perform aggregation and analysis of information so gleaned, the overhead costs associated with doing so may not be justifiable. Accordingly, for certain types of information, there are advantages to generating a "heartbeat" (e.g., once every second or once every minute) to facilitate the logging of this type of information.
[0055] At block 144, each of the installed monitoring clients 28 and/or application servers 14 logs transaction data and, utilizing the messaging API 30, and communicates the logging data in a common syntax to the cluster 16 of harvesters 18. In the exemplary system shown in Figure 1, the logging data may be communicated as a data logging message 90 to a cluster of harvesters 18. Alternatively, in the system 80 shown in Figure 3, the logging data may be published, as a logging message 90, by a monitoring client 28 utilizing a publisher 82, directly over a publish/subscribe messaging bus 58.
[0056] As noted above with respect to the description of the data logging message 90, each of the monitoring clients 28 may at block 144 monitor and log a wide variety of types of data, including origin information, in the form of pool and machine information, indicating an origin of the message 90, message class information, transaction name and type information, status information, duration information, timestamp information and other miscellaneous data. This data may then be formatted, according to the messaging API 30, as a message 90 conforming to a common syntax.
[0057] At block 146, the harvesters 18, having received the data logging messages 90, write logs into the disk array 38 via the network application server 42. The logs written into the disk array 38 are used by the reporters 44 to generate the static reports providing snapshot and historical information pertaining to the cluster 12 of application servers 14. [0058] Accordingly, at block 148, the reporters 44, for example via a network 40, access the log information within the disk array 38, and generate periodic (e.g., hourly or daily) reports utilizing the logging data stored in the disk array 38.
[0059] The real-time servers 19, at block 150, aggregate statistics in real-time, utilizing messages received from the harvesters 18, as well as historical data retrieved from the disk array 38. The messages communicated from the harvesters 18 typically include the same information as contained in a data logging message 90; however, the formatting of such messages may vary in order to facilitate writing of the logging data into the disk array 38. Nonetheless, the real-time servers 19 are able to receive and process this information to generate the aggregate statistics in near real-time.
[0060] Similarly, at block 152, the Automated Problem Detection (APD) servers 60, described above with reference to Figures 2 and 3, utilize the logging data contained within the data logging messages 90 to detect actual and potential issues in near real-time, to generate alerts, and, where appropriate, to initiate preventative or corrective actions. Further details regarding the operation of an exemplary Automatic Problem Detection application 66 will be described in further detail below. The method 140 then terminates at block 154. [0061] Figure 6 is a flowchart illustrating a method 152, according to one exemplary embodiment, for performing automatic problem detection within a diverse and heterogeneous application environment. At a high level, the method 152 comprises two phases running simultaneously in a pipeline, namely an aggregation phase whereby logged transaction data is aggregated, and an analysis phase wherein the aggregated data is analyzed. In one embodiment, the logged transaction data may be aggregated in a current time period (e.g., a current minute), while the analysis is performed on data aggregated with respect to a previous time period (e.g., a previous minute). The method 152 is furthermore performed, as noted above, by an Automatic Problem Detection application 66 executing on each of the APD servers 60, and the harvesters 18.
[0062] In one embodiment, the aggregation of the logged transaction data by the Automatic Problem Detection applications 66 may be viewed as transforming the logged transaction data into "heartbeats". The analysis, in this embodiment, performed by the applications 66 is done on the "heartbeats". Considering again the example in which aggregation is done on one-minute intervals, at the end of each minute, a set of statistics may be transferred to a drill-down analysis algorithm 70 to analyze. As the data is transferred once per minute, the data may thus be regarded as "heartbeat" data. The aggregation may therefore be viewed as occurring in the time dimension, in order to do the transfer to "heartbeats". However, the Automatic Problem Detection application 66 may also operate to aggregate in various "space" dimensions. For example, for each transaction time and for each pool 24, an Automatic Problem Detection application 66 may aggregate over all machines within a cluster 12 and produce "heartbeat" data such as, for example, the rate of transactions per minute per transaction type per pool, or the average transaction duration per type per pool.
[0063] In one embodiment of the Application Problem Detection application 66, the heartbeat information may be stored internally within a memory of an APD server 60, and thus not be encoded as "heartbeat messages" that are communicable on the publish/subscribe message bus 58. In alternative embodiments, an APD server 60 may support two tiers: a first tier responsible for the aggregation and the publication of "heartbeat" messages onto the message bus 58, and a second tier listening for "heartbeat" messages on the message bus 58, receiving such "heartbeat" messages, and performing analysis and alert functions utilizing data contained in such "heartbeat" messages. The above-described two-tier architecture may provide certain advantages in that it may provide improved scalability for higher volumes of traffic and, may also facilitate the dissemination of "heartbeat" data to other services beyond Automatic Problem Detection. Concerning the scalability of Automatic Problem Detection functionality, for a large application environment, a number of "aggregators" may be required, each aggregating only a subset of information received from a cluster 12 of application servers. Further, it may also be desirable to split the analysis function among various nodes according to analysis function. Of course, in one embodiment in which the two-tier approach is followed, the analysis may be performed in just one node of the second tier and, this one node performing analysis for all traffic (e.g., log transaction data transfer).
[0064] Regarding the availability of "heartbeat" information to other services, an example of such a further service may be the "real-time" analysis services provided by the real-time servers 19 that are shown in Figures 2 and 3 to be coupled to the message bus 58. In a single tier embodiment, the real-time servers may be required to also transform transactions (and events) into "heartbeats," thus duplicating operations that are also being performed by the Automatic Problem Detection applications 66. Where the APD servers 60 support a two-tier architecture consider the exemplary embodiment described above where the real-time servers 19 described herein wherein all information that is sent to the real-time servers 19 is in the form of one- second "heartbeats." Although the APD servers 60 are described as generating one-minute "heartbeats," the APD servers 60 may nonetheless be computing a wider range of statistics than the real-time servers 19. Accordingly, the two-tier architecture for the APD servers 60 may be utilized to consolidate certain aggregation operations that are then leveraged for above automatic problem detection purposes and for real-time report generation purposes. Of course, any number of other services may also subscribe to aggregate information generated. The method 152 described below provides one example of how the aggregation and analysis operations described above may be performed.
[0065] The method 152 commences at block 162 with the logging of transaction data at the various applications hosted on the application servers 14, utilizing the monitoring clients 28, as described above. The logged transaction data is then communicated by the monitoring clients 28, utilizing the messaging API 30, to the harvesters 18 and the APD servers 60. This communication of information may occur via any of the systems 10, 50 and/or 80 described above with reference to Figure 3, for example.
[0066] At block 166, the harvesters 18 perform data analysis on the incoming logged transaction data. Specifically, the harvesters 18 perform limited real-time analysis on raw messages 90 with a view to transforming the raw data into rows of data that can be inserted into an Online Analytical Processing (OLAP) data structure, which for the purposes of the present specification is conveniently labeled as a "multidimensional cube". As noted above, the data logging messages 90 include both dimension variables 92 and analysis variables 94. Utilizing the messages 90, the harvesters 18 are able to create transaction tables 180. Figure 7 illustrates an exemplary transaction table 180, including rows of transaction data suitable for insertion into an OLAP data structure that may be generated by the harvesters at block 166. [0067] Moving on to block 168, each of the harvesters 18 then creates a new OLAP data structure for regular, predetermined time intervals (e.g., every minute), these data structures being referred to as multidimensional cubes, or more simply as "cubes". In one embodiment, a cube is formed as an in-memory data structure optimized for speed. Cubes may be written to disk and then later read back into memory but, in one embodiment, operations are performed on a cube only when in memory. Working with an in-memory data structure, it will be appreciated, places a limit on the number of rows that can be inserted into a cube but the cube data structure may take advantage of redundancy in data to achieve a high degree of compression. At block 170, a batch job, forming part of the Automatic Problem Detection application 66, reads all of the cubes, created by the harvesters 18, for a predetermined time interval (e.g., one minute) and combines these cubes into a cluster-wide, unified cube (e.g., into a single cube for all data received from the cluster 12 of application servers 14) for the predetermined time interval. The creation of the unified cube (or OLAP data structure) should, in one embodiment, take less than the predetermined time interval for which the cubes are generated in order to prevent the batch job from falling behind in the creation of unified cubes. At block 172, the batch job proceeds to compare the unified cube with reference OLAP data, in the exemplary embodiment termed a "range cube", so as to detect "out-of-range" deviations between the unified cube and the range cube. The range cube may be drawn from a predetermined number of previous cubes, different numbers of which may have been selected for different time periods. For example, the range cube may be generated utilizing an immediately previous 60 cubes representing activity within the cluster 12 of application servers 14 within the last hour, a second predetermined number of cubes from a prior week, plus a further predetermined number of cubes from two weeks prior etc. [0047] The comparison of the unified cube with the reference OLAP data may include identifying analysis variables 94 (e.g., analysis variables that may be included within raw logging data, or analysis variables that are derived from information included within the raw logging data) for multiple dimension variables 92 , or combinations of dimension variables 92 , and determining whether the analysis variables 94 are within an acceptable range. [0048] At decision block 174, the compaπson algorithm 71 of the automatic program detection application 66 determines whether any of the analysis variables 94 are out of range. If so, at block 176, the automatic problem detection application 66 may cause the issuing of an appropriate alert and also possibly the initiation of preventative or corrective actions (e.g., human or automated actions). In the event that none of the analysis vanables is out of range, the method 152 proceeds to block 178, where an updated reference OLAP data structure (e.g., a range cube) is generated utilizing selected OLAP data structures. The method 152 then loops back to block 162.
[0049] Further detail regarding comparison operations that may, in one exemplary embodiment of the present invention, be performed at block 172 will now be descπbed. As will be appreciated, raw logging data may include a limited number of raw analysis variable information (e.g., transaction duration information, deπved from a duration vaπable 110 of a data logging message 90). However, the summary node generation algorithm 68 of the automatic problem detection application 66 is able to derive further analysis variables 94, not necessarily included withm a message 90, from the data included within a message 90. To this end, the summary node generation algorithm 68 may generate a collection of derived analysis variables 94. [0050] For any given dimensional analysis (i.e., an analysis performed on any of the dimension variables 92), a summary table may be generated in which many transactions are summarized per row, based on a dimension variable. The degree of summarization may depend upon a hierarchy defined with respect to the transaction variables 92. For example, at a highest level of summarization, a simple table could indicate a total for a number of errors detected across an entire cluster 12 of application servers 14.
[0051] Figure 8 illustrates an exemplary summary table 190 that may be generated by the summary node generation algorithm 68 for a dimensional analysis across the "transaction type" dimension variable 101. The summary table 190 is also shown to include an error column 196, an average duration column 198, and a percentage long column 200, each of the columns 196, 198 and 200 being populated with deπved analysis variables 94. It will, however, be appreciated that any number of summary tables may be generated, for different dimensional analyses, and each of these summary tables may include different analysis variables 94, either raw or deπved. [0052] Figure 9 is a diagrammatic representation of a dimensional hierarchy 210, according to an exemplary embodiment of the present invention. The dimensional hierarchy 210 is, in one embodiment, generated by the drill-down analysis algoπthm 70 of the automatic problem detection application 66, and stored in memory (e.g., a Random Access Memory (RAM)), of an Automatic Problem Detection server 60. Depending on the type of dπll-down analysis that may be required, the drill-down analysis algorithm 70 may generate any number of dimensional hierarchies (or trees) 210 to support an appropriate analysis. For example, in a further exemplary dimensional hierarchy 210, the transaction name dimension variable 101 may be connected to a root of the hierarchy 210, and any one of the dimensional variables may be regarded as a child of the transaction name dimension variable 101.
[0053] Turning to the exemplary dimensional hierarchy 210 shown in Figure 9, the hierarchy 210 is shown to support a drill-down analysis through the transaction type dimensional variable 101, the pool dimensional variable 96, the machine dimensional variable 98, and finally the transaction name dimension variable 101. Each of the nodes within the dimensional hierarchy 210 may have one or more summary tables associated therewith, summarizing various analysis variables at that level of the hierarchy 210. The dimensional hierarchy 210, and the summary tables associated with each of the nodes, support an effective drill-down analysis of logging data generated by the monitoring clients 28 deployed within the cluster 12 of application servers 14. [0054] As mentioned above, the summary tables 190, generated by the summary node generation algorithm 68 for each node of a dimensional hierarchy 210, may summarize logging data pertaining to a pre-determined time window or interval (e.g., a minute preceding a current minute in which the summary table 190 is viewable).
[0055] The unified OLAP data structure may be a "multi-dimensional cube", with all dimensions of the cube being regarded as independent and mathematically equal. Accordingly, an analysis, within the framework of a dimensional hierarchy, could be started utilizing any dimensional variable. The exemplary dimensional hierarchy 210 illustrated in Figure 9 begins utilizing the transaction type dimension variable 101, but any of the dimension variables could be utilized as the start dimension variable.
[0056] Figures 10-12 illustrates exemplary summary tables, which may be presented to a user for analysis or utilized by the comparison algorithm 71 to perform a comparison against analysis variable thresholds contained, for example, within a reference OLAP data structure (e.g., a range cube) for the purposes of detecting problems within the cluster 12 of application servers 14. The illustrated summary tables are generated by the summary node generation algorithm 68, and may, for example, support a drill-down analysis performed by the drill-down analysis algorithm 70.
[0057] Turning firstly to the exemplary set of summary tables shown in Figure 10, assume that a unified OLAP data structure has been generated, the unified OLAP data structure embodying logging data reflecting activities within the cluster 12 within a preceding time period (e.g., a minute). Failed transactions are a clear indicator of problems within the cluster 12, and may be indicated by non-zero values within status code dimension vanables 104 of data logging messages 90. The summary node generation algoπthm 68 creates a derived analysis vaπable, in which is counted the number of transactions in which the status code variable is non-zero. It will be appreciated that this count provides an indication of the number of errors encountered withm the cluster 12. To determine whether a count of unsuccessful transaction is problematic, the count total may be compared to minimum and maximum values within the reference OLAP data structure to determine whether the count is withm an acceptable range. [0058] Consider the example in which the reference OLAP data structure indicates that a total count of 2,000 errors within the cluster 12, within a mmute, is acceptable, but that if the number of errors exceeds this maximum threshold, a problem may exist. Turning specifically to Figure 10, it will be noted that the summary table 220 indicates that the number of errors, across all transaction types, withm the cluster 12 exceeds 4,000. Clearly, in this example, a problem exists for the monitored mmute, and the drill-down analysis algoπthm 70 will then proceed to perform a drill-down analysis with a view to identifying the specific problem and potentially to initiate a corrective action.
[0059] Having determined that the total number of errors withm the cluster 12 for the monitored minute exceeds a threshold, the drill-down analysis algorithm 70 may then expand the dimensional analysis by looking at the table 220, which indicates that the bulk of the detected errors occurred with respect to a URL transaction type. A compaπson may again be performed with respect to the reference OLAP data structure to determine that the number of errors pertaining to URL transactions falls outside of an acceptable range. The drill-down analysis algorithm 70 now continues the analysis to determine more specifically where the problem lies. A drill-down into the URL row of the summary table 220 reveals the summary table 222, which indicates that by far the majoπty of the errors pertaining to the URL transaction have aπsen with respect to machines in pool 1. Again, the drill-down analysis algorithm 70 will utilize the reference OLAP data structure to identify the errors pertaining to the URL transactions within pool 1 as falling outside an acceptable range, and then drill-down on the row for pool 1 within the table 222, to reveal the summary tables 224 and 226. The summary table 226, when analyzed by the dπll-down analysis algoπthm 70, reveals that the errors are not being generated disproportionately by any of the URL transactions being serviced by the machines in pool 1. However, the summary table 224 reveals that the machine "Marcus" in pool 1 is experiencing a hugely disproportionate number of errors for URL transactions. Accordingly, the dπll-down analysis algorithm 70, on an analysis of the table 224, may generate an alert to a human administrator, or to an automatic maintenance program. For example, the automatic maintenance program may, responsive to the alert, shut down the errant machine "Marcus", or configure the clusters 12 so that URL transactions are diverted away from the machine "Marcus" (e.g., by appropriate configuration of a load balancer 26). Further, the drill-down analysis algorithm 70 may perform further analysis with respect to the machine "Marcus", to find an even more specific description of the problem. For example, a drill-down into the machine "Marcus" could be performed and an expansion on the status code dimension variable performed to reveal further details. For example, various status codes may provide further information regarding the nature of errors encountered. The drill-down analysis algorithm 70 may then provide a count of the number of status codes of each type received (e.g., 3500 status codes 391 received, 200 status codes 415 received, etc.).
[0060] Figure 11 illustrates a drill-down analysis, (for example performed by the drill-down analysis algorithm 70 or a human operator) in which the observed errors pertaining to URL transactions are not caused by the machine "Marcus", but instead by a specific URL transaction (i.e., URL 2). Specifically, the summary table 224 reveals that the errors are uniformly distributed across all machines in the pool 1 , but that the observed problem is entirely specific to URL 1. From the URL 2 row in the table 226, a further drill-down may be performed and an expansion by status code may be performed to determine if the errors are due to one specific error, associated with a specific status code.
[0061] Figure 12 illustrates a drill-down analysis, responsive to an observation that the number of URL transactions exceeds a threshold, in which a URL error storm is not specific to any URL transaction type, and is distributed across two machines "Attila" and "Lenin". In this case, a specific build "E293" is identified as causing the URL storm.
[0062] As noted above, the drill-down analyses illustrated in Figures 10-12 may be performed by a human operator, or may be automated and performed by the drill-down analysis algorithm 70. In the case where the analysis is performed by a human operator, a graphical user interface may present the various summary tables to the human operator, with each of the rows of the tables being selectable (e.g., being a URL) to be expandable to generate a more focused summary table. To this end, a human operator, by selecting rows within tables, may navigate a dimensional hierarchy 210 such as that shown in Figure 9, to identify the source of an observed problem. In the case where the analysis is performed in an automated fashion by the drill-down analysis algorithm 70, the algorithm 70 may similarly navigate through a dimensional hierarchy 210 and perform various dimensional analyses with a view to pinpointing a source and/or cause of an observed problem or issue. For example, considering the drill-down analysis reflected in Figure 11, the algorithm 70 may drill-down to the summary table 224, observe that the errors are somewhat uniformly distributed across all machines within a particular pool, and based on this observation, determine that a further dimensional analysis (e.g., with respect to specific transaction names) is required. The summary node generation algorithm 68 may then generate the further summary table 226 on which a comparison operation, with respect to the reference OLAP data structure, is be performed.
[0063] Expanding upon the alert generation operation performed at block 176 in Figure 6, the automatic problem detection application 66 operates to determine the root cause of an observed problem, and then proceeds to report the problem. Further, the automatic problem detection application 66 may, in one embodiment, determine the cause of a particular problem. For example, the application 66 may make an assessment as to whether the problem is being caused by a hardware failure, or a software bug. If the problem is identified as a hardware problem, the application 66 may furthermore identify the hardware problem as pertaining to RAM, a hard disk, a network interface, etc. This information may be determined based on the status codes pertaining to errors observed by the drill-down analysis algorithm 70, and included in a report (or alert) that is generated. The reports or alerts generated at block 176 may furthermore be sent to an event correlator (not shown), which operates to correlate events with events that may have been observed by other monitoring systems, the event correlator then providing output to a human operator.
[0064] An alert that is presented to a human operator may also identify sources for the error that have been ruled out. For example, an alert may be presented as follows:
"Problem with machine "Marcus" in pool 1: Exceeded the acceptable range of URL errors. The problem is not present in other machines in pool 1. The problem is not a database problem". [0065] The alert text may also be hypertext-linked, so that text within the alert is user selectable to provide specific information. For example, the text "Exceeded the acceptable range of URL errors" may be hypertext-linked to generate a summary table that provides a count of the number of URL errors observed on the machine "Marcus". Similarly, the text "not present in other machines in pool 1" may be hypertext-linked to present the table 224, illustrated in Figure 10, to a human operator. Further, the text "not a database problem" may be hypertext-linked to present the table 226 to a human operator.
[0066] As noted above, the dimensional hierarchy 210 shown in Figure 9 illustrates merely one manner in which a drill-down analysis may be performed. It will be appreciated that other dimensional hierarchies may be generated to support an alternative drill-down analysis. [0067] Expanding on the generation of the reference OLAP data structure, described above with reference to block 178 of Figure 6, the reference OLAP data structure may be derived from a sample of many older OLAP data structures that provide an historic perspective on a "normal" state for the cluster 12. The reference OLAP data structure enables a determination to be made whether a specific analysis variable is within a "healthy" range, for a specific selection of dimension variable. In addition to a simple "yes/no" answer, the reference OLAP data structure also enables an assessment of whether a specific analysis variable is too high or too low. [0068] In one exemplary embodiment, the reference OLAP data structure may be generated to provide context to a given time, day or date. A different reference OLAP data structure may be generated for each of the 160 hours of a week, for example. In another embodiment, the reference OLAP data structure may be continually updated so that it is always appropriate for a particular time, day or date. Specifically, the reference OLAP data structure that is utilized for the comparison operation performed at block 172 of the method 152 shown in Figure 6 should be representative of a "healthy" state for a monitored system, at a particular time, day and/or date. Considering the exemplary embodiment in which a unique reference OLAP data structure is generated for each of the 160 hours of a week. A 1 -minute reference OLAP data structure for up to one hour in the past (for a particular day) may be representative but an OLAP data structure two hours in the past may not be representative. Further, a 1 -minute reference OLAP data structure for a current hour one or two weeks in the past may be representative, but an OLAP data structure for a current hour one or two days in the past may not be representative. [0069] In one embodiment of the present invention, a new reference OLAP data structure (e.g., a range cube) is created every minute. The reference OLAP data structure may be created by drawing on a prior 60 minutes of activity (e.g., providing a potential sample of 60 OLAP data structures). Further, OLAP data structures for one week in the past, and allowing for plus or minus one hour, increases the potential sample to 121 further OLAP data structures. Going back two or more weeks in the past increases the sample by a further 121 OLAP data structures per week. In one embodiment, one month's worth of reference OLAP data structures may be retained, thus providing more than 858 representative OLAP data structures from which may be sampled.
[0070] Having identified a set of potential sample OLAP data structures, data structures that correspond to past system problems are discarded (e.g., only representative "healthy" OLAP data structures are used). To this end, the automatic problem detection application 66 may flag unified OLAP data structures as either being "healthy" or "unhealthy", depending on whether a problem was detected within the relevant predetermined time interval (e.g., 1 minute). In one embodiment, the final flagging of a unified OLAP data structure as "healthy" or "unhealthy" may be subject to human confirmation. For example, the automatic problem detection application 66 may register a problem within a specific minute, but upon further human investigation the problem is determined in fact to represent a false positive. In this case, a human operator may flag the relevant unified OLAP data structure as being "healthy", not withstanding that a problem was reported by the automatic problem detection application 66. [0071] In yet a further embodiment, an assumption may be made that a reference OLAP data structure for one minute only exhibits minor differences from a reference OLAP data structure for the prior minute. This assumption may be factored into the determination of the health of a reference OLAP data structure for a particular minute, utilized to dampen the effects of any abnormal activities present in the other sample data, and also to account for changes with respect to the system over the sample period. For example, where a sample set extends one month into the past, system changes may have occurred that influence what may be regarded as a "healthy" state for a system. A significant number of machines may have been added to a particular machine pool within the one month period, which may substantially influence the reliability and value of samples prior to this system modification. Accordingly, the reference OLAP data structure from the preceding minute may be weighted in the calculation of the reference OLAP data structure so as to allow the current state of a system to more strongly influence what is considered to be a "healthy" state.
[0072] The influence of time, date and/or day may be particularly significant where the system being monitored is a website. Specifically, activity on a particular website may display significant variations, based on time, day and/or date. For example, where the website supports a commerce system, there may be specific times of the day in which transaction activity displays significant increases, and also specific days on which transaction volume is significantly higher than on other days. Further, transaction activity may increase as a specific calendar event (e.g., the Christmas holiday season) approaches. By a selection of the sample reference OLAP data structures, from which a current reference OLAP data structure is calculated, for corresponding past times, or time periods, and also by factoring in immediately past reference OLAP data structures, one embodiment of the present invention seeks to provide a current reference OLAP data structure that provides an accurate representation of a "healthy" state for a monitored system, such as the cluster 12 of application servers 14.
[0073] In various embodiments of the present invention, the unified OLAP data structure may also be configured to have different resolutions. For example, the reference OLAP data structure may be provided with an error code level resolution, whereas in another embodiment, a reference OLAP data structure may be provided with a higher resolution (e.g., at a pool level). [0074] Figure 13 shows a diagrammatic representation of machine in the exemplary form of a computer system 300 within which a set of instructions, for causing the machine to perform any one or more of the methodologies discussed herein, may be executed. In alternative embodiments, the machine operates as a standalone device or may be connected (e.g., networked) to other machines. In a networked deployment, the machine may operate in the capacity of a server or a client machine in server-client network environment, or as a peer machine in a peer-to-peer (or distributed) network environment. The machine may be a personal computer (PC), a tablet PC, a set-top box (STB), a Personal Digital Assistant (PDA), a cellular telephone, a web appliance, a network router, switch or bridge, or any machine capable of executing a set of instructions (sequential or otherwise) that specify actions to be taken by that machine. Further, while only a single machine is illustrated, the term "machine" shall also be taken to include any collection of machines that individually or jointly execute a set (or multiple sets) of instructions to perform any one or more of the methodologies discussed herein. [0075] The exemplary computer system 300 includes a processor 302 (e.g., a central processing unit (CPU), a graphics processing unit (GPU) or both), a main memory 304 and a static memory 306, which communicate with each other via a bus 308. The computer system 300 may further include a video display unit 310 (e.g., a liquid crystal display (LCD) or a cathode ray tube (CRT)). The computer system 300 also includes an alphanumeric input device 312 (e.g., a keyboard), a user interface (UI) navigation device 314 (e.g., a mouse), a disk drive unit 316, a signal generation device 318 (e.g., a speaker) and a network interface device 320. [0076] The disk drive unit 316 includes a machine-readable medium 322 on which is stored one or more sets of instructions and data structures (e.g., software 324) embodying or utilized by any one or more of the methodologies or functions described herein. The software 324 may also reside, completely or at least partially, within the main memory 304 and/or within the processor 302 during execution thereof by the computer system 300, the main memory 304 and the processor 302 also constituting machine-readable media.
[0077] The software 324 may further be transmitted or received over a network 326 via the network interface device 320 utilizing any one of a number of well-known transfer protocols (e.g., HTTP).
[0078] While the machine-readable medium 392 is shown in an exemplary embodiment to be a single medium, the term "machine-readable medium" should be taken to include a single medium or multiple media (e.g., a centralized or distributed database, and/or associated caches and servers) that store the one or more sets of instructions. The term "machine-readable medium" shall also be taken to include any medium that is capable of storing, encoding or carrying a set of instructions for execution by the machine and that cause the machine to perform any one or more of the methodologies of the present invention, or that is capable of storing, encoding or carrying data structures utilized by or associated with such a set of instructions. The term "machine-readable medium" shall accordingly be taken to include, but not be limited to, solid-state memories, optical and magnetic media, and carrier wave signals. [0079] Thus, a method and system to monitor a diverse heterogeneous application environment have been described. Although the present invention has been described with reference to specific exemplary embodiments, it will be evident that various modifications and changes may be made to these embodiments without departing from the broader spirit and scope of the invention. Accordingly, the specification and drawings are to be regarded in an illustrative rather than a restrictive sense.

Claims

CLAIMS What is claimed is:
1. A method to monitor a diverse and heterogeneous application environment, the method including: instrumenting each of a plurality of application servers to log data pertaining to a respective application server; communicating the logged data from each of the plurality of application servers to a central logging system; and aggregating the logged data so as to providing an aggregate view of the logged data across the plurality of application servers,
wherein the logged data is communicated from each of the plurality of application servers to the central logging system utilizing a common syntax so as to facilitate the aggregation of the logged data.
2. The method of claim 1, wherein the instrumenting of each of the plurality of application servers includes configuring respective application servers to monitor a predetermined a set of parameters of an associated application server.
3. The method of claim 2, wherein at least a first application server is configured to monitor a predetermined set of transaction types.
4. The method of claim 2, wherein at least a first application server is configured to contribute to a generation of heartbeat information made available by an associated application server.
5. The method of claim 2, wherein at least a first application server is adapted to retrieve information regarding hardware resources available to the first application server.
6. The method of claim 1, wherein the communicating of the logged data includes publishing the logged data on a publish/subscribe messaging bus.
7. The method of claim 1, including receiving the logged data at a cluster of harvesters, and writing the logged data into a non-volatile storage arrangement utilizing the cluster of harvesters.
8. The method of claim 7, wherein the aggregating of the logged data includes providing static reports to present the aggregate view of the transaction data across the plurality of application servers utilizing the logged data as stored in the non-volatile storage arrangement.
9. The method of claim 1, wherein the aggregating of the logged data includes receiving the logged data at a real-time server, and providing real-time reports to present the aggregate view of the transaction data across the plurality of application servers.
10. The method of claim 1, wherein the logged data is communicated from each of the monitoring clients as a data logging message conforming to the common syntax, the common syntax defining a predetermined set of message classes, and each data logging message identifying a message class from the predetermined set to which the message belongs.
11. The method of claim 10, wherein the predetermined set of message classes includes a transaction start message class of messages that identify a start of a transaction at a first application server.
12. The method of claim 10, wherein the predetermined set of message classes includes a transaction end message class of messages that identify an end of a transaction at a first application server instrumented by a first monitoring client.
13. The method of claim 10, wherein the predetermined set of message classes includes a transaction atomic message class of messages that identify a transaction, at a first application server, as being an atomic transaction.
14. The method of claim 10, wherein the predetermined set of message classes include a transaction heartbeat message class of messages that include heartbeat information generated by a first application server.
15. The method of claim 1, wherein the logged data is communicated as a data logging message conforming to the common syntax, the common syntax defining a predetermined set of transaction types.
16. The method of claim 1, wherein the logged data is communicated as a data logging message conforming to the common syntax, the common syntax defining a predetermined set of status codes indicating whether an associated transaction performed at a first application server was unsuccessful.
17. The method of claim 16, wherein at least one status code of the predetermined set of status codes identifies an error that caused the associated transaction performed at the first application server to be unsuccessful.
18. The method of claim 1, wherein the logged data is communicated as a data logging message conforming to the common syntax, the common syntax defining at least one dimension variable and at least one analysis variable.
19. The method of claim 1, wherein each of the plurality of application servers is instrumented with a monitoring client, and the common syntax is supported by an Application Program Interface (API) utilizing which at least one of the monitoring clients communicates the logged data.
20. The method of claim 1, wherein the aggregation of the logged data includes generating a multidimensional OLAP data structure utilizing the logged data.
21. The method of claim 20, wherein the multidimensional OLAP data structure is generated by aggregating the logged data pertaining to a predetermined time interval.
22. The method of claim 20, wherein the multidimensional OLAP data structure is generated and stored within volatile memory of a server.
23. The method of claim 20, including detecting a problem within the application environment by comparing the multidimensional OLAP data structure to an historic multidimensional OLAP data structure, and determining whether analysis variables of the multidimensional OLAP data structure transgress predetermined thresholds based on the historic multidimensional OLAP data structure.
24. The method of claim 1, wherein the logged data includes at least one of transaction, event and heartbeat data.
25. A system to monitor a diverse and heterogeneous application environment, the system including: a plurality of application servers; a central logging system; and a plurality of monitoring clients, each of the plurality of application servers being instrumented with a respective monitoring client, of the plurality of monitoring clients, to facilitate logging of data pertaining to the respective application server, wherein each of the monitoring clients is to communicate the logged data to the central logging system, and the cenfral logging system is to aggregate the logged data so as to provide an aggregate view of the logged data across the plurality of application servers, and wherein the each of the monitoring clients is to communicate the logged data to the central logging system utilizing a common syntax so as to facilitate the aggregation of the logged data.
26. The system of claim 25, wherein each of the monitoring clients facilitates monitoring of a predetermined set of parameters of an associated application server.
27. The system of claim 26, wherein at least a first monitoring client facilitates monitoring of a predetermined set of transaction types.
28. The system of claim 26, wherein at least a first monitoring client facilitates a generation of heartbeat information pertaining to an associated application server.
29. The system of claim 26, wherein at least a first monitoring client facilitates a collection of information regarding hardware resources available to an associated application server.
30. The system of claim 25, wherein the system includes a publish/subscribe messaging bus, and each of the monitoring clients is configured to publish the logged data on the publish/subscribe messaging bus.
31. The system of claim 25, wherein the system includes a cluster of harvesters configured to receive the logged data and to write the logged data into a non-volatile storage arrangement.
32. The system of claim 31 , wherein the central logging system is to provide static reports to present the aggregate view of the transaction data across the plurality of application servers utilizing the logged data as stored in the non-volatile storage arrangement.
33. The system of claim 25, wherein the central logging system includes a real-time server, and the aggregating of the logged data includes receiving the logged data at the real-time server, and providing real-time reports to present the aggregate view of the logged data across the plurality of application servers.
34. The system of claim 25, wherein each of the monitoring clients is configured to communicate the logged data as a data logging message conforming to the common syntax, the common syntax defining a predetermined set of message classes, and each data logging message identifying a message class from the predetermined set to which the message belongs.
35. The system of claim 34, wherein the predetermined set of message classes includes a transaction start message class of messages that identify a start of a transaction at a first application server instrumented by a first monitoring client.
36. The system of claim 34, wherein the predetermined set of message classes includes a transaction end message class of messages that identify an end of a transaction at a first application server instrumented by a first monitoring client.
37. The system of claim 34, wherein the predetermined set of message classes includes a transaction atomic message class of messages that identify a fransaction at a first application server, instrumented by a first monitoring client, as being an atomic transaction.
38. The system of claim 34, wherein the predetermined set of message classes include a transaction heartbeat message class of messages that include heartbeat information generated by a first application server, instrumented by a first monitoring client.
39. The system of claim 25, wherein each of the monitoring clients is to communicate the logged data as a data logging message conforming to the common syntax, the common syntax defining a predetermined set of transaction types.
40. The system of claim 25, wherein each of the monitoring clients is to communicate the logged data as a data logging message conforming to the common syntax, the common syntax defining a predetermined set of status codes indicating whether an associated fransaction performed at a first application server was unsuccessful.
41. The system of claim 40, wherein at least one status code of the predetermined set of status codes identifies an error that caused the associated transaction performed at the first application server to be unsuccessful.
42. The system of claim 25, wherein each of the monitoring clients is to communicate the logged data as a data logging message conforming to the common syntax, the common syntax defining at least one to dimension variable and at least one analysis variable.
43. The system of claim 25, wherein the common syntax is supported by an Application Program Interface (API) utilizing which at least one of the monitoring clients communicates the logged data.
44. The system of claim 25, wherein the central logging system is to aggregate the logged data by generating a multidimensional OLAP data structure utilizing the logged data.
45. The system of claim 44, wherein the multidimensional OLAP data structure is generated by aggregating the logged data pertaining to a predetermined time interval.
46. The system of claim 44, wherein the multidimensional OLAP data structure is generated and stored within volatile memory of a server.
47. The system of claim 44, wherein the central logging system is configured to detect a problem within the application environment by comparing the multidimensional OLAP data structure to an historic multidimensional OLAP data structure, and determining whether analysis variables of the multidimensional OLAP data structure transgress predetermined thresholds based on the historic multidimensional OLAP data structure.
48. The system of claim 25, wherein the logged data includes at least one of transaction, event and heartbeat data.
49 . A method to detect potential problems within a heterogeneous and diverse application environment, the method including: receiving operations data from a plurality of application servers within the application environment, the operations data pertaining to operations performed at the plurality of application servers; aggregating the operations data pertaining to the operations performed at the plurality of application servers over a predetermined time interval; comparing the aggregated operations data to reference operations data ; and detecting a potential problem within the application environment if the aggregated operations data deviates from the reference operations data in a predetermined manner.
50. The method of claim 49,wherein the received operations data conforms to a common syntax.
51. The method of claim 50, wherein the common syntax defines at least one dimension variable and one analysis variable.
52. The method of claim 51, wherein the at least one dimension variable is a transaction type variable identifying an associated transaction as being one of a predetermined set of transaction types.
53. The method of claim 51, wherein the at least one dimension variable is a message class variable identifying a message class, of a predetermined set of a message classes, to which a message embodying at least a portion of operations data of a message belongs.
54. The method of claim 49, wherein the aggregation of the operations data includes generating a multidimensional data structure into which the operations data, pertaining to the transactions performed at the plurality of application servers over the predetermined time interval, is aggregated.
55. The method of claim 54, wherein the multidimensional data structure is a multidimensional OLAP data structure.
56. The method of claim 49, including generating the reference operations data based on historical operations data pertaining to the application environment.
57. The method of claim 56, wherein the generating of the reference operations data includes selecting the historical operations data based on the predetermined time interval.
58. The method of claim 57, wherein the historical operations data is selected as pertaining to a past time interval corresponding to the predetermined time interval.
59. The method of claim 58, wherein the past time interval corresponds to the predetermined time interval on at least one of a previous day, week and month.
60. The method of claim 58, wherein the past time interval corresponds to the predetermined time interval according to the time of day.
61. The method of claim 49, wherein the comparing of the aggregated operations data to the reference operations data includes performing comparisons on multiple dimensions common to the aggregated operations data and the reference operations data.
62. The method of claim 61, wherein the performance of the comparisons on the multiple dimensions includes generating a dimensional hierarchy common to the aggregated fransactional data and the reference operations data, and performing comparisons at a plurality of levels of the dimensional hierarchy.
63. The method of claim 49, wherein the detecting of the potential problem includes generating at least one threshold based on the reference operations data, and determining whether the aggregated operations data transgresses the at least one threshold.
64. The method of claim 40, wherein the detecting of the potential problem includes generating a range, based on the reference operations data, for at least one analysis variable of the aggregate operations data , and determining whether the at least one variable of the aggregate operations data falls outside of the range.
65. The method of claim 49, including generating an alert including information pertaining to the potential problem if the potential problem is detected.
66. The method of claim 49, including automatically initiating an action to correct the potential problem, responsive to the detection thereof.
67. The method of claim 49, wherein the operations data is at least one of transaction, event and heartbeat data.
68. A system to detect potential problems within a heterogeneous and diverse application environment, the system including: a summary module configured to receive operations data from a plurality of application servers within the application environment, the operations data pertaining to operations performed at the plurality of application servers, and to aggregate the operations data pertaining to the operations performed at the plurality of application servers over a predetermined time interval; and a comparison module configured to compare the aggregated operations data to reference operations data, and to detect a potential problem within the application environment if the aggregated operations data deviates from the reference operations data in a predetermined manner.
69. The system of claim 68,wherein the received operations data conforms to a common syntax.
70. The system of claim 69, wherein the common syntax defines at least one dimension variable and one analysis variable.
71. The system of claim 70, wherein the at least one dimension variable is a transaction type variable identifying an associated fransaction as being one of a predetermined set of fransaction types.
72. The system of claim 70, wherein the at least one dimension variable is a message class variable identifying a message class, of a predetermined set of a message classes, to which a message embodying at least a portion of operations data of a message belongs.
73. The system of claim 68, wherein the summary module is configured to generate a multidimensional data structure into which the operations data, pertaining to the transactions performed at the plurality of application servers over the predetermined time interval, is aggregated.
74. The system of claim 73, wherein the multidimensional data structure is a multidimensional OLAP data structure.
75. The system of claim 68, wherein the comparison module is configured to generate the reference operations data based on historical operations data pertaining to the application environment.
76. The system of claim 75, wherein the comparison module is configured to generate the reference operations data by selecting the historical operations data based on the predetermined time interval.
77. The system of claim 76, wherein the historical operations data is selected as pertaining to a past time interval corresponding to the predetermined time interval.
78. The system of claim 77, wherein the past time interval corresponds to the predetermined time interval on at least one of a previous day, week and month.
79. The system of claim 77, wherein the past time interval corresponds to the predetermined time interval according to the time of day.
80. The system of claim 68, wherein the comparison module is configured to compare the aggregated operations data to the reference operations data by performing comparisons on multiple dimensions common to the aggregated operations data and the reference operations data.
81. The system of claim 80, wherein the comparison module is configured to generate a dimensional hierarchy common to the aggregated operational data and the reference operations data, and to perform comparisons at a plurality of levels of the dimensional hierarchy.
82. The system of claim 68, wherein the comparison module is configured to generate at least one threshold based on the reference operations data, and to determine whether the aggregated operations data transgresses the at least one threshold.
83. The system of claim 68, wherein the comparison module is configured to generate a range, based on the reference operations data, for at least one analysis variable of the aggregate operations data, and to determine whether the at least one variable of the aggregate operations data falls outside of the range.
84. The system of claim 68, wherein the comparison module is configured to generate an alert including information pertaining to the potential problem if the potential problem is detected.
85. The system of claim 68, wherein the comparison module is configured automatically to initiate an action to correct the potential problem, responsive to the detection thereof.
86. A machine-readable medium storing a sequence of instructions that, when executed by a machine, cause the machine to perform a method to monitor a diverse and heterogeneous application environment, the method including: communicating logged data from each of a plurality of monitoring clients to a central logging system, each of a plurality of application servers having been instrumented with a respective monitoring client to log data pertaining to a respective application server; and aggregating the logged data so as to providing an aggregate view of the logged data across the plurality of application servers,
wherein the logged data is communicated from each of the monitoring clients to the central logging systems utilizing a common syntax so as to facilitate the aggregation of the logged data.
87. A system to monitor a diverse and heterogeneous application environment, the system including: a plurality of application servers; central logging means; and monitoring means, each of the plurality of application servers being instrumented utilizing the monitoring means to log data pertaining to a respective application server, wherein the monitoring means is for communicating the logged data to the central logging means, and the central logging means is for aggregating the logged data so as to providing an aggregate view of the logged data across the plurality of application servers, and wherein the monitoring means is for communicating the logged data to the central logging means utilizing a common syntax so as to facilitate the aggregation of the logged data.
88. A machine-readable medium stoπng a sequence of instructions that, when executed by a machine, cause the machine to perform a method to detect potential problems withm a heterogeneous and diverse application environment, the method including: receiving operations data from a plurality of application servers with the application environment, the operations data pertaining to operations performed at the plurality of application servers; aggregating the operations data pertaining to the operations performed at the plurality of application servers over a predetermined time interval; compaπng the aggregated operations data to reference operations data; and detecting a potential problem withm the application environment if the aggregated operations data deviates from the reference operations data in a predetermined manner.
89 A system to detect potential problems withm a heterogeneous and diverse application environment, the system including. summary means for receiving operations data from a plurality of application servers withm the application environment, the operations data pertaining to operations performed at the plurality of application servers, and for aggregating the operations data pertaining to the operations performed at the plurality of application servers over a predetermined time interval; and
comparison means for comparing the aggregated operations data to reference operations data, and to detect a potential problem withm the application environment if the aggregated operations data deviates from the reference operations data m a predetermined manner.
PCT/US2004/014780 2004-02-27 2004-05-10 Method and system to monitor a diverse heterogeneous application environment WO2005093607A1 (en)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US54835704P 2004-02-27 2004-02-27
US60/548,357 2004-02-27

Publications (1)

Publication Number Publication Date
WO2005093607A1 true WO2005093607A1 (en) 2005-10-06

Family

ID=35056382

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2004/014780 WO2005093607A1 (en) 2004-02-27 2004-05-10 Method and system to monitor a diverse heterogeneous application environment

Country Status (2)

Country Link
US (3) US7526670B2 (en)
WO (1) WO2005093607A1 (en)

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP1892624A1 (en) * 2006-08-24 2008-02-27 Research In Motion Limited System and method for processing operational data associated with a transmission in a data communication system
US7788330B2 (en) 2006-08-24 2010-08-31 Research In Motion Limited System and method for processing data associated with a transmission in a data communication system
WO2013121394A1 (en) * 2012-02-15 2013-08-22 Universidade Do Porto Remote debugging service
EP2927819A1 (en) * 2014-04-04 2015-10-07 Siemens Aktiengesellschaft Method for automatically processing a number of protocol files of an automation system
US11249815B2 (en) * 2013-10-22 2022-02-15 International Business Machines Corporation Maintaining two-site configuration for workload availability between sites at unlimited distances for products and services

Families Citing this family (36)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8983966B2 (en) 2004-02-27 2015-03-17 Ebay Inc. Method and system to monitor a diverse heterogeneous application environment
WO2005093607A1 (en) * 2004-02-27 2005-10-06 Ebay Inc. Method and system to monitor a diverse heterogeneous application environment
GB0606226D0 (en) * 2006-03-29 2006-05-10 Ibm A method for resolving a unit of work
US20070294596A1 (en) * 2006-05-22 2007-12-20 Gissel Thomas R Inter-tier failure detection using central aggregation point
US8204914B2 (en) * 2006-12-05 2012-06-19 Sap Ag Method and system to process multi-dimensional data
US7685475B2 (en) * 2007-01-09 2010-03-23 Morgan Stanley Smith Barney Holdings Llc System and method for providing performance statistics for application components
US8224845B2 (en) * 2008-01-21 2012-07-17 International Business Machines Corporation Transaction prediction modeling method
US8230269B2 (en) * 2008-06-17 2012-07-24 Microsoft Corporation Monitoring data categorization and module-based health correlations
US8180824B2 (en) 2009-02-23 2012-05-15 Trane International, Inc. Log collection data harvester for use in a building automation system
US8291268B2 (en) * 2009-04-02 2012-10-16 International Business Machines Corporation Apparatus, system, and method to provide alert notification with reconcile actions
CN102143008A (en) * 2010-01-29 2011-08-03 国际商业机器公司 Method and device for diagnosing fault event in data center
US8667138B2 (en) 2010-10-29 2014-03-04 Cisco Technology, Inc. Distributed hierarchical rendering and provisioning of cloud services
US8639793B2 (en) 2010-10-29 2014-01-28 Cisco Technology, Inc. Disaster recovery and automatic relocation of cloud services
US9235447B2 (en) 2011-03-03 2016-01-12 Cisco Technology, Inc. Extensible attribute summarization
US8924392B2 (en) 2011-05-23 2014-12-30 Cisco Technology, Inc. Clustering-based resource aggregation within a data center
US9171020B2 (en) 2012-04-30 2015-10-27 Sap Se Deleting records in a multi-level storage architecture
US9165010B2 (en) 2012-04-30 2015-10-20 Sap Se Logless atomic data movement
US9465844B2 (en) 2012-04-30 2016-10-11 Sap Se Unified table query processing
US9465829B2 (en) 2012-04-30 2016-10-11 Sap Se Partial merge
US10162766B2 (en) * 2012-04-30 2018-12-25 Sap Se Deleting records in a multi-level storage architecture without record locks
US10114148B2 (en) * 2013-10-02 2018-10-30 Nec Corporation Heterogeneous log analysis
US9742624B2 (en) * 2014-01-21 2017-08-22 Oracle International Corporation Logging incident manager
US9444735B2 (en) 2014-02-27 2016-09-13 Cisco Technology, Inc. Contextual summarization tag and type match using network subnetting
US10073679B2 (en) * 2014-09-26 2018-09-11 Oracle International Corporation Efficient and intuitive databinding for mobile applications
US9826045B2 (en) 2014-09-26 2017-11-21 Oracle International Corporation Efficient means to test server generated applications on mobile device
US10290133B2 (en) 2014-09-26 2019-05-14 Oracle International Corporation High fidelity interactive screenshots for mobile applications
GB201504612D0 (en) 2015-03-18 2015-05-06 Inquisitive Systems Ltd Forensic analysis
US9959195B2 (en) * 2015-04-29 2018-05-01 Cisco Technology, Inc. Dynamic instrumentation of WSGI applications
US10169719B2 (en) * 2015-10-20 2019-01-01 International Business Machines Corporation User configurable message anomaly scoring to identify unusual activity in information technology systems
US9772895B2 (en) * 2015-10-20 2017-09-26 International Business Machines Corporation Identifying intervals of unusual activity in information technology systems
US10042693B2 (en) * 2016-07-12 2018-08-07 Infineon Technologies Ag Diverse integrated processing using processors and diverse firmware
US11416064B2 (en) * 2017-05-17 2022-08-16 Siemens Healthcare Diagnostics Inc. Alerts with augmented reality
GB201708671D0 (en) 2017-05-31 2017-07-12 Inquisitive Systems Ltd Forensic analysis
US10776196B2 (en) * 2018-08-29 2020-09-15 International Business Machines Corporation Systems and methods for anomaly detection in a distributed computing system
US11093310B2 (en) * 2018-12-31 2021-08-17 Paypal, Inc. Flow based pattern intelligent monitoring system
US20230222169A1 (en) * 2022-01-12 2023-07-13 Dell Products L.P. Automated shifting of web pages between different user devices

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20030120593A1 (en) * 2001-08-15 2003-06-26 Visa U.S.A. Method and system for delivering multiple services electronically to customers via a centralized portal architecture
US20030225604A1 (en) * 2002-06-04 2003-12-04 Fabio Casati System and method for analyzing data and making predictions

Family Cites Families (37)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP3734051B2 (en) * 1995-09-28 2006-01-11 日立ソフトウエアエンジニアリング株式会社 Network management system
WO1998000784A1 (en) * 1996-06-28 1998-01-08 Mci Communications Corporation System and method for reporting telecommunication service conditions
US5872912A (en) * 1996-06-28 1999-02-16 Mciworldcom, Inc. Enhanced problem alert signals
US5913036A (en) * 1996-06-28 1999-06-15 Mci Communications Corporation Raw performance monitoring correlated problem alert signals
US6258939B1 (en) 1997-03-10 2001-07-10 The Regents Of The University Of California PSCA antibodies and hybridomas producing them
US20030082540A1 (en) 1997-09-17 2003-05-01 Genentech, Inc. Secreted and transmembrane polypeptides and nucleic acids encoding the same
JP3488617B2 (en) * 1998-02-10 2004-01-19 シャープ株式会社 Remote fault management system using the Internet
US6148338A (en) 1998-04-03 2000-11-14 Hewlett-Packard Company System for logging and enabling ordered retrieval of management events
US6978297B1 (en) 1998-11-12 2005-12-20 Ricoh, Co., Ltd. System and method of managing queues by maintaining metadata files having attributes corresponding to capture of electronic document and using the metadata files to selectively lock the electronic document
US7356559B1 (en) 1999-07-01 2008-04-08 Affinity Internet, Inc. Integrated platform for developing and maintaining a distributed multiapplication online presence
US6502088B1 (en) 1999-07-08 2002-12-31 International Business Machines Corporation Method and system for improved access to non-relational databases
US6832341B1 (en) * 1999-09-23 2004-12-14 International Business Machines Corporation Fault event management using fault monitoring points
US7020697B1 (en) 1999-10-01 2006-03-28 Accenture Llp Architectures for netcentric computing systems
US6636983B1 (en) * 1999-10-07 2003-10-21 Andrew E. Levi Method and system for uniform resource locator status tracking
US6824780B1 (en) 1999-10-29 2004-11-30 Genentech, Inc. Anti-tumor antibody compositions and methods of use
US6625595B1 (en) 2000-07-05 2003-09-23 Bellsouth Intellectual Property Corporation Method and system for selectively presenting database results in an information retrieval system
US7464164B2 (en) * 2000-08-01 2008-12-09 Qwest Communications International, Inc. Linking order entry process to realtime network inventories and capacities
US7065566B2 (en) * 2001-03-30 2006-06-20 Tonic Software, Inc. System and method for business systems transactions and infrastructure management
JP3876692B2 (en) * 2001-11-13 2007-02-07 株式会社日立製作所 Network system failure analysis support method and method
US20070218434A1 (en) 2002-03-29 2007-09-20 Juergen Habichler Using skill level history information
US20070203711A1 (en) 2002-03-29 2007-08-30 Nation Mark S Personalized learning recommendations
US20070208572A1 (en) 2002-03-29 2007-09-06 Juergen Habichler Managing competencies of groups
US7805381B2 (en) 2002-03-29 2010-09-28 Siebel Systems, Inc. Competency self-assessment approval
US6918067B2 (en) * 2002-04-30 2005-07-12 International Business Machines Corporation Detecting network instability
US7318076B2 (en) 2003-01-22 2008-01-08 Intelitrac, Inc. Memory-resident database management system and implementation thereof
US7043505B1 (en) * 2003-01-28 2006-05-09 Unisys Corporation Method variation for collecting stability data from proprietary systems
US7181653B2 (en) * 2003-12-11 2007-02-20 Lenovo Singapore Pte, Ltd Method for establishing network connections
WO2005093607A1 (en) 2004-02-27 2005-10-06 Ebay Inc. Method and system to monitor a diverse heterogeneous application environment
US8983966B2 (en) 2004-02-27 2015-03-17 Ebay Inc. Method and system to monitor a diverse heterogeneous application environment
US20060200490A1 (en) 2005-03-03 2006-09-07 Abbiss Roger O Geographical indexing system and method
EP1880307A4 (en) 2005-05-10 2009-01-21 Brent J Angeline Internet operating system
US20060282333A1 (en) 2005-06-09 2006-12-14 Wang Yongnian Electronic search method for telecommunication network
US9501453B2 (en) 2007-12-23 2016-11-22 Salesforce.Com Inc. Method and system for a flexible-data column user interface
US20090204672A1 (en) 2008-02-12 2009-08-13 Idelix Software Inc. Client-server system for permissions-based locating services and location-based advertising
US8423536B2 (en) 2008-08-05 2013-04-16 Yellowpages.Com Llc Systems and methods to sort information related to entities having different locations
US9177068B2 (en) 2008-08-05 2015-11-03 Yellowpages.Com Llc Systems and methods to facilitate search of business entities
US8768980B2 (en) 2009-11-02 2014-07-01 Stg Interactive S.A. Process for optimizing file storage systems

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20030120593A1 (en) * 2001-08-15 2003-06-26 Visa U.S.A. Method and system for delivering multiple services electronically to customers via a centralized portal architecture
US20030225604A1 (en) * 2002-06-04 2003-12-04 Fabio Casati System and method for analyzing data and making predictions

Non-Patent Citations (3)

* Cited by examiner, † Cited by third party
Title
CHEN M. ET AL: "Pinpoint: Problem Determination in Large, Dynamic Internet Services.", INTERNATIONAL CONFERENCE ON DEPENDABLE SYSTEM AND NETWORKS., 23 June 2002 (2002-06-23) - 26 June 2002 (2002-06-26), pages 595 - 604, XP010600350 *
CHEN M.ET AL: "PAth-Based Failure and Evolution Management.", FIRST SYMPOSIUM OF NETWORK SYSTEMS DESIGN AND IMPLEMENTATION., 29 March 2004 (2004-03-29), pages 1 - 14, XP002994765 *
VINOSKI S. ET AL: "COBRA: Integrating Diverse Applications Within Distributed Heterogeneous Environments.", IEEE COMMUNICATION MAGAZINE, vol. 35, no. 2, February 1997 (1997-02-01), pages 46 - 55, XP000683401 *

Cited By (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP1892624A1 (en) * 2006-08-24 2008-02-27 Research In Motion Limited System and method for processing operational data associated with a transmission in a data communication system
US7788330B2 (en) 2006-08-24 2010-08-31 Research In Motion Limited System and method for processing data associated with a transmission in a data communication system
WO2013121394A1 (en) * 2012-02-15 2013-08-22 Universidade Do Porto Remote debugging service
US11249815B2 (en) * 2013-10-22 2022-02-15 International Business Machines Corporation Maintaining two-site configuration for workload availability between sites at unlimited distances for products and services
EP2927819A1 (en) * 2014-04-04 2015-10-07 Siemens Aktiengesellschaft Method for automatically processing a number of protocol files of an automation system
WO2015150164A1 (en) * 2014-04-04 2015-10-08 Siemens Aktiengesellschaft Method for automatic processing of a number of protocol files of an automation system
US11113236B2 (en) 2014-04-04 2021-09-07 Siemens Aktiengesellschaft Method for automatic processing of a number of protocol files of an automation system

Also Published As

Publication number Publication date
US20090228741A1 (en) 2009-09-10
US7526670B2 (en) 2009-04-28
US20110099430A1 (en) 2011-04-28
US20050262136A1 (en) 2005-11-24
US7870420B2 (en) 2011-01-11
US8621259B2 (en) 2013-12-31

Similar Documents

Publication Publication Date Title
US8621259B2 (en) Method and system to monitor a diverse heterogeneous application environment
US9576010B2 (en) Monitoring an application environment
US10353808B2 (en) Flow tracing of software calls
US7379999B1 (en) On-line service/application monitoring and reporting system
US8892719B2 (en) Method and apparatus for monitoring network servers
US7457872B2 (en) On-line service/application monitoring and reporting system
Wada et al. Data Consistency Properties and the Trade-offs in Commercial Cloud Storage: the Consumers' Perspective.
US10303533B1 (en) Real-time log analysis service for integrating external event data with log data for use in root cause analysis
US20200042428A1 (en) User interface for specifying data stream processing language programs for analyzing instrumented software
US11086755B2 (en) System and method for implementing an application monitoring tool
US20190163546A1 (en) Correlating failures with performance in application telemetry data
EP1386240B1 (en) Synthetic transaction monitor
US7076397B2 (en) System and method for statistical performance monitoring
US20150227409A1 (en) Anomaly detection service
US11093349B2 (en) System and method for reactive log spooling
US10452463B2 (en) Predictive analytics on database wait events
US8688729B2 (en) Efficiently collecting transaction-separated metrics in a distributed enviroment
WO2003073203A2 (en) System and method for analyzing input/output activity on local attached storage
US20130047169A1 (en) Efficient Data Structure To Gather And Distribute Transaction Events
US10191800B2 (en) Metric payload ingestion and replay
US8229884B1 (en) Systems and methods for monitoring multiple heterogeneous software applications
Chakraborty et al. Observability
JP7424052B2 (en) Control program, control method and control device
US11797391B2 (en) Current monitoring in hyperscaler environment
Haapaniemi Non-intrusive Monitoring of Microservices via an API Gateway

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A1

Designated state(s): AE AG AL AM AT AU AZ BA BB BG BR BW BY BZ CA CH CN CO CR CU CZ DE DK DM DZ EC EE EG ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MA MD MG MK MN MW MX MZ NA NI NO NZ OM PG PH PL PT RO RU SC SD SE SG SK SL SY TJ TM TN TR TT TZ UA UG US UZ VC VN YU ZA ZM ZW

AL Designated countries for regional patents

Kind code of ref document: A1

Designated state(s): BW GH GM KE LS MW MZ NA SD SL SZ TZ UG ZM ZW AM AZ BY KG KZ MD RU TJ TM AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HU IE IT LU MC NL PL PT RO SE SI SK TR BF BJ CF CG CI CM GA GN GQ GW ML MR NE SN TD TG

121 Ep: the epo has been informed by wipo that ep was designated in this application
122 Ep: pct application non-entry in european phase