1. Field of the Invention
Embodiments of this invention generally relate to system resource monitoring and more particularly, to using a hierarchical monitor tree for monitoring of the resources.
2. Description of Related Art
In many modern computing systems and networks (systems), monitoring of system resources and components of significant importance to ensure not only the reliability and security of information flow, but also to promptly detect system deficiencies so that they are corrected in a timely manner. Typically, conventional client-server monitoring systems or architectures are used to perform monitoring of the resources.
Conventional monitoring systems, however, do not provide real-time, continuous, or adequate monitoring of the resources, as they are limited in performance because of, for example, architectural limitations, inflexibility in levels of monitoring, lack of convenience in viewing the monitoring data, low level programming interface, and having the resources shared by all the software running on the system including virtual machines.
A method, apparatus, and system are provided for monitoring of system resources using a monitor tree. According to one embodiment, a resource may be associated with a monitor managed bean at a node of a monitor tree. Monitoring information regarding the associated resources may be requested from a runtime managed bean, and the monitoring information may be received by the monitor managed bean at the node of the monitor tree.
The appended claims set forth the features of the present invention with particularity. The embodiments of the present invention, together with its advantages, may be best understood from the following detailed description taken in conjunction with the accompanying drawings of which:
A method, apparatus, and system are provided for monitoring of system resources using a monitor tree. Java objects, such as managed beans may be used for monitoring of the resources. The managed beans may include a combination of monitor managed beans (monitor beans) and runtime managed beans (runtime beans or resource beans). According to one embodiment, a monitor tree may be generated using instructions from a file from a central database. The monitor tree may include a number of nodes, each of the nodes having a monitor bean and a resource associated with the monitor bean. The monitor bean may request monitoring information from a runtime bean which may, in real-time, monitor one or more of the resources including the resource associated with the monitor tree. The runtime bean may provide, also in real-time, the monitoring information to the monitor bean at the node of the tree. The monitored resources may include Java resources associated with a Java 2 Platform, Enterprise Edition (J2EE) engine. Throughout this document, the use of the term “managed beans” in any combination may refer to Java Managed Beans (or Java MBeans). It should be noted, however, that the underlying principles of the invention are not limited to any particular application server specification or programming language.
According to one embodiment, runtime beans continuously provide monitoring information to monitor beans. According to another embodiment, the runtime beans provide the monitoring information to the monitor beans in response to a request from the monitor beans. According to yet another embodiment, the runtime beans provide a notification signal (runtime notification) to the monitor beans indicating the availability of the monitoring information. The monitor bean may, in response to the runtime notification, request the monitoring information, which the runtime bean will provide. According to yet another embodiment, a timer may be employed to provide a notification signal (timer notification) to the monitor beans to request the monitoring information from the runtime beans. The timer notification may be based on, for example, predetermined time period or availability of the monitoring information.
According to one embodiment, a monitor service may be employed to connect the monitor tree with a central database and client-level applications. The client-level applications may include, for example, a computing center management system (“CCMS”), a well known management and monitoring architecture designed by SAP AG for use in R/3 systems. Additional and/or alternate destinations may include administrative tools/viewers, standard Web browsers, and third party tools/viewers. As described in detail below, one embodiment of the administration tools includes a monitor viewer for displaying the monitoring information (e.g., based on the structure of the monitoring tree). Client-level applications may also be used to originate and send request to the monitor tree to request monitoring information regarding various monitored resources.
In the following description, numerous specific details such as logic implementations, opcodes, resource partitioning, resource sharing, and resource duplication implementations, types and interrelationships of system components, and logic partitioning/integration choices may be set forth in order to provide a more thorough understanding of various embodiments of the present invention. It will be appreciated, however, to one skilled in the art that the embodiments of the present invention may be practiced without such specific details, based on the disclosure provided. In other instances, control structures, gate level circuits and full software instruction sequences have not been shown in detail in order not to obscure the invention. Those of ordinary skill in the art, with the included descriptions, will be able to implement appropriate functionality without undue experimentation.
Various embodiments of the present invention will be described below. The various embodiments may be performed by hardware components or may be embodied in machine-executable instructions, which may be used to cause a general-purpose or special-purpose processor or a machine or logic circuits programmed with the instructions to perform the various embodiments. Alternatively, the various embodiments may be performed by a combination of hardware and software.
Various embodiments of the present invention may be provided as a computer program product, which may include a machine-readable medium having stored thereon instructions, which may be used to program a computer (or other electronic devices) to perform a process according to various embodiments of the present invention. The machine-readable medium may include, but is not limited to, floppy diskette, optical disk, compact disk-read-only memory (“CD-ROM”), magneto-optical disk, read-only memory (“ROM”) random access memory (“RAM”), erasable programmable read-only memory (“EPROM”), electrically erasable programmable read-only memory (“EEPROM”), magnetic or optical card, flash memory, or another type of media/machine-readable medium suitable for storing electronic instructions. Moreover, various embodiments of the present invention may also be downloaded as a computer program product, wherein the program may be transferred from a remote computer to a requesting computer by way of data signals embodied in a carrier wave or other propagation medium via a communication link (e.g., a modem or network connection).
The processor bus 212, also known as the host bus or the front side bus, may be used to couple the processors 202-206 with the system interface 214. The processor bus 212 may include a control bus 232, an address bus 234, and a data bus 236. The control bus 232, the address bus 234, and the data bus 236 may be multidrop bi-directional buses, e.g., connected to three or more bus agents, as opposed to a point-to-point bus, which may be connected only between two bus agents.
The system interface 214 may be connected to the processor bus 212 to interface other components of the system 200 with the processor bus 212. For example, system interface 214 may includes a memory controller 218 for interfacing a main memory 216 with the processor bus 212. The main memory 216 typically includes one or more memory cards and a control circuit (not shown). System interface 214 may also include an input/output (I/O) interface 220 to interface the I/O bridge 224 with the processor bus 212. The I/O bridge 224 may operate as a bus bridge to interface between the system interface 214 and an I/O bus 226. One or more I/O controllers 228 and I/O devices 230 may be connected with the I/O bus 226, as illustrated. I/O bus 226 may include a peripheral component interconnect (PCI) bus or other type of I/O bus.
The system 200 may include a dynamic storage device, referred to as main memory 216, or a random access memory (RAM) or other devices coupled to the processor bus 212 for storing information and instructions to be executed by the processors 202-206. The main memory 216 also may be used for storing temporary variables or other intermediate information during execution of instructions by the processors 202-206. System 200 may include a read only memory (ROM) and/or other static storage device coupled to the processor bus 212 for storing static information and instructions for the processors 202-206.
The main memory 216 may include a wide variety of memory devices including read-only memory (ROM), erasable programmable read-only memory (EPROM), electrically erasable programmable read-only memory (EEPROM), random access memory (RAM), non-volatile random access memory (NVRAM), cache memory, flash memory, and other memory devices. The main memory 216 may also include one or more hard disks, floppy disks, ZIP disks, compact disks (e.g., CD-ROM), digital versatile/video disks (DVD), magnetic random access memory (MRAM) devices, and other system-readable media that store instructions and/or data. The main memory 216 may store program modules such as routines, programs, objects, images, data structures, program data, and other program modules that perform particular tasks or implement particular abstract data types that facilitate system use.
The I/O device 230 may include a display device (not shown), such as a cathode ray tube (CRT) or liquid crystal display (LCD), for displaying information to an end user. For example, graphical and/or textual indications of installation status, time remaining in the trial period, and other information may be presented to the prospective purchaser on the display device. The I/O device 230 may also include an input device (not shown), such as an alphanumeric input device, including alphanumeric and other keys for communicating information and/or command selections to the processors 202-206. Another type of user input device includes cursor control, such as a mouse, a trackball, or cursor direction keys for communicating direction information and command selections to the processors 202-206 and for controlling cursor movement on the display device.
The system 200 may also include a communication device (not shown), such as a modem, a network interface card, or other well-known interface devices, such as those used for coupling to Ethernet, token ring, or other types of physical attachment for purposes of providing a communication link to support a local or wide area network, for example. Stated differently, the system 200 may be coupled with a number of clients and/or servers via a conventional network infrastructure, such as a company's Intranet and/or the Internet, for example.
It is appreciated that a lesser or more equipped computer system than the example described above may be desirable for certain implementations. Therefore, the configuration of system 200 will vary from implementation to implementation depending upon numerous factors, such as price constraints, performance requirements, technological improvements, and/or other circumstances.
It should be noted that, while the embodiments described herein may be performed under the control of a programmed processor, such as processors 202-206, in alternative embodiments, the embodiments may be fully or partially implemented by any programmable or hardcoded logic, such as field programmable gate arrays (“FPGAs”), TTL logic, or application specific integrated circuits (“ASICs”). Additionally, the embodiments of the present invention may be performed by any combination of programmed general-purpose computer components and/or custom hardware components. Therefore, nothing disclosed herein should be construed as limiting the various embodiments of the present invention to a particular embodiment wherein the recited embodiments may be performed by a specific combination of hardware components.
The distributed services level 310 may serve as an interface between the JMX architecture 300 and one or more users or clients. As illustrated, the distributed services level 310 may include one or more user terminals 312-314. One or more of the user terminals 312-314 to collect and gather user input and send it to the agent level 320 over a network connection. Network connection may be a wired or wireless connection to a Local Area Network (LAN), a Wide Area Network (WAN), a Metropolitan Area Network (MAN), an intranet, and/or the Internet. Distributed services level terminals 312-314 may include personal computers, notebook computers, personal digital assistants, telephones, and the like. According to one embodiment in which network connection may connect to the Internet, one or more of the user terminals 312-314 may include a Web browser (e.g., Internet Explorer or Netscape Navigator) to interface with the Internet.
According to one embodiment, the distributed services level 310 may also include management applications 316, such as a JMX-compliant management application, a JMX manager, and/or a proprietary management application. The management applications 316 may also include one or more graphical management applications, such as a visual administrator, operating to, for example, retrieve and display information received from the agent level 320 and/or the instrumentation level 330.
The visual administrator may include a monitor viewer to display such information. Management applications 316 may also include third party tools including a file system to store the information and may also include a Graphical User Interface (“GUI”)-based monitor viewer to display the information. The distributed services level 310 may also include the CCMS system described above.
The agent level 320 may include one or more application servers 322-326. An application server may refer to a computing device that performs data processing. The agent level 320 may also include a computing device (e.g., a dispatcher) to perform load balancing among application servers 322-326. According to one embodiment in which the agent level 320 exchanges information with the distributed services level 310 via the Internet, one or more of the application servers 322-326 may include a Web application server. According to one embodiment, the application servers 322-326 may be implemented according to the Java 2 Enterprise Edition Specification v1.4, published on Jul. 12, 2002 (“the J2EE Standard”). In one embodiment of the invention, the management techniques described herein are used to manage resources within a “cluster” of server nodes. An exemplary cluster architecture is described below with respect to
The applications servers 322-326 may include one or more dedicated Java Managed Bean (“MBean”) servers having agent services. According to one embodiment, for and at each Java virtual machine (“JVM”) with managed resources, there may be one or more agents operating at the agent level 320. The one or more agents may include the one or more MBean servers, agent services, a set of MBeans, one or more connectors, and/or one or more protocol adaptors. An MBean Server may include a registry for MBeans and act as a single entry point for calling MBeans in a uniform fashion from management applications at other JVMs.
The instrumentation level 330 may provide a data storage medium for the JMX architecture 300. As illustrated, according to one embodiment, the instrumentation level 330 may include one or more database management systems (“DBMS”) 332-334 and data sources 336-338. According to one embodiment, the data sources 336-338 may include databases and/or other systems capable of providing a data store.
Furthermore, according to one embodiment, the instrumentation level 330 may include one or more hosts including one or more resources having MBeans, such as instrumentation MBeans. The instrumentation level 330 may make Java objects available to management applications 316. The Java objects instrumented according to the JMX-standard may include MBeans. According to one embodiment, the resources represented by MBeans may include managed resources 340. The managed resources 340 may include a kernel, a server component, or the like. MBeans may expose a management interface including constructors, attributes, operations, and notifications.
According to one embodiment, various services of the monitoring service 412 may include monitoring of the resources, gathering of the monitoring data relating to the monitored resources, and maintaining of the monitoring data 410. The maintaining of the monitoring data 410 may include maintaining history and providing alerts when various resources, such as parameters, applications, or components reach a critical state, and such features may be enabled or disabled depending on when and whether the J2EE engine 406 is connected to the CCMS 422 via CCMS agent 402 with shared memory 404, directly or indirectly, coupled with the CCMS agent 402 and CCMS connector 408.
According to one embodiment, the JMA 400 may include the monitoring service 412 and one or more JMX-based monitor servers (JMX monitors). The monitoring service 412 may help establish a connection between a JMX monitor and the various components of the JMA 400. According to one embodiment, JMX monitors may reside and work on separate or remote Java virtual machines (JVMs) to collect data from cluster elements, and report information and statistics regarding the cluster nodes and their components to, for example, the visual administrator 414 having a monitor viewer 416, and/or to the CCMS 422 via the CCMS agent 402, and to various other third party tools. The CCMS 422, the visual administrator 414, and other third party tools may reside generally on the client side 420, while other components, as illustrated, may reside on the server side 418.
The data collected may include information and statistics related to, for example, applications, server parameters, cluster nodes and their components of the J2EE engine. According to one embodiment, the collected data may also be reported to the CCMS 422 via a CCMS agent 402, and/or to the third party tools 518. In one embodiment, the third party tools 518 include a file system to, for example, temporarily store the collected data in a specified file format such as, for example, an Extensible Markup Language (“XML”) format or a HyperText Markup Language (“HTML”) format. The collected data may subsequently be reported to the components on the client-side 420 (e.g., in an XML or HTML format.
According to one embodiment, the expected overhead of the JMA 500 may vary according to its functionality. For example, the overhead may be light when reporting to the CCMS 422 or the third party tools 518, as opposed to when reporting to the visual administrator 414. Furthermore, the larger the requesting and/or reporting interval of the monitor server 502, the smaller the expected overhead may be. The expected overhead may be relatively higher when using the monitor viewer 416 of the visual administrator 414 to actively retrieve and view the monitoring data.
According to one embodiment, managed beans (MBeans or beans) (e.g., runtime managed beans or resources beans) 612-616 may be used to provide continuous monitoring of various resources 624-628 associated with a Java 2 Platform, Enterprise Edition (J2EE) engine, such as the J2EE 406 of
According to one embodiment, JMA 600 provides monitoring of the Java 2 Platform, Enterprise Edition (J2EE) engine 406 (see, e.g.,
For monitoring of the resources 720, the JMA 700 may employ a monitor service 702 having modules, servers, and/or interfaces to connect the monitoring side with the rest of the JMA 700, including the central database 710 and client-side applications, such as the visual administrator 704 and CCMS 708. The monitoring architecture may include a managed bean server (bean server) 712, a plurality of monitor managed beans (monitor beans) 716 and/or runtime managed beans (runtime beans) 718. In one embodiment, the runtime beans 718 register with the bean server 712 to provide monitoring of the underlying resources 720 at runtime. The bean server 712 may include a container for the monitor beans 716 and the runtime beans 718, to provide them access to various resources 720 and management applications 704, 708.
To provide Java objects (e.g., monitor beans 716 and runtime beans 718) to various applications 704, 708 and to use the bean server 712 for such purposes, the applications 704, 708 may be made available via the distributed services level (e.g., distributed services level 310 of
The JMA 600 may be spread into three levels of the JMX architecture including a distributed services level 310, an agent level 320, and an instrumentation level 330 (see, e.g.,
According to one embodiment, various Java resources 720 at the agent level may be included as an external library. A JMX service module (jmx_service) may provide some of the functionality from the distributed services level, and may create an instance of the bean server 712 on each of the nodes in one or more clusters and provide local and cluster connections to all of them. The monitor beans 716 may be registered clusterwide. As such, a user or client may work with the bean server 712 transparently (e.g., from the user's perspective there may appear to be only one bean sever 712 showing all monitor beans 716 of the cluster). In addition, to receive JMX notifications clusterwide, a notification service module (jmx_notification) may be employed in combination with the JMX service.
The bean server 712 may include a registry of the monitor and runtime beans 716-718, and the bean server 712 may serve as a single entry point for calling the monitor and runtime beans 716-718 in a uniform fashion from applications 704, 708 to monitor the resources 720, and collect or gather the monitoring data or information associated with the monitored resources 726. According to one embodiment, the bean server 712 may reside at a particular Java virtual machine (JVM) and may call the registered monitor and runtime beans 716-718 from the same JVM or other JVMs. According to one embodiment, the bean server 712 may not be limited to one bean server 712 and may include multiple managed bean servers. According to one embodiment, various modules of the monitor service 702 may also reside at the same JVM along with the bean server 712, or may reside at other one or more JVMs that may be remotely located.
According to one embodiment, the resources 720 including kernel resources, libraries, interfaces, and services may be monitored using the runtime and monitor beans 716-718 registered with the bean server 712. To monitor the resources 720, including arbitrary Java resources, and be manageable, a management interface may be provided, and objects (e.g., monitor bean 716 and runtime bean 718) that implement such management interface may be registered with the bean server 712. The bean server 712, as previously described, may then serve as a container for the monitor bean 716 and the runtime bean 718, and provide them with access to the resources 720 to be monitored.
According to one embodiment, the runtime bean 718 (also sometimes referred to herein as a “resource” bean) may provide continuous or periodic monitoring of the resources 720 and may provide dynamic resource notifications or responses including information regarding the resources 720 to each of the monitor beans 716. According to one embodiment, the monitor service 702 may retrieve an Extensible Markup Language (XML) file 728, having semantics and installation directives on how a monitor tree 714 is created, from the database 710 to create the monitor tree 714. The monitor tree 714 may then be generated with various nodes, such as the node 730. Each of the nodes includes one or more monitor beans 716 associated with one or more resources 726.
According to one embodiment, the monitor bean 716 at the node 730 may request 722 information regarding its associated resource 726 from the runtime bean 718 associated with the resource. For example, the monitor bean 716 may invoke a method or request 722 during runtime to retrieve monitoring data from the runtime bean 718, and the runtime bean 718 may respond or provide a notification including the requested information 724 to the monitor bean 716 regarding the associated resource 726. According to another embodiment, the information 724 regarding the associated resource 726 may be provided periodically as predetermined and pre-set using a timer 732. The timer 732 may include predetermined criteria including a predetermined time period for periodically providing information 724 from the runtime bean 718 to the monitor bean 716.
The monitor service 702 may include an administrative services interface to provide the monitoring data or information to, for example, administrative tools including the visual administrator 704. The information received at the visual administrator 704 may be displayed using a monitor viewer 706 including a Web-based monitor browser or Graphical User Interface (GUI)-based monitor viewer. The monitor service 702 may include other interfaces, such as a managed enterprise Java beans (“MEJB”) interface, to connect to remote third party tools, and a CCMS agent to connect to the CCMS 708.
The MEJB of the MEJB interface may include the following three types of beans: (1) session beans to perform processing; (2) entity beans to represent data, which may be a row, a column, or a table in a database, and (3) message driven beans that are generated to process Java messaging service (JMS) messages. The MEJB may reside in and may be executed in a runtime environment (e.g., MEJB container), which may provide a number of common interfaces and service to the MEJB. The common interfaces and services may include security and transaction support. The MEJB interface may provide future scalability and allow multiple user interfaces to be used, such as a standard Web browser.
The managed beans, such as the monitor and runtime beans 716-718, may include the following two logical types of registered managed beans: (1) standard beans and (2) specific beans. Standard beans may provide standard functionality of start/stop, get/set properties, etc. Standard beans may be registered by default for all deployed components (e.g., kernel, libraries, interfaces, and services). Specific beans may provide component-specific functionalities that may vary from one component to another. To have the specific beans, a component may register an object that may implement a specific interface to list the processes available for its management and to extend the management interface (e.g., com.company.engine.frame.state. ManagementInterface).
According to one embodiment, for kernel resources, a standard bean may be registered with each manager having a specific bean. A prerequisite for this may be to return a non-null value in a method (e.g., getManagementInterface( )) from the manager interface. For libraries and interfaces, only standard beans may be registered. For services, except for the already registered standard beans, each of the services may register specific beans. Implementation of the management interface may also cause a specific bean to be registered for that particular service.
For example, according to one embodiment, using the monitor tree, the module developer may configure runtime beans 718 to monitor one or more resources 720 and provide the monitoring information 724 to monitor beans 716 at a particular node 730 (or group of nodes). The monitoring information 724 provided to the monitor bean 716 may be provided continuously and/or upon request 722 from the monitor bean 716 associated with the underlying resource 726.
The associated resource 726 is associated with a particular monitor bean 716 to individualize the monitoring process (i.e., by receiving monitoring information about a particular resource, as opposed to about all of the resources 720). Similarly, according to one embodiment, particular resources 720 may be associated with one or more runtime beans 718 to further individualize the process. The resources 720 may include the kernel, services, interfaces, libraries, and the like, for each of the dispatchers and servers associated with an application server engine (e.g., such as the Java 2 Platform, Enterprise Edition (J2EE) engine 406 described above).
As used herein, a “J2EE server” may include distributed J2EE servers, including, for example, multiple instances of a group of redundant J2EE servers and a dispatcher. The associated resource 726 may refer to one of the resources 720 that is associated with the monitor bean 716 at the node 730 to, for example, allow the monitor bean 716 to request monitoring information from the runtime bean 718. The end result is a simplified distribution of monitoring information in the form of a monitor tree with individual nodes, as opposed to a system in which monitoring information must be centralized.
According to one embodiment, the monitoring data 724 may then be provided to various client level applications, such as the visual administrator 704 and/or CCMS 708 via the monitor service 702. According to one embodiment, the monitor viewer 706 may be used to view the monitor tree (e.g., monitor tree 714 of
According to one embodiment, the monitor viewer 706 may be used to display other information related to the resources 720 including, for example, the name of the resource, the resource description, the resource type, relevant dates and/or time, resource properties and values. The information may also include data history regarding the resources 720. The data history may include, for example, values associated with the resource over different periods of time (e.g., over a minute, hour, day, . . . etc).
As mentioned above, according to one embodiment, an XML file 728 may be retrieved by the monitor service 702 from a central database 710 to generate a monitor tree 714. The XML file may include semantics and directives to generate the monitor tree using the monitor service 702. An XML parser may be used to parse the semantics and directives of the XML file. Furthermore, a Java Management Extensions (JMX)-based application programming interface (API) may be used to create and customize the monitor tree. The monitor API may facilitate and handle both (1) the creation of the monitor tree and (2) the customization of the monitor tree as will as the reporting of the monitoring information and values. Typically, an API refers to a language or message format used by an application program to communicate with the operating system, communications protocols, and/or with other control programs (e.g., database management systems).
At decision block 1004, it is determined whether timer notification service is being utilized. If the timer notification service is employed, the timer notification may be received at the monitor bean from the timer at processing block 1006. The request for the monitoring information regarding the associated resource may then be placed by the monitor bean with the runtime bean at processing block 1012. However, if the notification service is not employed, the process may continue with decision block 1008.
At decision block 1008, a determination is made as to whether a runtime bean notification service is used. As described above, if the runtime bean notification service is used, the runtime bean may provide a notification to the monitor bean in response to a specified event associated with the resource (e.g., when the monitored value reaches a threshold). Upon receiving the runtime notification, at processing block 1010, the monitor bean may request the monitoring data associated with the associated resource at processing block 1012.
With neither the timer notification service nor the runtime notification service is employed, the monitor bean may place a request with the runtime bean seeking the monitoring information regarding the associated resource at processing block 1012. The monitor bean may then receive such monitoring information from the runtime bean at processing block 1014. The process may then continue with processing block 1004.
The JMA 1110 may include a monitor tree (e.g., monitor tree 714 of
Memory devices 1104 may encompass a wide variety of memory devices including read-only memory (ROM), erasable programmable read-only memory (EPROM), electrically erasable programmable read-only memory (EEPROM), random access memory (RAM), non-volatile random access memory (NVRAM), cache memory, flash memory, and other memory devices. Memory devices 1104 may also include one or more hard disks, floppy disks, ZIP disks, compact disks (e.g., CD-ROM), digital versatile/video disks (DVD), magnetic random access memory (MRAM) devices, and other system-readable media that store instructions and/or data. Memory devices 1104 may store program modules, such as routines, programs, objects, images, data structures, program data, and other program modules that perform particular tasks or implement particular abstract data types that facilitate system use.
The I/O devices 1106 may include hard disk drive interfaces, magnetic disk drive interfaces, optical drive interfaces, parallel ports, serial controllers or super I/O controllers, serial ports, universal serial bus (USB) ports, display device interfaces (e.g., video adapters), network interface cards (NICs), sound cards, modems, and the like. System interconnect or network 1112 may permit communication between the various elements of node 1100. System interconnects 1112 may include a wide variety of signal lines including one or more of memory buses, peripheral buses, local buses, host buses, and bridge, optical, electrical, acoustical, and other propagated signal lines.
For example, the green mark 1208, represented here as a circle, may indicate monitoring of the corresponding resource. The yellow mark 1210, represented here as a triangle, may indicate continuous monitoring of the corresponding resource and/or may indicate that the resource being monitored is close to a critical value or stage. The red mark 1212, represented here as a square, may indicate that the corresponding resource has reached a critical value. Finally, the white mark 1214, represented here as a diamond, may indicate inactivity or that the corresponding resource is not being monitored.
In one embodiment of the invention, the management techniques which are the focus of this application are used to manage resources within a cluster of server nodes. An exemplary application server architecture will now be described, followed by a detailed description of the management architecture and associated processes.
An application server architecture employed in one embodiment of the invention is illustrated in
The server nodes 1414, 1416, 1418 within instance 1410 provide the business and/or presentation logic for the network applications supported by the system. Each of the server nodes 1414, 1416, 1418 within a particular instance 1410 may be configured with a redundant set of application logic and associated data. In one embodiment, the dispatcher 1412 distributes service requests from clients to one or more of the server nodes 1414, 1416, 1418 based on the load on each of the servers. For example, in one embodiment, a dispatcher implements a round-robin policy of distributing service requests (although various alternate load balancing techniques may be employed).
In one embodiment of the invention, the server nodes 1414, 1416, 1418 are Java 2 Platform, Enterprise Edition (“J2EE”) server nodes which support Enterprise Java Bean (“EJB”) components and EJB containers (at the business layer) and Servlets and Java Server Pages (“JSP”) (at the presentation layer). Of course, certain aspects of the invention described herein may be implemented in the context of other software platforms including, by way of example, Microsoft .NET platforms and/or the Advanced Business Application Programming (“ABAP”) platforms developed by SAP AG, the assignee of the present application.
In one embodiment, communication and synchronization between each of the instances 1410, 1420 is enabled via the central services instance 1400. As illustrated in
In one embodiment, the locking service 1402 disables access to (i.e., locks) certain specified portions of configuration data and/or program code stored within a central database 1430. A locking manager 1440, 1450 employed within the server nodes locks data on behalf of various system components which need to synchronize access to specific types of data and program code (e.g., such as the configuration managers 1444, 1454 illustrated in
In one embodiment, the messaging service 1404 and the locking service 1402 are each implemented on dedicated servers. However, the messaging service 1404 and the locking service 1402 may be implemented on a single server or across multiple servers while still complying with the underlying principles of the invention.
As illustrated in
Referring now to
In one embodiment of the invention, to improve the speed at which the servers and dispatchers access the configuration data, the configuration managers 1444, 1454 cache configuration data locally within configuration caches 1500, 1501. As such, to ensure that the configuration data within the configuration caches 1500, 1501 remains up-to-date, the configuration managers 1444, 1454 may implement cache synchronization policies.
It should be appreciated that reference throughout this specification to “one embodiment” or “an embodiment” means that a particular feature, structure or characteristic described in connection with the embodiment is included in at least one embodiment of the present invention. Therefore, it is emphasized and should be appreciated that two or more references to “an embodiment” or “one embodiment” or “an alternative embodiment” in various portions of this specification are not necessarily all referring to the same embodiment. Furthermore, the particular features, structures or characteristics may be combined as suitable in one or more embodiments of the invention.
Similarly, it should be appreciated that in the foregoing description of exemplary embodiments of the invention, various features of the invention are sometimes grouped together in a single embodiment, figure, or description thereof for the purpose of streamlining the disclosure aiding in the understanding of one or more of the various inventive aspects. This method of disclosure, however, is not to be interpreted as reflecting an intention that the claimed invention requires more features than are expressly recited in each claim. Rather, as the following claims reflect, inventive aspects lie in less than all features of a single foregoing disclosed embodiment. Thus, the claims following the detailed description are hereby expressly incorporated into this detailed description, with each claim standing on its own as a separate embodiment of this invention.
While certain exemplary embodiments have been described and shown in the accompanying drawings, it is to be understood that such embodiments are merely illustrative of and not restrictive, and that the embodiments of the present invention are not to be limited to specific constructions and arrangements shown and described, since various other modifications may occur to those ordinarily skilled in the art upon studying this disclosure.
Number | Name | Date | Kind |
---|---|---|---|
5201044 | Frey et al. | Apr 1993 | A |
5608720 | Biegel et al. | Mar 1997 | A |
5802291 | Balick et al. | Sep 1998 | A |
5944841 | Christie | Aug 1999 | A |
6026237 | Berry et al. | Feb 2000 | A |
6055492 | Alexander, III et al. | Apr 2000 | A |
6061721 | Ismael et al. | May 2000 | A |
6061740 | Ferguson et al. | May 2000 | A |
6066181 | DeMaster | May 2000 | A |
6083281 | Diec et al. | Jul 2000 | A |
6118940 | Alexander, III et al. | Sep 2000 | A |
6134581 | Ismael et al. | Oct 2000 | A |
6144967 | Nock | Nov 2000 | A |
6178529 | Short et al. | Jan 2001 | B1 |
6202199 | Wygodny et al. | Mar 2001 | B1 |
6205476 | Hayes, Jr. | Mar 2001 | B1 |
6212520 | Maruyama et al. | Apr 2001 | B1 |
6230313 | Callahan, II et al. | May 2001 | B1 |
6260187 | Cirne | Jul 2001 | B1 |
6272537 | Kekic et al. | Aug 2001 | B1 |
6289506 | Kwong et al. | Sep 2001 | B1 |
6308208 | Jung et al. | Oct 2001 | B1 |
6351776 | O'Brien et al. | Feb 2002 | B1 |
6356931 | Ismael et al. | Mar 2002 | B2 |
6381735 | Hunt | Apr 2002 | B1 |
6389464 | Krishnamurthy et al. | May 2002 | B1 |
6427228 | Wigger | Jul 2002 | B1 |
6463454 | Lumelsky et al. | Oct 2002 | B1 |
6466973 | Jaffe | Oct 2002 | B2 |
6470388 | Niemi et al. | Oct 2002 | B1 |
6539501 | Edwards | Mar 2003 | B1 |
6553403 | Jarriel et al. | Apr 2003 | B1 |
6567809 | Santosuosso | May 2003 | B2 |
6591228 | Hall et al. | Jul 2003 | B1 |
6631515 | Berstis | Oct 2003 | B1 |
6658600 | Hogdal et al. | Dec 2003 | B1 |
6662359 | Berry et al. | Dec 2003 | B1 |
6664978 | Kekic et al. | Dec 2003 | B1 |
6681232 | Sistanizadeh | Jan 2004 | B1 |
6708173 | Behr et al. | Mar 2004 | B1 |
6738933 | Fraenkel et al. | May 2004 | B2 |
6742178 | Berry et al. | May 2004 | B1 |
6754890 | Berry et al. | Jun 2004 | B1 |
6772178 | Mandal et al. | Aug 2004 | B2 |
6788315 | Kekic et al. | Sep 2004 | B1 |
6789257 | MacPhail | Sep 2004 | B1 |
6792456 | Hellerstein et al. | Sep 2004 | B1 |
6792460 | Oulu et al. | Sep 2004 | B2 |
6795791 | Gorman | Sep 2004 | B2 |
6802067 | Camp et al. | Oct 2004 | B1 |
6834301 | Hanchett | Dec 2004 | B1 |
6836878 | Cuomo et al. | Dec 2004 | B1 |
6851118 | Ismael et al. | Feb 2005 | B1 |
6853995 | Matsuzaki et al. | Feb 2005 | B2 |
6857119 | Desai | Feb 2005 | B1 |
6862711 | Bahrs et al. | Mar 2005 | B1 |
6871228 | Shah et al. | Mar 2005 | B2 |
6880125 | Fry | Apr 2005 | B2 |
6895578 | Kolawa et al. | May 2005 | B1 |
6922417 | Vanlint | Jul 2005 | B2 |
6925631 | Golden | Aug 2005 | B2 |
6934942 | Chilimbi | Aug 2005 | B1 |
6950874 | Chang et al. | Sep 2005 | B2 |
6952726 | White et al. | Oct 2005 | B1 |
6961918 | Garner et al. | Nov 2005 | B2 |
6968540 | Beck et al. | Nov 2005 | B2 |
6985848 | Swoboda et al. | Jan 2006 | B2 |
6990601 | Tsuneya et al. | Jan 2006 | B1 |
6993453 | Krissell | Jan 2006 | B2 |
7000235 | Mandal et al. | Feb 2006 | B2 |
7017051 | Patrick | Mar 2006 | B2 |
7017162 | Smith et al. | Mar 2006 | B2 |
7024474 | Clubb et al. | Apr 2006 | B2 |
7051324 | Gissel et al. | May 2006 | B2 |
7058558 | Reichenthal | Jun 2006 | B2 |
7062540 | Reddy et al. | Jun 2006 | B2 |
7069267 | Spencer, Jr. | Jun 2006 | B2 |
7082464 | Hasan et al. | Jul 2006 | B2 |
7085851 | Nusbickel et al. | Aug 2006 | B2 |
7086065 | Yeluripati et al. | Aug 2006 | B1 |
7086067 | Wason | Aug 2006 | B1 |
7093234 | Hibbeler et al. | Aug 2006 | B2 |
7120685 | Ullmann et al. | Oct 2006 | B2 |
7131113 | Chang et al. | Oct 2006 | B2 |
7150014 | Graupner | Dec 2006 | B2 |
7152104 | Musante et al. | Dec 2006 | B2 |
7155501 | Mandal et al. | Dec 2006 | B2 |
7174370 | Saini et al. | Feb 2007 | B1 |
7197559 | Goldstein et al. | Mar 2007 | B2 |
7200588 | Srivastava et al. | Apr 2007 | B1 |
7203697 | Chang et al. | Apr 2007 | B2 |
7203868 | Evoy | Apr 2007 | B1 |
7206827 | Viswanath et al. | Apr 2007 | B2 |
7209898 | Pfeiffer et al. | Apr 2007 | B2 |
7209963 | Burton et al. | Apr 2007 | B2 |
7233989 | Srivastava et al. | Jun 2007 | B2 |
7240334 | Fluke et al. | Jul 2007 | B1 |
7251809 | Barclay et al. | Jul 2007 | B2 |
7305671 | Davidov et al. | Dec 2007 | B2 |
7412497 | Viswanath et al. | Aug 2008 | B2 |
7493624 | Kautzleben et al. | Feb 2009 | B1 |
7496896 | Bley et al. | Feb 2009 | B2 |
7526519 | Potter et al. | Apr 2009 | B2 |
20020029298 | Wilson | Mar 2002 | A1 |
20020073063 | Faraj | Jun 2002 | A1 |
20020075325 | Allor et al. | Jun 2002 | A1 |
20020170036 | Cobb et al. | Nov 2002 | A1 |
20020186238 | Sylor et al. | Dec 2002 | A1 |
20020188610 | Spencer | Dec 2002 | A1 |
20030005173 | Shah et al. | Jan 2003 | A1 |
20030041142 | Zhang et al. | Feb 2003 | A1 |
20030051102 | Jacobs et al. | Mar 2003 | A1 |
20030061247 | Renaud | Mar 2003 | A1 |
20030069969 | Renaud | Apr 2003 | A1 |
20030110252 | Yang-Huffman | Jun 2003 | A1 |
20030120593 | Bansal et al. | Jun 2003 | A1 |
20030167304 | Zhu et al. | Sep 2003 | A1 |
20030177477 | Fuchs | Sep 2003 | A1 |
20030225851 | Fanshier et al. | Dec 2003 | A1 |
20030225872 | Bartek et al. | Dec 2003 | A1 |
20030236880 | Srivastava et al. | Dec 2003 | A1 |
20040003122 | Melillo | Jan 2004 | A1 |
20040019662 | Viswanath et al. | Jan 2004 | A1 |
20040019669 | Viswanath et al. | Jan 2004 | A1 |
20040019684 | Potter et al. | Jan 2004 | A1 |
20040022237 | Elliott et al. | Feb 2004 | A1 |
20040028059 | Josyula et al. | Feb 2004 | A1 |
20040031020 | Berry et al. | Feb 2004 | A1 |
20040058652 | McGregor et al. | Mar 2004 | A1 |
20040064552 | Chong et al. | Apr 2004 | A1 |
20040073782 | Price et al. | Apr 2004 | A1 |
20040078722 | Pfeiffer et al. | Apr 2004 | A1 |
20040123279 | Boykin et al. | Jun 2004 | A1 |
20040148610 | Tsun et al. | Jul 2004 | A1 |
20040154011 | Wang et al. | Aug 2004 | A1 |
20040158837 | Sengodan | Aug 2004 | A1 |
20040215649 | Whalen et al. | Oct 2004 | A1 |
20040230973 | Cundiff, Jr. et al. | Nov 2004 | A1 |
20040244001 | Haller et al. | Dec 2004 | A1 |
20040249613 | Sprogis et al. | Dec 2004 | A1 |
20040268314 | Kollman et al. | Dec 2004 | A1 |
20050010608 | Horikawa | Jan 2005 | A1 |
20050022157 | Brendle et al. | Jan 2005 | A1 |
20050028171 | Kougiouris et al. | Feb 2005 | A1 |
20050033777 | Moraes et al. | Feb 2005 | A1 |
20050038889 | Frietsch | Feb 2005 | A1 |
20050039171 | Avakian et al. | Feb 2005 | A1 |
20050039187 | Avakian et al. | Feb 2005 | A1 |
20050097110 | Nishanov et al. | May 2005 | A1 |
20050102536 | Patrick et al. | May 2005 | A1 |
20050132041 | Kundu | Jun 2005 | A1 |
20050132337 | Wedel et al. | Jun 2005 | A1 |
20050172306 | Agarwal et al. | Aug 2005 | A1 |
20050216584 | Chisholm | Sep 2005 | A1 |
20050234931 | Yip et al. | Oct 2005 | A1 |
20050234967 | Draluk et al. | Oct 2005 | A1 |
20050257157 | Gilboa et al. | Nov 2005 | A1 |
20060095674 | Twomey | May 2006 | A1 |
20070226359 | Gunduc et al. | Sep 2007 | A1 |
Number | Date | Country |
---|---|---|
2001195151 | Jul 2001 | JP |
2002073522 | Mar 2002 | JP |
2002082777 | Mar 2002 | JP |
WO 0205102 | Jan 2002 | WO |
WO 0241154 | May 2002 | WO |