US20120167083A1 - Coalescing virtual machines to enable optimum performance - Google Patents

Coalescing virtual machines to enable optimum performance Download PDF

Info

Publication number
US20120167083A1
US20120167083A1 US12/979,237 US97923710A US2012167083A1 US 20120167083 A1 US20120167083 A1 US 20120167083A1 US 97923710 A US97923710 A US 97923710A US 2012167083 A1 US2012167083 A1 US 2012167083A1
Authority
US
United States
Prior art keywords
virtual machines
basg
network
current resource
usage data
Prior art date
Legal status (The legal status 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 status listed.)
Granted
Application number
US12/979,237
Other versions
US9354960B2 (en
Inventor
John M. Suit
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Red Hat Inc
Original Assignee
Red Hat 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 Red Hat Inc filed Critical Red Hat Inc
Priority to US12/979,229 priority Critical patent/US9588821B2/en
Priority to US12/979,255 priority patent/US9477572B2/en
Priority to US12/979,237 priority patent/US9354960B2/en
Priority to US12/979,245 priority patent/US9495152B2/en
Priority to US12/979,259 priority patent/US9727440B2/en
Assigned to RED HAT, INC. reassignment RED HAT, INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: SUIT, JOHN M.
Publication of US20120167083A1 publication Critical patent/US20120167083A1/en
Application granted granted Critical
Publication of US9354960B2 publication Critical patent/US9354960B2/en
Active legal-status Critical Current
Adjusted expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/0703Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation
    • G06F11/079Root cause analysis, i.e. error or fault diagnosis
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/0703Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation
    • G06F11/0706Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation the processing taking place on a specific hardware platform or in a specific software environment
    • G06F11/0712Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation the processing taking place on a specific hardware platform or in a specific software environment in a virtual computing platform, e.g. logically partitioned 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/3442Recording 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 for planning or managing the needed capacity
    • 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
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45558Hypervisor-specific management and integration aspects
    • 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/3409Recording 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 for performance assessment
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45558Hypervisor-specific management and integration aspects
    • G06F2009/45591Monitoring or debugging support
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2201/00Indexing scheme relating to error detection, to error correction, and to monitoring
    • G06F2201/81Threshold
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2201/00Indexing scheme relating to error detection, to error correction, and to monitoring
    • G06F2201/815Virtual
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2201/00Indexing scheme relating to error detection, to error correction, and to monitoring
    • G06F2201/865Monitoring of software

Definitions

  • Embodiments of the invention relate to analyzing network traffic analysis and, in particular, to performing automatic determining of service groups within a communications network.
  • An enterprise may be thought of as a geographically dispersed network under the jurisdiction of one organization. It often includes several different types of networks and computer systems from different vendors.
  • These network nodes that are part of the enterprise may be comprised of both physical and virtual machines.
  • Enterprise networks that include a plurality of virtual machines may require a physical host, which is required to allocate resources among the virtual machines.
  • Groups of network nodes included in the enterprise may form business process application service groups (BASGs).
  • BASGs business process application service groups
  • the “components” of these groups are comprised of virtual machines, hosts, storage devices and network devices. Each of these components may be dependent on one another.
  • enterprise environments are not designed to pair virtual machines with hosts, storage devices, and network BASGs. As a result the virtual machines are not fully optimal and available resources may be underutilized.
  • FIG. 1 illustrates an example embodiment of a system for creating and updating an ontological description of a network.
  • FIG. 2 illustrates a detail of ontological creation engine, according to an example embodiment.
  • FIG. 3A illustrates an example graphical user interface to view the amount of allocated resources used over time, according to example embodiments of the present invention.
  • FIG. 3B illustrates an example table of BASG profile information and related input data and corresponding threshold metric values for the virtual machine candidates, according to example embodiments of the present invention.
  • FIG. 4 illustrates a graphical user interface used to view the network hierarchy, according to example embodiments of the present invention.
  • FIG. 5 illustrates an example flow diagram, according to example embodiments of the present invention.
  • FIG. 6 illustrates another example flow diagram, according to example embodiments of the present invention.
  • FIG. 7 is a block diagram of an exemplary computer system that may perform one or more of the operations described herein, according to example embodiments of the present invention.
  • Example embodiments of the present invention may include a method of assigning virtual machines operating in a network.
  • the method may include generating a list of the virtual machines currently operating in the network, surveying the virtual machines to determine their current resource usage data and ranking the virtual machines based on their current resource usage data to indicate available resources of the virtual machines.
  • the method may also include assigning the virtual machines to at least one business application service group (BASG) that requires the available resources of the virtual machines.
  • BASG business application service group
  • the apparatus may include a memory to store a list of the virtual machines currently operating in the network.
  • the apparatus may also include a processor to generate the list of the virtual machines currently operating in the network, store the list in the memory, survey the virtual machines to determine their current resource usage data, rank the virtual machines based on their current resource usage data to indicate available resources of the virtual machines, and assign the virtual machines to at least one business application service group (BASG) that requires the available resources of the virtual machines.
  • BASG business application service group
  • the term “message” has been used in the description of embodiments of the present invention, the invention may be applied to many types of network data, such as packet, frame, datagram, etc.
  • the term “message” also includes packet, frame, datagram, and any equivalents thereof.
  • certain types of messages and signaling are depicted in exemplary embodiments of the invention, the invention is not limited to a certain type of message, and the invention is not limited to a certain type of signaling.
  • FIG. 1 illustrates an example logic diagram of a system 100 configured to deploy data collection agents onto network nodes, according to example embodiments of the present invention.
  • an application server 101 interfaces with a web browser 102 and a local agent data collection network element 500 .
  • Certain operations may be performed by the system 100 , such as, monitoring network connections instantiated at each network node, acquiring resulting data, automatically creating an ontological description of the network from the acquired data, dynamically updating the ontological description, etc.
  • elements of system 100 may utilize the Java® software platform and Enterprise Java Bean® (EJB) architecture to provide certain functionality.
  • EJB Enterprise Java Bean®
  • System 100 may consist of an application server 101 , which interacts across a network with a number of data collection agents 500 .
  • Application server 101 may be an element of an administrative console (AC) that also provides a suite of network management tools.
  • a system administrator may perform network traffic analysis and/or other network management tasks by accessing application server 101 through a web browser 102 .
  • Application server 101 may include an EJB module 612 , an ontological description creation engine 613 , and a web application 111 .
  • Web browser 102 may include a rendering engine 102 B and a knowledge browser 102 A.
  • data collection agent(s) 500 may be deployed onto network nodes including physical and/or virtual machines in an enterprise information technology (IT) infrastructure environment.
  • application server 101 receives messages from data collection agents 500 .
  • These messages may include data representing, for example, state and relationship information about the network nodes, configuration information related to the IT infrastructure, performance/utilization data and network communication.
  • Thresholds are assigned to a component and/or can also be assigned to an entire business application service group (BASG).
  • BASG business application service group
  • a host may provide CPU usage as a resource allocated to a virtual machine, the CPU operational usage performance is an example metric.
  • the virtual machine and host machine are both examples of components.
  • the received messages may be initially handled by EJB module 612 .
  • message driven EJB 623 may initially inspect a received message.
  • a received message relating to network traffic or node status may be forwarded by message driven EJB 623 to the business logic EJB 624 .
  • Business logic EJB 624 may call network traffic analysis engine 625 for messages relating to network traffic.
  • infrastructure messages i.e., those messages relating to node status
  • State and profiling engine 626 may identify the entities within the IT infrastructure as well as their dependency on one another, based on messages received from the platform.
  • state and profiling engine 626 may perform further processing to determine the state of one or more entities.
  • State may be based on a threshold that has been defined, for example, by the system administrator.
  • the threshold may be based on a metric that either exceeds or underperforms in a specific area of interest of the system administrator.
  • An example threshold may be set for a server operating in the enterprise network that is exceeding a specified CPU utilization percentage, a disk utilization percentage and/or a memory utilization percentage.
  • a data output from state and profiling engine 626 may be sent to ontological description creation engine 613 .
  • the data may be handled by a resource description framework (RDF) application programming interface (API) knowledge base 620 , where the data is categorized and stored utilizing a predefined entity relationship determined by ontology web language (OWL) API or ontology model 621 .
  • RDF resource description framework
  • API application programming interface
  • Messages handled by the network traffic analysis engine 625 may include source-to-destination data, qualified by a communicating application within the operating system of the originating node, as well as frequency of communication information. This received data is analyzed by processing the number and type of connections to determine if an ontological “communicates_with” relationship exists. A determination may be made by tracking the number of connections of a specific application over a period of time. The period of time may be preselected, for example, by the system administrator.
  • Data output from network traffic analysis engine 625 may be sent to ontological description creation engine 613 .
  • the data may be handled by the RDF API knowledge base 620 where the data is categorized and stored utilizing a predefined entity relationship, determined by OWL API ontology model 621 .
  • OWL API ontology model 621 may define what entity classes exist, their possible relationship to each other, and their possible state.
  • FIG. 2 illustrates a detailed diagram of ontological description creation engine 613 , according to example embodiments of the present invention.
  • logic in the RDF API knowledge base 620 may map the incoming data to the appropriate ontological classes and relationships defined by OWL ontology API model 621 . Once the correct classes and relationships are selected, the entity and relationship information may be entered into RDF API knowledge base 620 .
  • the knowledge base may also be forwarded to a SPARQL database or query engine 622 for later inference processing by inference engine 633 .
  • Inference engine 633 may determine inferred relationships based on the ontology model contained in OWL ontology API model 621 .
  • OWL web ontology language
  • Ontologies are used to represent the properties of a domain, and may be used to describe the domain.
  • the ontology provides the direct and indirect dependency information that the (SPARQL) query engine 622 requires in order to infer the impact a change in “state” will have on the rest of a service group or BASG.
  • a business application will typically include a primary application with one or more executables that execute on one or more nodes of the network. These nodes may have direct and indirect dependencies on other nodes of the network.
  • the business application may be described by a network ontology. When an alert state occurs for the business application, the components of the business application ontology may be analyzed to determine what adjustments are required to achieve a steady state based on assigned thresholds.
  • the root cause may be a direct or indirect root cause, which may then be reported to the system administrator.
  • a visualization of a current network state and/or communication activity may be provided to an administrator.
  • the system administrator may be provided with a visual rendering (e.g., on a computer monitor) of the knowledge base.
  • the visualization may be filtered to any selected entity of interest.
  • the system administrator or other user may use a web browser 102 to request rendering of data via web application 111 from controllers 627 .
  • Controllers 627 may pass along any filtering information such as a specific Host ID.
  • business logic EJB 624 may be called by the controllers.
  • Business logic EJB 624 may query RDF API knowledge base 620 for requested data.
  • the requested data may be returned through controllers 627 to the web browser.
  • the requested data may then be converted into a directed graph chart by a rendering engine.
  • Example embodiments of the present invention may provide the ability to automatically determine allocation adjustments that may be required for virtual machine performance, and monitoring the service tier thresholds assigned to a specified virtual machine.
  • Thresholds are directly related to a node “state”.
  • the state may be defined as an indicator to the system and the user of a business application service, such as, whether, the business application service meets a specified threshold requirement.
  • the process to determine the state of an individual element may be based on a threshold that has been defined, for example, by the system administrator.
  • the threshold may include a metric that either exceeds or underperforms in a specific area of interest of the system administrator. An example would be a server in a network that is exceeding a specified CPU utilization percentage.
  • Example embodiments of the present invention may provide automatically detecting when a virtual machine's baseline of performance requires an allocation change from the virtual machine's host. Determining the percentage of increase or decrease in CPU usage, memory usage, storage usage, and network usage may be required in order to maintain a baseline operating in a normal range.
  • the system 100 may monitor for a steady state of a virtual machine by tracking service tier thresholds identified as normal.
  • the system will provide the virtual machine's host with the changes in performance allocations needed to operate within a normal range to continue or achieve a normal range.
  • the adjustment is expressed in terms of a percentage increase or decrease from the present allocation of resources assigned to it by its physical host.
  • first user terminal could be termed a second user terminal, and similarly, a second user terminal may be termed a first user terminal without departing from the teachings of the present invention.
  • second user terminal may be termed a first user terminal without departing from the teachings of the present invention.
  • the term “and/or” includes any and all combinations of one or more of the associated listed items. The symbol “/” may also be used as a shorthand notation for “and/or”.
  • Networks including computer entities, physical and/or virtual machines operating on network nodes, etc. may be advantageously described via an ontology that describes the operational usage and current state of the entities rather than being based on a fixed IT infrastructure architecture.
  • the ontological description may be automatically and dynamically updated based on data acquired from data collection agents deployed to the nodes of the network.
  • the data collection agents observe communicative relationships based on connections between nodes in operational use, while annotating a class state.
  • a network analyst or system operator may be provided with an improved ability to analyze network traffic.
  • Data relating to actual connections may be acquired automatically in near real-time. For example, an actual connection may be monitored in an interrupt-driven way while collecting information regarding an application that made the connection. Moreover a “volume for the connections” may be derived.
  • a software-based data collection agent may be received by a computing device at a node within a communications network. The agent may be distributed to one or more nodes from a central node via the network.
  • the software-based data collection agent may be inserted in an operating system of the receiving node.
  • the agent may be inserted in the kernel of the operating system or in a user space (i.e., an area in virtual memory of a computer that contains user applications that execute at the application layer).
  • the installation may be performed such that it is transparent or undetectable by a user of the node.
  • the installed data collection agent may monitor data packet traffic between an adaptive driver layer and a protocol layer and report results of the monitoring to the central node.
  • the data collection agent 500 may have an interface to an operating system's network stack and may periodically determine what applications are using the network stack. As a result, the data collection agent may track information regarding a network connection, the connection duration, and any applications and systems involved in the connection. Moreover, the data collection agent 500 may normalize the foregoing information and report it to an administration console so that different operating systems may be correlated by the administration console.
  • the data collection agent 500 may include a network filter inserted into the network stack to determine exactly when a connection is made between entities.
  • the filter component of the data collection agent may be inserted at one or more layers of the OSI model.
  • a data collection agent 500 may have a filter interface at the transport layer and/or a filter interface at the network layer.
  • the data collection agent 500 may track information regarding a network connection, the connection duration, and any applications and systems involved in the connection.
  • the data collection agent may normalize the foregoing information and report it to the administration console so that different operating systems may be correlated by the administration console.
  • the data collection agent 500 described in the preceding paragraphs may also include a packet filter inserted into the network stack to track connection data.
  • a data collection agent 500 may have a filter interface at the data link layer. Then, the data collection agent 500 may correlate and normalize (if required) data from the network filter and the packet filter to track information regarding the network connection, the connection duration, any applications and systems involved in the connection, connection status and connection resource usage information. Moreover, the data collection agent 500 may normalize the foregoing information and report it to the administration console so that different operating systems may be correlated by the administration console.
  • an illustrative system 100 for deploying data collection agents onto network nodes, monitoring network connections instantiated at each network node, acquiring resulting data, automatically creating an ontological description of the network from the acquired data, and dynamically updating the ontological description will be described.
  • the system 100 may further be used for monitoring configuration drifts within an enterprise network as will be described in more detail below.
  • elements of system 100 utilize the Java software platform and Enterprise Java Bean (EJB) architecture to provide certain functionality, and these well-known terms may be used in the description that follows.
  • EJB Enterprise Java Bean
  • the process to automatically determine a performance allocation may begin by monitoring those virtual machines that have sustained a service tier threshold in either a critical low and/or a critical high level for more than 24 hours. Such an observation may be observed by the virtual machine agent.
  • the SQARQL query engine 622 simultaneously initiates a query for current performance threshold data stored in a database.
  • the components' states may be determined since they have thresholds that include at least one of achieved, overachieved, and/or underachieved.
  • Nodes, executables and the business application service groups (BASGs) may also incorporate status and alerts from infrastructure providers.
  • the executables may have a state that relates to the “communicates_with” relationship. For example, if an executable such as sqlservr.exe no longer communicates with node X, it may be designated critical high and indicated on a user interface as red or as a warning. This example may be true of a node that represents a “communicates_with” relationship as well as a primary application represented as a node.
  • the state and profiling engine 626 may set the state of the business application service group (BASG) using the agent data and system information.
  • BASG business application service group
  • the user may view the component as red (indicating a high warning) as well as the BASG itself being displayed in red on a graphical user interface.
  • Various other visual indicators e.g., shapes, sizes, shades, etc. may be used to illustrate different operating performance levels.
  • the process to determine the state of an individual element may be based on a threshold that has been defined, for example, by the system administrator.
  • the threshold may include a metric that either exceeds or underperforms in a specific area of interest to the system administrator. An example would be where a server in a network is exceeding a specified CPU utilization percentage.
  • Example embodiments of the present invention may automatically determine the optimum pairing of virtual machines in a business process application service group (BASG) to maximize performance as measured by a service tier threshold system. Examples may include automatically analyzing the baseline of direct and indirect connections based on network interactivity of the applications that are utilized to perform a process.
  • BASG business process application service group
  • a BASG is comprised of one or more nodes operating on the enterprise network.
  • the basis for an automatic base-lining procedure may be in the ontological structure of the categorized BASG.
  • the resulting data file may contain a structure that includes classes, object properties, and data values.
  • the system creates a profile type for each selected BASG host, storage device, and other network dependent components/elements. This profile may include specific attributes that are used to pair virtual machines with BASGs providing the virtual machine to execute optimally.
  • Example operations may provide identifying specific virtual machines to pair with a specific business BASG.
  • One ore more virtual machines may be paired with one or more BASGs.
  • the system may determine which BASGs are best suited for a pairing based on parameters that include high availability, high capacity, high speed, moderate capacity, moderate speed, moderate availability, low capacity, low speed, and low availability. These are considered by the system to be the BASG types.
  • the virtual machines that require these attributes are then paired to these BASGS.
  • the system 100 may analyze each of the BASGs performance data to determine if any of the BASGs would benefit from a newly added virtual machine pairing. This analysis may be performed by processing the aggregate service tier thresholds of the host member(s) of the BASG. For example, by processing the state information of both the storage and network BASG dependencies, the need for additional virtual machines may be apparent based on the needs and requirements of the BASG. The storage and network state information may be factored with the host performance threshold data and state information to determine a profile of the BASG.
  • the BASG profile may include categories, which may include but are not limited to high availability, high capacity, high speed, moderate capacity, moderate speed, moderate availability, low capacity, low speed, and low availability.
  • FIG. 3B illustrates an example table of a BASG profile and its corresponding threshold data input and service tier threshold metric information required for a virtual machine candidate selection process. Depending on the metrics that are measured, a virtual machine that is operating less than or above the specified metric ranges included in FIG. 3B , may not be considered a candidate for pairing with a particular BASG.
  • the service tier thresholds may be based on the requirements of a particular BASG and its current operating baseline.
  • the system 100 may analyze the virtual machines to determine the optimal combination of host applications, storage required and network performance by analyzing the service tier threshold performance data acquired.
  • Each virtual machine is assigned a profile requirement, such as, high availability, high capacity, high speed, moderate capacity, moderate speed, moderate availability, low capacity, low speed, and low availability.
  • the system 100 pairs the virtual machine with at least one host, network, and storage group that has availability and, which may be assigned to a BASG. Or, alternatively, the BASG can produce availability by migrating one or more less optimally paired virtual machine elsewhere.
  • the system 100 may also provide a work order that can be processed by an orchestration system, or, individual, who is responsible for executing the changes.
  • the system 100 routinely (as defined through the user interface) monitors the networking environment to maintain optimum virtual machine pairings with host, storage, and speed groups that include one or more BASGs.
  • FIG. 3A illustrates an example graphical user interface (GUI) used to demonstrate resource allocation and usage over time, according to example embodiments of the present invention.
  • GUI graphical user interface
  • a GUI for a system administrator may include a graph of percentage of capacity vs. time (weeks).
  • resources are included in the graph, including, CPU allocation 301 , memory allocation 302 , memory usage 303 and CPU usage 304 .
  • the performance details are illustrated in a table that includes the current base-line information, last week, last four weeks and last three months, and days remaining.
  • a physical capacity summary is also provided for easy summarization of the total CPU capacity, memory capacity and disk capacity.
  • This base-line summary provides a system administrator with a snapshot of operating conditions of the BASGs, virtual machines and overall available resources. This provides the system administrator with the information necessary to determine if the BASGs, virtual machines and available resources are being utilized efficiently throughout the network.
  • FIG. 4 illustrates another example GUI according to example embodiments of the present invention.
  • a hierarchical logic flow diagram 400 includes a host device 401 , which may be a SQL team of individuals assigned to a particular BASG, and two different virtual machines 402 and 403 .
  • the various network resources 404 - 411 are illustrated as being assigned to at least one virtual machine.
  • Resource icon 404 represents a logical network in the “enterprise” for virtual machine 402 . It is associated with a device at the virtual infrastructure management level (i.e., ESX Server), which is a name for the network as it is known to the enterprise for our purposes.
  • ESX Server virtual infrastructure management level
  • Resource icon 405 is the physical host (hardware) for the virtual machine 402 along with other virtual machines, and is referred to as the hypervisor.
  • Resource icon 406 is the network for virtual machine 402 . It is the same as 404 , a logical network in the “Enterprise”, and is associated with a device at the virtual infrastructure management level (i.e., ESX Server), which is a name for the network as it is known to the enterprise for our purposes.
  • ESX Server virtual infrastructure management level
  • Resource icon 407 is a datastore for virtual machine 402 . It represents a physical allocation of disk storage, and is associated with a hard disk storage device at the virtual infrastructure management level.
  • Resource icon 408 is the “User” assigned to both virtual machines 402 and 403 . It has been defined and assigned by this virtualization management software.
  • Resource icon 409 is the host for virtual machine 403 . The host is a physical host (hardware) that the virtual machine is running on, along with other virtual machines, and may be referred to as the hypervisor.
  • Resource icon 410 is the primary application that is being executed on the virtual machine 403 .
  • 411 is the datastore for the virtual machine 403 . These resource icons may be dragged and dropped to reassign resources to the virtual machines, and, in turn, modify the allocations of the BASGS.
  • the system 100 will automatically determine the optimum pairing of virtual machines with BASGs to maximize performance as measured by a service tier threshold monitoring system.
  • the application server 101 may receive a message to survey the virtual machines for their respective CPU and memory usage over the past 30 days. The survey may be performed by the web application server 101 sending a request to the state and profiling engine 626 to compile the usage data from the database.
  • the state and profiling engine 626 may transmit a JMS message to the business logic 624 that compiles the database query.
  • the business logic 624 generates an EJB based query that includes a request for CPU and memory usage data for the last 30 days.
  • a ranking may be performed by the SPARQL query engine 622 initiating a query.
  • An Example of the data returned by the database is described with reference to FIG. 1 . This data is used to rank the virtual machines. The ranking is averaged over the range of virtual machines returned. The ranked virtual machines are then assigned a profile by the state and profiling engine 626 .
  • the profiles may include high availability, high capacity, high speed, moderate capacity, moderate speed, moderate availability, low capacity, low speed, and low availability.
  • the breakpoints for the profiles may match the predefine service tier thresholds assigned by the system.
  • the state and profiling engine sends this list via a profile EJB to the RDF API knowledge base 620 .
  • the system 100 initiates the process to compile a candidate list of BASG dependencies.
  • the virtual machines that reside in the described ontological structures are not considered for the candidate process.
  • the BASG candidate process is initiated by the state and profiling engine 626 .
  • the state and profiling engine 626 sends a JMS request message to the business logic 624 to compile a list of candidate hosts, networks, and storage groups that are configured within the BASGs.
  • the request is included within a profile EJB. This results in a database query for usage data for the last 30 days from the database.
  • the business logic sends a request to the RDF API knowledge base 620 for state data for host, network, and storage roll-up data based on 24 hour roll-ups for the last 30 days.
  • the state data may contain warning or errors that resulted in a “red” state for the given nodes.
  • the usage and state information are sent back to the state and profiling engine 626 , where they are used to rank and profile the BASGs.
  • the ranked BASGs are then assigned a profile by the state and profiling engine.
  • the BASG profiles may include high availability, high capacity, high speed, moderate capacity, moderate speed, moderate availability, low capacity, low speed, and low availability.
  • the breakpoints for the profiles may match the service tier thresholds previously assigned by the system.
  • the state information for each BASG may be used to assign a profile by automatically assigning a “low” profile to any BASG that is experiencing a warning or error (red indication).
  • the error may be based on a 20% margin of exceeding the predefined resource threshold, and may be based on a 24 hour data roll-up for a 30-day period.
  • No virtual machines are used to rank a BASG. The virtual machine itself is ranked in the virtual machine profile process mentioned above.
  • the state and profiling engine 626 may use a standard matching algorithm to pair the virtual machines with BASGs.
  • the state and profiling engine 626 generates a report that details the recommended change in virtual machine assignment to BASGs. This list may be formatted in XML to be utilized by an orchestration system to complete the changes or to be read by a user for manual adjustments.
  • the states of the individual business application service components may be aggregated to calculate an overall state for the BASG. Any support nodes within the BASG ontology that have achieved a high warning may be labeled under the BASG as having a high warning. If any one node with a “communicates_with” relationship achieves a high warning status it may be identified as having a high warning for its associated BASG. High errors may be identified in a similar manner. For example, in order for a node to achieve these states, the states must have been observed and processed by the state and profiling engine 626 three times within one hour. As a result, spurious errors and random faults will not lead to warnings being generated for the overall business application process.
  • the method of FIG. 5 may be performed by processing logic that may comprise hardware (e.g., circuitry, dedicated logic, programmable logic, microcode, etc.), software (such as instructions run on a processing device), firmware, or a combination thereof.
  • processing logic may comprise hardware (e.g., circuitry, dedicated logic, programmable logic, microcode, etc.), software (such as instructions run on a processing device), firmware, or a combination thereof.
  • the method is performed by a server (e.g., application server 101 of FIG. 1 ).
  • a query is sent to the RDF knowledgebase 620 that identifies the BASG that is currently in an error state.
  • the RDF knowledge base 620 returns the list of components of the BASG (e.g., hardware nodes, virtual nodes, executables, processes, primary applications, etc) and their state.
  • the primary application of the BASG is considered by the RDF knowledge base to be a “node”. Any of these components of the BASG may have independent thresholds assigned by the system administrator. Examples of components may include virtual machines, host machines, storage devices, network devices. Examples of resources that are allocated may include memory, CPU, storage disk space, network adapters. Examples of metrics may include a CPU utilization of 1024 Ghz, a memory utilization of 8 gigabytes, a network adapter operating at 100 Mbps, etc.
  • a filter is applied to determine those components that may have contributed to the “high warning” threshold that was exceeded and which triggered an alarm.
  • the filter omits any individual component that has not exceeded a “high warning” threshold individually from the process. This may reduce the chances of false alarms occurring due to random instances of a predefined threshold being exceeded.
  • the process continues by inspecting each of the filtered components to determine a root cause.
  • the inspection process looks up performance data previously reported by the agents deployed to the nodes.
  • the inspection process may yield all of the component's relevant data for determining a root cause.
  • the data used for this determination is service tier data, such as, CPU, memory, disk, and network operation threshold roll-up data (last 30 days), though other relevant data may also be used.
  • the root cause process may also use virtualization infrastructure alarms and network status updates. These are available to the system for host, virtual machines, disks, and network devices, and may be sent in messages from a proxy agent.
  • the proxy agent may contain an instruction for translating virtual infrastructure messages to a format that the state and profile engine 626 can process. If, for example, the proxy agent receives a message from the virtual infrastructure stating a disk has achieved full capacity and has an error level of 3, the proxy agent will modify the received message with a translation on the “level of 3” to “High Error.” This is then sent to the message driven bean factory 623 , where an EJB is created with the contents received from the proxy agent. The business logic then routes the new state EJB to the state and profiling engine 626 . This data is provided to the user as support evidence for the root cause conclusion.
  • the SPARQL query engine 622 determines the state of the primary applications and the contributing executables that make up the primary application by requesting the ontology for the business application service.
  • the ontology is analyzed for breaks in communication with nodes, as described in the Applicant's co-pending applications referenced above.
  • the SPARQL query engine 622 will send a request to the agent to send back the performance statistics of the executables that make up the primary application of the business application service. This will provide the user with the real-time performance statistics of the executables to provide support for a conclusion that a root cause of failure is due to the failure of the primary application support nodes, at operation 504 .
  • the result of the conclusion may automatically trigger a recommendation to perform an increase and/or decrease in the present resource allocation of resources provided by a virtual machine(s), at operation 505 .
  • CPU resources and disk space may be reallocated from among the network resources by the system administrator as a result or receiving the recommendation. Or, alternatively, certain reallocation measures may be performed automatically.
  • System 100 may comprise an application server 101 , which interacts across a network with a number of data collection agents 500 deployed in various nodes of the network.
  • application server 101 may be an element of an administrative console (AC) that also provides a suite of network management tools.
  • a system administrator may perform network traffic analysis and/or other network management tasks by accessing application server 101 by way of web browser 102 .
  • Application server 101 may comprise an EJB module 612 , an ontological description creation engine 613 , and a web application 111 .
  • Data collection agents 500 may be deployed onto network nodes including physical and/or virtual machines in an enterprise IT infrastructure environment. After such deployment, application server 101 receives messages from data collection agents 500 . These messages may include data representing, for example, state and relationship information about the network nodes, configuration information related to the IT infrastructure, performance/utilization data and network communication.
  • the received messages may be initially handled by EJB module 612 .
  • message driven EJB module 623 may initially inspect a received message.
  • a received message relating to network traffic or node status may be forwarded by message driven EJB 623 to the business logic EJB 624 .
  • Business logic EJB 624 may call network traffic analysis engine 625 for messages relating to network traffic.
  • “infrastructure messages” i.e., those relating to node status
  • the state and profiling engine 626 may identify the entities within the IT infrastructure as well as their dependency on one another, based on messages received from the platform. In addition, state and profiling engine 626 may perform further processing to determine the state of one or more entities.
  • the states may be based on a threshold that has been defined, for example, by the system administrator.
  • the threshold may be based on a metric that either exceeds or underperforms in a specific area of interest to the system administrator. An example would be a server operating in a network that is exceeding a specified CPU utilization percentage.
  • the threshold may be set to 80% CPU utilization and if the server is operating at 81%, the threshold is being exceeded.
  • Example embodiments for determining a required resource allocation of a virtual machine based on thresholds are discussed below.
  • the web application server business logic creates a message request to provide the necessary changes in virtual machine performance allocation variables to create a condition of no critical low and/or no critical high conditions for the next 24 hours. If the recommended change is not successful, the cycle repeats by incrementing the 24 hour period with no critical low and/or no critical high warning by the service tier threshold system. Another 24 hour monitoring period may then begin.
  • a recommendation of a change in a variable by a factor of 10% may be a general modification used to satisfy a threshold condition that has been exceeded/underperformed.
  • the 10% factor modification may be used until the virtual machine exceeds a performance request, which results in the web browser 102 initiating a message to the web application 111 and controllers 627 of the virtual machine.
  • This modification in turn, creates a message driven entity bean that contains the request, which is transferred to a rules engine.
  • the rules engine sends a request to gather a historical period of information to the web browser 102 . Such historical information may be for a period of 1 to 90 days.
  • the rules engine (not shown) may be part of creation engine 613 and/or EJBs 612 .
  • the rules engine message is sent to a database (not shown) to gather the data tables requested.
  • the database sends the data back to the rules engine.
  • the rules engine factors the data resulting in a recommendation to increase or decrease the allocation for each of the performance threshold criteria, which may include, for example, CPU utilization, memory utilization, data storage utilization, and network resource utilization.
  • the resource modification recommendation is created by the creation engine, which may also be referred to as a rules engine 613 .
  • the rules engine 613 may perform averaging the actual threshold observed by the service tier threshold integer (0-100 scale). The average is taken from metrics observed while the virtual machine is observed in its normal operating range. If no normal range is observed, than the rules engine will increment the recommended change by increasing or decreasing the allocated resource(s) by 20% until a normal range is observed over a period of 24 hours. According to one example, the recommended increase or decrease is only 10% for a period following 24 hours if the data gathered does contain “normal” range input data.
  • a proxy agent may be part of the local agent that is used to collect data. In operation, the proxy agent collects data from the virtual infrastructure management provider. The user will utilize the default thresholds or adjust them as deemed necessary. Thresholds are used by the state and profiling engine 626 for tracking the “state” of the nodes that make up the components for a business application process. The inventory in the database may be updated by the proxy agent with a list of virtual machines, storage, hosts, and network devices.
  • the agent may be deployed via the physical hosts connected directly to the virtual machine's O/S.
  • the state and profiling engine 626 assigns the “state” of the various network components and receives additional input from the proxy agent to factor into the “state” (e.g., alarms, network, and “communicates_with” relationship status, etc.) and updates the RDF API knowledge base 620 ontologies to reflect the assignments.
  • the agent tracks executable applications to see what other nodes are communicating with the virtual machines (VMs) in the enterprise.
  • the network traffic analysis engine 625 determines which executable applications and services are communicating with other nodes that constitute a “communicates_with relationship.” A determination may be made as to whether any pairs of nodes have a “communicates_with relationship.” Upon the assignment of a “communicates_with” relationship to the ontology of a node and its direct and indirect relationships, the state and profiling engine 626 assigns the group of nodes as a “service group.”
  • the RDF API knowledge base 620 stores an ontology for each individual node.
  • the model and structure the system uses to create and update the knowledge base is contained within the ontology web language (OWL) file present on the application server 101 .
  • OWL ontology web language
  • the state and profiling engine 626 tracks the “state” continually of the components and receives additional input from the proxy agent to factor into the “state” (e.g., alarms, network, and “Communication_with” relationship status).
  • the user may identify a “service group” of network nodes as a business application service group (BASG) by selecting a name for the group of nodes and the executables that are the basis for the “communicates_with” relationship.
  • BASG business application service group
  • the user may also add nodes that the system did not auto-detect as a component of the service group. Those added nodes will be recorded and stored in the ontology model 621 .
  • the ontology itself provides the direct and indirect dependency information of the nodes that the SPARQL query engine 622 requires to infer the impact a change in “state” will have on the rest of the service group. For instance, if a storage device's (component) state is changed to “RED” because it is almost full (e.g., only two gigabytes left of a 1500 gigabyte memory) then this may cause the physical host to start the paging memory, which will effect the performance of any and all virtual machines running on that physical host.
  • the SPARQL query engine 622 parses the service group ontology for the components that have a “communicates_with” relationship, which forms the basis for a primary application.
  • the state and profiling engine 626 tracks the “state” of the BASG by requesting the current “state” from the RDF knowledge base 620 and updating the ontology when any new messages are received from the business logic EJB factory 624 .
  • the ontology itself provides the direct and indirect dependency information that the SPARQL query engine 622 requires to infer the impact a change in “state” will have on the rest of the BASG.
  • SPARQL query engine 622 parses the BASG ontology for the components that have a “communicates_with” relationship, which forms the basis for a primary application.
  • SPARQL query engine 622 provides a list of candidate BASG members for base-lining and adjusting what may be needed to achieve “normal” acceptable performance levels.
  • a list of qualifying components may be produced.
  • SPARQL query engine 622 may parse the BASG ontology to determine the components that have a “communicates_with” relationship. Such components may be used to form the basis for a primary application.
  • SPARQL query engine 622 may generate a list of virtual machine and BASG member pairing recommendations.
  • Web application server 101 may receive the message to survey the virtual machines for their CPU and/or memory usage over the past 30 days. Web application server 101 may send a request to the state and profiling engine 626 to compile the usage data from the database. The state and profiling engine 626 sends a message to the business logic 624 that compiles the database query. The business logic 624 generates an entity Java Bean (EJB) based query that includes a request for CPU and memory usage data for the last 30 days.
  • EJB entity Java Bean
  • a ranking may be performed by the SPARQL query engine 622 .
  • the ranking may be performed by sorting a list of the observed performance metrics averaged over time.
  • the best candidate may be generated as being available on top of the generated list.
  • the user may drag and drop the best candidate virtual machine to create a pair with the BASG. As a result of the pairing operation, the next available candidate becomes the top candidate.
  • the performance data is averaged over the total number of virtual machines (VMs) returned to create the ranking list.
  • the ranked virtual machines are then assigned a profile by the state and profiling engine 626 .
  • the profiles may include high availability, high capacity, high speed, moderate capacity, moderate speed, moderate availability, low capacity, low speed, and low availability.
  • the VMs that are operating closest to within the thresholds are ranked in order with the closest matched VM placed on top or in first position in the table of FIG. 3B .
  • the breakpoints may be established as the points that the threshold metrics dictate the profile characteristics.
  • the state and profiling engine 626 sends this list via a profile EJB to the RDF API knowledge base 620 .
  • the system 100 initiates the process to compile a candidate list of BASG dependencies, such as, CPU usage, uptime, memory usage and network device usage.
  • the virtual machines that reside in the described ontological structures are then processed for the BASG candidate process, which may be initiated by the state and profiling engine 626 .
  • the state and profiling engine 626 sends a JMS message to the business logic to compile a list of candidate hosts, networks, and storage groups that are configured within the presently operating BASGs.
  • the request is contained within a profile EJB. This results in a database query being generated for usage data for the last 30 days from the database.
  • the business logic 624 sends a request to the RDF API knowledge base 620 for state data for hosts, network, and storage roll-up data for 24 hour roll-ups for the last 30 days.
  • the state data may contain warnings and/or errors that resulted in a “red” state for certain network nodes.
  • the usage and state information are sent back to the state and profiling engine 626 where they are used to rank and profile the BASGs. The ranking is based on the service tier threshold performance results (see FIG. 3B ).
  • the ranked BASGs are then assigned a profile by the state and profiling engine 626 .
  • the profiles are high availability, high capacity, high speed, moderate capacity, moderate speed, moderate availability, low capacity, low speed, and low availability.
  • the breakpoints for the profiles match the service tier thresholds previously assigned by the system 100 .
  • the state information for each BASG is considered when assigning a profile. For example, automatically assigning a “low” profile to any BASG that has been observed to have a warning and/or error (red indication) for exceeding a service tier threshold by more than 20% based on a 24-hour data roll-up for a the time period of 30 days.
  • Each of the virtual machines may be ranked in the virtual machine profile process.
  • the state and profiling engine 626 may use a standard matching algorithm to pair VMs with BASGs.
  • the ranked VMs are ranked and then sorted to be paired with the hosts that contain the matching BASG types (see FIG. 3B ).
  • the state and profiling engine 626 generates a report that details the recommended change in virtual machine assignments to BASGs. This list is formatted in XML to be utilized by an orchestration system and/or to be completed manually by a user. A determination may be made as to whether the change in allocation was successful. Regardless, the cycle of reassigning the VMs may be repeated every 30 days by default.
  • One example method of operation may include a method of assigning virtual machines operating in a network, as illustrated in FIG. 6 .
  • the method of FIG. 6 may be performed by processing logic that may comprise hardware (e.g., circuitry, dedicated logic, programmable logic, microcode, etc.), software (such as instructions run on a processing device), firmware, or a combination thereof.
  • the method is performed by a server (e.g., application server 101 of FIG. 1 ).
  • the method may include generating a list of the virtual machines currently operating in the network, at operation 601 .
  • the method may also include surveying the virtual machines to determine their current resource usage data, at operation 602 , and ranking the virtual machines based on their current resource usage data to indicate available resources of the virtual machines, at operation 603 .
  • the method may further include assigning the virtual machines to at least one business application service group (BASG) that requires the available resources of the virtual machines, at operation 604 .
  • BASG business application service group
  • FIG. 7 illustrates a diagrammatic representation of a machine in the exemplary form of a computer system 1000 within which a set of instructions, for causing the machine to perform any one or more of the methodologies discussed herein, may be executed.
  • the machine may be connected (e.g., networked) to other machines in a Local Area Network (LAN), an intranet, an extranet, or the Internet.
  • LAN Local Area Network
  • the machine may operate in the capacity of a server or a client machine in a client-server 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 server, 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.
  • PC personal computer
  • PDA Personal Digital Assistant
  • STB set-top box
  • WPA Personal Digital Assistant
  • a cellular telephone a web appliance
  • server e.g., a server
  • network router e.g., switch or bridge
  • the exemplary computer system 1000 includes a processing device 1002 , a main memory 1004 (e.g., read-only memory (ROM), flash memory, dynamic random access memory (DRAM) such as synchronous DRAM (SDRAM) or Rambus DRAM (RDRAM), etc.), a static memory 1006 (e.g., flash memory, static random access memory (SRAM), etc.), and a secondary memory 1016 (e.g., a data storage device), which communicate with each other via a bus 1008 .
  • main memory 1004 e.g., read-only memory (ROM), flash memory, dynamic random access memory (DRAM) such as synchronous DRAM (SDRAM) or Rambus DRAM (RDRAM), etc.
  • DRAM dynamic random access memory
  • SDRAM synchronous DRAM
  • RDRAM Rambus DRAM
  • static memory 1006 e.g., flash memory, static random access memory (SRAM), etc.
  • secondary memory 1016 e.g., a data storage device
  • Processing device 1002 represents one or more general-purpose processing devices such as a microprocessor, central processing unit, or the like. More particularly, the processing device 1002 may be a complex instruction set computing (CISC) microprocessor, reduced instruction set computing (RISC) microprocessor, very long instruction word (VLIW) microprocessor, processor implementing other instruction sets, or processors implementing a combination of instruction sets. Processing device 1002 may also be one or more special-purpose processing devices such as an application specific integrated circuit (ASIC), a field programmable gate array (FPGA), a digital signal processor (DSP), network processor, or the like. Processing device 1002 is configured to execute instructions 1026 for performing the operations and steps discussed herein.
  • CISC complex instruction set computing
  • RISC reduced instruction set computing
  • VLIW very long instruction word
  • ASIC application specific integrated circuit
  • FPGA field programmable gate array
  • DSP digital signal processor
  • network processor or the like.
  • the computer system 1000 may further include a network interface device 1022 .
  • the computer system 1000 also may include a video display unit 1010 (e.g., a liquid crystal display (LCD) or a cathode ray tube (CRT)), an alphanumeric input device 1012 (e.g., a keyboard), a cursor control device 1014 (e.g., a mouse), and a signal generation device 1020 (e.g., a speaker).
  • a video display unit 1010 e.g., a liquid crystal display (LCD) or a cathode ray tube (CRT)
  • an alphanumeric input device 1012 e.g., a keyboard
  • a cursor control device 1014 e.g., a mouse
  • a signal generation device 1020 e.g., a speaker
  • the secondary memory 1016 may include a machine-readable storage medium (or more specifically a computer-readable storage medium) 1024 on which is stored one or more sets of instructions 1026 embodying any one or more of the methodologies or functions described herein.
  • the instructions 1026 may also reside, completely or at least partially, within the main memory 1004 and/or within the processing device 1002 during execution thereof by the computer system 1000 , the main memory 1004 and the processing device 1002 also constituting machine-readable storage media.
  • the machine-readable storage medium 1024 may also be used to store software performing the operations discussed herein, and/or a software library containing methods that call this software. While the machine-readable storage medium 1024 is shown in an exemplary embodiment to be a single medium, the term “machine-readable storage 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 storage medium” shall also be taken to include any medium that is capable of storing or encoding 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. The term “machine-readable storage medium” shall accordingly be taken to include, but not be limited to, solid-state memories, and optical and magnetic media.
  • Embodiments of the invention also relate to an apparatus for performing the operations herein.
  • This apparatus may be specially constructed for the required purposes, or it may comprise a general purpose computer selectively activated or reconfigured by a computer program stored in the computer.
  • a computer program may be stored in a computer readable storage medium, such as, but not limited to, any type of disk including floppy disks, optical disks, CD-ROMs, and magnetic-optical disks, read-only memories (ROMs), random access memories (RAMs), EPROMs, EEPROMs, magnetic or optical cards, or any type of media suitable for storing electronic instructions.
  • a computer program may be embodied on a computer readable medium, such as a storage medium.
  • a computer program may reside in random access memory (“RAM”), flash memory, read-only memory (“ROM”), erasable programmable read-only memory (“EPROM”), electrically erasable programmable read-only memory (“EEPROM”), registers, hard disk, a removable disk, a compact disk read-only memory (“CD-ROM”), or any other form of storage medium known in the art.
  • An exemplary storage medium may be coupled to the processor such that the processor may read information from, and write information to, the storage medium.
  • the storage medium may be integral to the processor.
  • the processor and the storage medium may reside in an application specific integrated circuit (“ASIC”).
  • ASIC application specific integrated circuit
  • the processor and the storage medium may reside as discrete components.

Abstract

Virtual machine resources may be monitored for optimal allocation. One example method may include generating a list of virtual machines operating in a network and surveying the virtual machines to determine their current resource usage data. The method may also include ranking the virtual machines based on their current resource usage data to indicate available resources of the virtual machines, and assigning the virtual machines to at least one business application service group (BASG) that requires the available resources of the virtual machines.

Description

    CROSS REFERENCE TO RELATED APPLICATIONS
  • This application is related to co-pending applications: U.S. patent application Ser. No. 11/767,173, filed on Jun. 22, 2007, titled “Method and system for cloaked observation and remediation of software attacks”; U.S. patent application Ser. No. 11/867,456, filed on Oct. 4, 2007, titled “Method and system for collaboration involving enterprise nodes”; and U.S. patent application Ser. No. 12/626,872, filed on Nov. 27, 2009, titled “Network traffic analysis using a dynamically updating ontological network description.”
  • This application is further related to the Applicant's co-pending applications:
  • Attorney Docket No. Fortisphere 1: titled “System and method for identification of business process application service groups”, U.S. patent application Ser. No. 12/905,565.
  • Attorney Docket No. Fortisphere 2: titled “System and method for migration of network entities to a cloud infrastructure”, U.S. patent application Ser. No. 12/905,645.
  • Attorney Docket No. Fortisphere 3: titled “System and method for monitoring system performance changes based on configuration modification”, U.S. patent application Ser. No. 12/905,688.
  • Attorney Docket No. Fortisphere 4: titled “System and method for indicating the impact to a business application service group resulting from a change in state of a single business application service group node”, U.S. patent application Ser. No. 12/905,761.
  • Attorney Docket No. Fortisphere 5: titled “System and method for enterprise nodes that are contained within a public cloud to communicate with private enterprise infrastructure dependencies”, U.S. patent application Ser. No. 12/905,850.
  • Attorney Docket No. Fortisphere 6: titled “System and method for determination of the root cause of an overall failure of a business application service”, U.S. patent application Ser. No. 12/905,879.
  • Attorney Docket No. Fortisphere 7: titled “Automatic determination of required resource allocation of virtual machines”, U.S. patent application Ser. No. ______.
  • Attorney Docket No. Fortisphere 9: titled “Automatic enabling of business application service groups comprised of virtual machines”, U.S. patent application Ser. No. ______.
  • Attorney Docket No. Fortisphere 10: titled “xyy”, U.S. patent application Ser. No. ______.
  • Attorney Docket No. Fortisphere 11: titled “xyz”, U.S. patent application Ser. No. ______.
  • Attorney Docket No. Fortisphere 12: titled “xzx”, U.S. patent application Ser. No. ______.
  • The entire contents of each of the above mentioned applications are specifically incorporated herein by reference in their entireties.
  • TECHNICAL FIELD
  • Embodiments of the invention relate to analyzing network traffic analysis and, in particular, to performing automatic determining of service groups within a communications network.
  • BACKGROUND
  • Traditionally enterprises are comprised of various nodes that contribute to an overall business process. An enterprise may be thought of as a geographically dispersed network under the jurisdiction of one organization. It often includes several different types of networks and computer systems from different vendors.
  • These network nodes that are part of the enterprise may be comprised of both physical and virtual machines. Enterprise networks that include a plurality of virtual machines may require a physical host, which is required to allocate resources among the virtual machines.
  • Groups of network nodes included in the enterprise may form business process application service groups (BASGs). The “components” of these groups are comprised of virtual machines, hosts, storage devices and network devices. Each of these components may be dependent on one another. Generally, enterprise environments are not designed to pair virtual machines with hosts, storage devices, and network BASGs. As a result the virtual machines are not fully optimal and available resources may be underutilized.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • Features of the invention are more fully disclosed in the following detailed description of the invention, reference being had to the accompanying drawings described in detail below.
  • FIG. 1 illustrates an example embodiment of a system for creating and updating an ontological description of a network.
  • FIG. 2 illustrates a detail of ontological creation engine, according to an example embodiment.
  • FIG. 3A illustrates an example graphical user interface to view the amount of allocated resources used over time, according to example embodiments of the present invention.
  • FIG. 3B illustrates an example table of BASG profile information and related input data and corresponding threshold metric values for the virtual machine candidates, according to example embodiments of the present invention.
  • FIG. 4 illustrates a graphical user interface used to view the network hierarchy, according to example embodiments of the present invention.
  • FIG. 5 illustrates an example flow diagram, according to example embodiments of the present invention.
  • FIG. 6 illustrates another example flow diagram, according to example embodiments of the present invention.
  • FIG. 7 is a block diagram of an exemplary computer system that may perform one or more of the operations described herein, according to example embodiments of the present invention.
  • DETAILED DESCRIPTION
  • Example embodiments of the present invention may include a method of assigning virtual machines operating in a network. The method may include generating a list of the virtual machines currently operating in the network, surveying the virtual machines to determine their current resource usage data and ranking the virtual machines based on their current resource usage data to indicate available resources of the virtual machines. The method may also include assigning the virtual machines to at least one business application service group (BASG) that requires the available resources of the virtual machines.
  • Another example embodiment of the present invention may include an apparatus configured to assign virtual machines operating in a network. The apparatus may include a memory to store a list of the virtual machines currently operating in the network. The apparatus may also include a processor to generate the list of the virtual machines currently operating in the network, store the list in the memory, survey the virtual machines to determine their current resource usage data, rank the virtual machines based on their current resource usage data to indicate available resources of the virtual machines, and assign the virtual machines to at least one business application service group (BASG) that requires the available resources of the virtual machines.
  • It will be readily understood that the components of the present invention, as generally described and illustrated in the figures herein, may be arranged and designed in a wide variety of different configurations. Thus, the following detailed description of the embodiments of a method, apparatus, and system, as represented in the attached figures, is not intended to limit the scope of the invention as claimed, but is merely representative of selected embodiments of the invention.
  • The features, structures, or characteristics of the invention described throughout this specification may be combined in any suitable manner in one or more embodiments. For example, the usage of the phrases “example embodiments”, “some embodiments”, or other similar language, throughout this specification refers to the fact that a particular feature, structure, or characteristic described in connection with the embodiment may be included in at least one embodiment of the present invention. Thus, appearances of the phrases “example embodiments”, “in some embodiments”, “in other embodiments”, or other similar language, throughout this specification do not necessarily all refer to the same group of embodiments, and the described features, structures, or characteristics may be combined in any suitable manner in one or more embodiments.
  • In addition, while the term “message” has been used in the description of embodiments of the present invention, the invention may be applied to many types of network data, such as packet, frame, datagram, etc. For purposes of this invention, the term “message” also includes packet, frame, datagram, and any equivalents thereof. Furthermore, while certain types of messages and signaling are depicted in exemplary embodiments of the invention, the invention is not limited to a certain type of message, and the invention is not limited to a certain type of signaling.
  • Specific example embodiments of the present invention will now be described with reference to the accompanying drawings. This invention may, however, be embodied in many different forms, and should not be construed as limited to the embodiments set forth herein. Rather, these embodiments are provided so that this disclosure will be thorough and complete, and will fully convey the scope of the invention to those skilled in the art.
  • It will be understood that when an element is referred to as being “connected” or “coupled” to another element, it can be directly connected or coupled to the other element, or intervening elements may be present. Furthermore, “connected” or “coupled” as used herein may include wirelessly connected or coupled. It will be understood that although the terms “first” and “second” are used herein to describe various elements, these elements should not be limited by these terms.
  • FIG. 1 illustrates an example logic diagram of a system 100 configured to deploy data collection agents onto network nodes, according to example embodiments of the present invention. Referring to FIG. 1 an application server 101 interfaces with a web browser 102 and a local agent data collection network element 500. Certain operations may be performed by the system 100, such as, monitoring network connections instantiated at each network node, acquiring resulting data, automatically creating an ontological description of the network from the acquired data, dynamically updating the ontological description, etc.
  • According to an example embodiment, elements of system 100 may utilize the Java® software platform and Enterprise Java Bean® (EJB) architecture to provide certain functionality. These well-known terms may be used in the description that follows. Other software platforms and architectures, providing similar functionality, may be used without departing from the scope of the present invention.
  • System 100 may consist of an application server 101, which interacts across a network with a number of data collection agents 500. Application server 101, may be an element of an administrative console (AC) that also provides a suite of network management tools. A system administrator may perform network traffic analysis and/or other network management tasks by accessing application server 101 through a web browser 102. Application server 101 may include an EJB module 612, an ontological description creation engine 613, and a web application 111. Web browser 102 may include a rendering engine 102B and a knowledge browser 102A.
  • In operation, data collection agent(s) 500 may be deployed onto network nodes including physical and/or virtual machines in an enterprise information technology (IT) infrastructure environment. After such deployment, application server 101 receives messages from data collection agents 500. These messages may include data representing, for example, state and relationship information about the network nodes, configuration information related to the IT infrastructure, performance/utilization data and network communication. Thresholds are assigned to a component and/or can also be assigned to an entire business application service group (BASG). A host may provide CPU usage as a resource allocated to a virtual machine, the CPU operational usage performance is an example metric. The virtual machine and host machine are both examples of components.
  • The received messages may be initially handled by EJB module 612. For example, message driven EJB 623 may initially inspect a received message. A received message relating to network traffic or node status may be forwarded by message driven EJB 623 to the business logic EJB 624. Business logic EJB 624 may call network traffic analysis engine 625 for messages relating to network traffic. Alternately, “infrastructure messages” (i.e., those messages relating to node status) may be forwarded directly to the state and profiling engine 626.
  • Messages forwarded to the state and profiling engine 626 may undergo sorting and processing. The state and profiling engine 626, for example, may identify the entities within the IT infrastructure as well as their dependency on one another, based on messages received from the platform. In addition, state and profiling engine 626 may perform further processing to determine the state of one or more entities. State may be based on a threshold that has been defined, for example, by the system administrator. The threshold may be based on a metric that either exceeds or underperforms in a specific area of interest of the system administrator. An example threshold may be set for a server operating in the enterprise network that is exceeding a specified CPU utilization percentage, a disk utilization percentage and/or a memory utilization percentage.
  • A data output from state and profiling engine 626 may be sent to ontological description creation engine 613. Initially, the data may be handled by a resource description framework (RDF) application programming interface (API) knowledge base 620, where the data is categorized and stored utilizing a predefined entity relationship determined by ontology web language (OWL) API or ontology model 621.
  • Messages handled by the network traffic analysis engine 625 may include source-to-destination data, qualified by a communicating application within the operating system of the originating node, as well as frequency of communication information. This received data is analyzed by processing the number and type of connections to determine if an ontological “communicates_with” relationship exists. A determination may be made by tracking the number of connections of a specific application over a period of time. The period of time may be preselected, for example, by the system administrator.
  • Data output from network traffic analysis engine 625 may be sent to ontological description creation engine 613. Initially, the data may be handled by the RDF API knowledge base 620 where the data is categorized and stored utilizing a predefined entity relationship, determined by OWL API ontology model 621. For example, OWL API ontology model 621 may define what entity classes exist, their possible relationship to each other, and their possible state.
  • FIG. 2 illustrates a detailed diagram of ontological description creation engine 613, according to example embodiments of the present invention. Referring to FIG. 2, as data is received by RDF API knowledge base 620, logic in the RDF API knowledge base 620 may map the incoming data to the appropriate ontological classes and relationships defined by OWL ontology API model 621. Once the correct classes and relationships are selected, the entity and relationship information may be entered into RDF API knowledge base 620. The knowledge base may also be forwarded to a SPARQL database or query engine 622 for later inference processing by inference engine 633. Inference engine 633 may determine inferred relationships based on the ontology model contained in OWL ontology API model 621.
  • The model and structure the system uses to create and update the knowledge base is contained within a web ontology language (OWL) file present on the application server 101. OWL is a family of knowledge representation languages for authoring ontologies which are a formal representation of the knowledge by a set of concepts within a domain and the relationships between those concepts. Ontologies are used to represent the properties of a domain, and may be used to describe the domain. The ontology provides the direct and indirect dependency information that the (SPARQL) query engine 622 requires in order to infer the impact a change in “state” will have on the rest of a service group or BASG.
  • In an enterprise network, a business application will typically include a primary application with one or more executables that execute on one or more nodes of the network. These nodes may have direct and indirect dependencies on other nodes of the network. The business application may be described by a network ontology. When an alert state occurs for the business application, the components of the business application ontology may be analyzed to determine what adjustments are required to achieve a steady state based on assigned thresholds. The root cause may be a direct or indirect root cause, which may then be reported to the system administrator.
  • According to an example embodiment, a visualization of a current network state and/or communication activity may be provided to an administrator. The system administrator may be provided with a visual rendering (e.g., on a computer monitor) of the knowledge base. The visualization may be filtered to any selected entity of interest. For example, referring again to FIG. 1, the system administrator or other user may use a web browser 102 to request rendering of data via web application 111 from controllers 627.
  • Controllers 627 may pass along any filtering information such as a specific Host ID. Next, business logic EJB 624 may be called by the controllers. Business logic EJB 624 may query RDF API knowledge base 620 for requested data. The requested data may be returned through controllers 627 to the web browser. The requested data may then be converted into a directed graph chart by a rendering engine.
  • Example embodiments of the present invention may provide the ability to automatically determine allocation adjustments that may be required for virtual machine performance, and monitoring the service tier thresholds assigned to a specified virtual machine. Thresholds are directly related to a node “state”. The state may be defined as an indicator to the system and the user of a business application service, such as, whether, the business application service meets a specified threshold requirement. The process to determine the state of an individual element may be based on a threshold that has been defined, for example, by the system administrator. The threshold may include a metric that either exceeds or underperforms in a specific area of interest of the system administrator. An example would be a server in a network that is exceeding a specified CPU utilization percentage.
  • Example embodiments of the present invention may provide automatically detecting when a virtual machine's baseline of performance requires an allocation change from the virtual machine's host. Determining the percentage of increase or decrease in CPU usage, memory usage, storage usage, and network usage may be required in order to maintain a baseline operating in a normal range.
  • The system 100 may monitor for a steady state of a virtual machine by tracking service tier thresholds identified as normal. The system will provide the virtual machine's host with the changes in performance allocations needed to operate within a normal range to continue or achieve a normal range. The adjustment is expressed in terms of a percentage increase or decrease from the present allocation of resources assigned to it by its physical host.
  • The following terminology is used only to distinguish one element from another element. Thus, for example, a first user terminal could be termed a second user terminal, and similarly, a second user terminal may be termed a first user terminal without departing from the teachings of the present invention. As used herein, the term “and/or” includes any and all combinations of one or more of the associated listed items. The symbol “/” may also be used as a shorthand notation for “and/or”.
  • Networks including computer entities, physical and/or virtual machines operating on network nodes, etc., may be advantageously described via an ontology that describes the operational usage and current state of the entities rather than being based on a fixed IT infrastructure architecture. The ontological description may be automatically and dynamically updated based on data acquired from data collection agents deployed to the nodes of the network. The data collection agents observe communicative relationships based on connections between nodes in operational use, while annotating a class state. Using the ontological description, a network analyst or system operator may be provided with an improved ability to analyze network traffic.
  • Data relating to actual connections may be acquired automatically in near real-time. For example, an actual connection may be monitored in an interrupt-driven way while collecting information regarding an application that made the connection. Moreover a “volume for the connections” may be derived. A software-based data collection agent may be received by a computing device at a node within a communications network. The agent may be distributed to one or more nodes from a central node via the network.
  • Once the software-based data collection agent is received, it may be inserted in an operating system of the receiving node. Advantageously, the agent may be inserted in the kernel of the operating system or in a user space (i.e., an area in virtual memory of a computer that contains user applications that execute at the application layer). The installation may be performed such that it is transparent or undetectable by a user of the node. The installed data collection agent may monitor data packet traffic between an adaptive driver layer and a protocol layer and report results of the monitoring to the central node.
  • In one example, the data collection agent 500 may have an interface to an operating system's network stack and may periodically determine what applications are using the network stack. As a result, the data collection agent may track information regarding a network connection, the connection duration, and any applications and systems involved in the connection. Moreover, the data collection agent 500 may normalize the foregoing information and report it to an administration console so that different operating systems may be correlated by the administration console.
  • As a further example, the data collection agent 500 may include a network filter inserted into the network stack to determine exactly when a connection is made between entities. The filter component of the data collection agent may be inserted at one or more layers of the OSI model. For example, a data collection agent 500 may have a filter interface at the transport layer and/or a filter interface at the network layer. The data collection agent 500 may track information regarding a network connection, the connection duration, and any applications and systems involved in the connection. Moreover, the data collection agent may normalize the foregoing information and report it to the administration console so that different operating systems may be correlated by the administration console.
  • As yet a further example, the data collection agent 500 described in the preceding paragraphs may also include a packet filter inserted into the network stack to track connection data. For example, a data collection agent 500 may have a filter interface at the data link layer. Then, the data collection agent 500 may correlate and normalize (if required) data from the network filter and the packet filter to track information regarding the network connection, the connection duration, any applications and systems involved in the connection, connection status and connection resource usage information. Moreover, the data collection agent 500 may normalize the foregoing information and report it to the administration console so that different operating systems may be correlated by the administration console.
  • Referring again to FIG. 1, an illustrative system 100 for deploying data collection agents onto network nodes, monitoring network connections instantiated at each network node, acquiring resulting data, automatically creating an ontological description of the network from the acquired data, and dynamically updating the ontological description will be described. The system 100 may further be used for monitoring configuration drifts within an enterprise network as will be described in more detail below. In an example embodiment, elements of system 100 utilize the Java software platform and Enterprise Java Bean (EJB) architecture to provide certain functionality, and these well-known terms may be used in the description that follows.
  • According to example embodiments of the present invention, the process to automatically determine a performance allocation may begin by monitoring those virtual machines that have sustained a service tier threshold in either a critical low and/or a critical high level for more than 24 hours. Such an observation may be observed by the virtual machine agent. The SQARQL query engine 622 simultaneously initiates a query for current performance threshold data stored in a database.
  • The components' states may be determined since they have thresholds that include at least one of achieved, overachieved, and/or underachieved. Nodes, executables and the business application service groups (BASGs) may also incorporate status and alerts from infrastructure providers. The executables may have a state that relates to the “communicates_with” relationship. For example, if an executable such as sqlservr.exe no longer communicates with node X, it may be designated critical high and indicated on a user interface as red or as a warning. This example may be true of a node that represents a “communicates_with” relationship as well as a primary application represented as a node.
  • The state and profiling engine 626 may set the state of the business application service group (BASG) using the agent data and system information. When any component of the BASG has achieved a “High Warning” state, the user may view the component as red (indicating a high warning) as well as the BASG itself being displayed in red on a graphical user interface. Various other visual indicators (e.g., shapes, sizes, shades, etc.) may be used to illustrate different operating performance levels.
  • The process to determine the state of an individual element may be based on a threshold that has been defined, for example, by the system administrator. The threshold may include a metric that either exceeds or underperforms in a specific area of interest to the system administrator. An example would be where a server in a network is exceeding a specified CPU utilization percentage.
  • Example embodiments of the present invention may automatically determine the optimum pairing of virtual machines in a business process application service group (BASG) to maximize performance as measured by a service tier threshold system. Examples may include automatically analyzing the baseline of direct and indirect connections based on network interactivity of the applications that are utilized to perform a process.
  • A BASG is comprised of one or more nodes operating on the enterprise network. The basis for an automatic base-lining procedure may be in the ontological structure of the categorized BASG. The resulting data file may contain a structure that includes classes, object properties, and data values. The system creates a profile type for each selected BASG host, storage device, and other network dependent components/elements. This profile may include specific attributes that are used to pair virtual machines with BASGs providing the virtual machine to execute optimally.
  • Example operations may provide identifying specific virtual machines to pair with a specific business BASG. One ore more virtual machines may be paired with one or more BASGs. The system may determine which BASGs are best suited for a pairing based on parameters that include high availability, high capacity, high speed, moderate capacity, moderate speed, moderate availability, low capacity, low speed, and low availability. These are considered by the system to be the BASG types. The virtual machines that require these attributes are then paired to these BASGS.
  • Initially, the system 100 may analyze each of the BASGs performance data to determine if any of the BASGs would benefit from a newly added virtual machine pairing. This analysis may be performed by processing the aggregate service tier thresholds of the host member(s) of the BASG. For example, by processing the state information of both the storage and network BASG dependencies, the need for additional virtual machines may be apparent based on the needs and requirements of the BASG. The storage and network state information may be factored with the host performance threshold data and state information to determine a profile of the BASG.
  • The BASG profile may include categories, which may include but are not limited to high availability, high capacity, high speed, moderate capacity, moderate speed, moderate availability, low capacity, low speed, and low availability. FIG. 3B illustrates an example table of a BASG profile and its corresponding threshold data input and service tier threshold metric information required for a virtual machine candidate selection process. Depending on the metrics that are measured, a virtual machine that is operating less than or above the specified metric ranges included in FIG. 3B, may not be considered a candidate for pairing with a particular BASG. The service tier thresholds may be based on the requirements of a particular BASG and its current operating baseline.
  • The system 100 may analyze the virtual machines to determine the optimal combination of host applications, storage required and network performance by analyzing the service tier threshold performance data acquired. Each virtual machine is assigned a profile requirement, such as, high availability, high capacity, high speed, moderate capacity, moderate speed, moderate availability, low capacity, low speed, and low availability. The system 100 pairs the virtual machine with at least one host, network, and storage group that has availability and, which may be assigned to a BASG. Or, alternatively, the BASG can produce availability by migrating one or more less optimally paired virtual machine elsewhere.
  • The system 100 may also provide a work order that can be processed by an orchestration system, or, individual, who is responsible for executing the changes. The system 100 routinely (as defined through the user interface) monitors the networking environment to maintain optimum virtual machine pairings with host, storage, and speed groups that include one or more BASGs.
  • FIG. 3A illustrates an example graphical user interface (GUI) used to demonstrate resource allocation and usage over time, according to example embodiments of the present invention. Referring to FIG. 3A, a GUI for a system administrator may include a graph of percentage of capacity vs. time (weeks). For example, resources are included in the graph, including, CPU allocation 301, memory allocation 302, memory usage 303 and CPU usage 304. The performance details are illustrated in a table that includes the current base-line information, last week, last four weeks and last three months, and days remaining.
  • In FIG. 3A, a physical capacity summary is also provided for easy summarization of the total CPU capacity, memory capacity and disk capacity. This base-line summary provides a system administrator with a snapshot of operating conditions of the BASGs, virtual machines and overall available resources. This provides the system administrator with the information necessary to determine if the BASGs, virtual machines and available resources are being utilized efficiently throughout the network.
  • FIG. 4 illustrates another example GUI according to example embodiments of the present invention. Referring to FIG. 4, a hierarchical logic flow diagram 400 includes a host device 401, which may be a SQL team of individuals assigned to a particular BASG, and two different virtual machines 402 and 403. The various network resources 404-411 are illustrated as being assigned to at least one virtual machine.
  • The various network resources 404-411 are illustrated as being assigned to at least one virtual machine. Resource icon 404 represents a logical network in the “enterprise” for virtual machine 402. It is associated with a device at the virtual infrastructure management level (i.e., ESX Server), which is a name for the network as it is known to the enterprise for our purposes.
  • Resource icon 405 is the physical host (hardware) for the virtual machine 402 along with other virtual machines, and is referred to as the hypervisor. Resource icon 406 is the network for virtual machine 402. It is the same as 404, a logical network in the “Enterprise”, and is associated with a device at the virtual infrastructure management level (i.e., ESX Server), which is a name for the network as it is known to the enterprise for our purposes.
  • Resource icon 407 is a datastore for virtual machine 402. It represents a physical allocation of disk storage, and is associated with a hard disk storage device at the virtual infrastructure management level. Resource icon 408 is the “User” assigned to both virtual machines 402 and 403. It has been defined and assigned by this virtualization management software. Resource icon 409 is the host for virtual machine 403. The host is a physical host (hardware) that the virtual machine is running on, along with other virtual machines, and may be referred to as the hypervisor. Resource icon 410 is the primary application that is being executed on the virtual machine 403. Lastly, 411 is the datastore for the virtual machine 403. These resource icons may be dragged and dropped to reassign resources to the virtual machines, and, in turn, modify the allocations of the BASGS.
  • According to example embodiments of the present invention, the system 100 will automatically determine the optimum pairing of virtual machines with BASGs to maximize performance as measured by a service tier threshold monitoring system. In operation, upon initiation by the user through the web browser interface 102, the application server 101 may receive a message to survey the virtual machines for their respective CPU and memory usage over the past 30 days. The survey may be performed by the web application server 101 sending a request to the state and profiling engine 626 to compile the usage data from the database.
  • The state and profiling engine 626 may transmit a JMS message to the business logic 624 that compiles the database query. The business logic 624 generates an EJB based query that includes a request for CPU and memory usage data for the last 30 days. A ranking may be performed by the SPARQL query engine 622 initiating a query. An Example of the data returned by the database is described with reference to FIG. 1. This data is used to rank the virtual machines. The ranking is averaged over the range of virtual machines returned. The ranked virtual machines are then assigned a profile by the state and profiling engine 626. The profiles may include high availability, high capacity, high speed, moderate capacity, moderate speed, moderate availability, low capacity, low speed, and low availability.
  • The breakpoints for the profiles may match the predefine service tier thresholds assigned by the system. Once all of the virtual machines have been assigned a profile based on their usage, the state and profiling engine sends this list via a profile EJB to the RDF API knowledge base 620. Once completed the system 100 initiates the process to compile a candidate list of BASG dependencies. The virtual machines that reside in the described ontological structures are not considered for the candidate process. The BASG candidate process is initiated by the state and profiling engine 626.
  • The state and profiling engine 626 sends a JMS request message to the business logic 624 to compile a list of candidate hosts, networks, and storage groups that are configured within the BASGs. The request is included within a profile EJB. This results in a database query for usage data for the last 30 days from the database. The business logic sends a request to the RDF API knowledge base 620 for state data for host, network, and storage roll-up data based on 24 hour roll-ups for the last 30 days.
  • The state data may contain warning or errors that resulted in a “red” state for the given nodes. The usage and state information are sent back to the state and profiling engine 626, where they are used to rank and profile the BASGs. The ranked BASGs are then assigned a profile by the state and profiling engine. The BASG profiles may include high availability, high capacity, high speed, moderate capacity, moderate speed, moderate availability, low capacity, low speed, and low availability. The breakpoints for the profiles may match the service tier thresholds previously assigned by the system.
  • The state information for each BASG may be used to assign a profile by automatically assigning a “low” profile to any BASG that is experiencing a warning or error (red indication). The error may be based on a 20% margin of exceeding the predefined resource threshold, and may be based on a 24 hour data roll-up for a 30-day period. No virtual machines are used to rank a BASG. The virtual machine itself is ranked in the virtual machine profile process mentioned above. Once all BASGs have been profiled, the state and profiling engine 626 may use a standard matching algorithm to pair the virtual machines with BASGs. The state and profiling engine 626 generates a report that details the recommended change in virtual machine assignment to BASGs. This list may be formatted in XML to be utilized by an orchestration system to complete the changes or to be read by a user for manual adjustments.
  • The states of the individual business application service components may be aggregated to calculate an overall state for the BASG. Any support nodes within the BASG ontology that have achieved a high warning may be labeled under the BASG as having a high warning. If any one node with a “communicates_with” relationship achieves a high warning status it may be identified as having a high warning for its associated BASG. High errors may be identified in a similar manner. For example, in order for a node to achieve these states, the states must have been observed and processed by the state and profiling engine 626 three times within one hour. As a result, spurious errors and random faults will not lead to warnings being generated for the overall business application process.
  • One example method for processing state information of elements of a business process ontology and more specifically for a BASG that is in an error state will now be described with reference to FIG. 5. The method of FIG. 5 may be performed by processing logic that may comprise hardware (e.g., circuitry, dedicated logic, programmable logic, microcode, etc.), software (such as instructions run on a processing device), firmware, or a combination thereof. In one embodiment, the method is performed by a server (e.g., application server 101 of FIG. 1).
  • At operation 501, a query is sent to the RDF knowledgebase 620 that identifies the BASG that is currently in an error state. The RDF knowledge base 620 returns the list of components of the BASG (e.g., hardware nodes, virtual nodes, executables, processes, primary applications, etc) and their state.
  • It should be noted that the primary application of the BASG is considered by the RDF knowledge base to be a “node”. Any of these components of the BASG may have independent thresholds assigned by the system administrator. Examples of components may include virtual machines, host machines, storage devices, network devices. Examples of resources that are allocated may include memory, CPU, storage disk space, network adapters. Examples of metrics may include a CPU utilization of 1024 Ghz, a memory utilization of 8 gigabytes, a network adapter operating at 100 Mbps, etc.
  • At operation 502, a filter is applied to determine those components that may have contributed to the “high warning” threshold that was exceeded and which triggered an alarm. In one example embodiment, the filter omits any individual component that has not exceeded a “high warning” threshold individually from the process. This may reduce the chances of false alarms occurring due to random instances of a predefined threshold being exceeded.
  • At operation 503, the process continues by inspecting each of the filtered components to determine a root cause. The inspection process looks up performance data previously reported by the agents deployed to the nodes. The inspection process may yield all of the component's relevant data for determining a root cause. In one example, the data used for this determination is service tier data, such as, CPU, memory, disk, and network operation threshold roll-up data (last 30 days), though other relevant data may also be used.
  • The root cause process may also use virtualization infrastructure alarms and network status updates. These are available to the system for host, virtual machines, disks, and network devices, and may be sent in messages from a proxy agent. The proxy agent may contain an instruction for translating virtual infrastructure messages to a format that the state and profile engine 626 can process. If, for example, the proxy agent receives a message from the virtual infrastructure stating a disk has achieved full capacity and has an error level of 3, the proxy agent will modify the received message with a translation on the “level of 3” to “High Error.” This is then sent to the message driven bean factory 623, where an EJB is created with the contents received from the proxy agent. The business logic then routes the new state EJB to the state and profiling engine 626. This data is provided to the user as support evidence for the root cause conclusion.
  • The SPARQL query engine 622 determines the state of the primary applications and the contributing executables that make up the primary application by requesting the ontology for the business application service. The ontology is analyzed for breaks in communication with nodes, as described in the Applicant's co-pending applications referenced above.
  • The SPARQL query engine 622 will send a request to the agent to send back the performance statistics of the executables that make up the primary application of the business application service. This will provide the user with the real-time performance statistics of the executables to provide support for a conclusion that a root cause of failure is due to the failure of the primary application support nodes, at operation 504. The result of the conclusion may automatically trigger a recommendation to perform an increase and/or decrease in the present resource allocation of resources provided by a virtual machine(s), at operation 505. For example, CPU resources and disk space may be reallocated from among the network resources by the system administrator as a result or receiving the recommendation. Or, alternatively, certain reallocation measures may be performed automatically.
  • System 100 may comprise an application server 101, which interacts across a network with a number of data collection agents 500 deployed in various nodes of the network. Advantageously, application server 101, may be an element of an administrative console (AC) that also provides a suite of network management tools. A system administrator may perform network traffic analysis and/or other network management tasks by accessing application server 101 by way of web browser 102. Application server 101 may comprise an EJB module 612, an ontological description creation engine 613, and a web application 111.
  • Data collection agents 500, as described hereinabove, may be deployed onto network nodes including physical and/or virtual machines in an enterprise IT infrastructure environment. After such deployment, application server 101 receives messages from data collection agents 500. These messages may include data representing, for example, state and relationship information about the network nodes, configuration information related to the IT infrastructure, performance/utilization data and network communication.
  • The received messages may be initially handled by EJB module 612. For example, message driven EJB module 623 may initially inspect a received message. A received message relating to network traffic or node status may be forwarded by message driven EJB 623 to the business logic EJB 624. Business logic EJB 624 may call network traffic analysis engine 625 for messages relating to network traffic. Alternatively, “infrastructure messages” (i.e., those relating to node status) may be forwarded directly to the state and profiling engine 626.
  • Messages forwarded to the state and profiling engine 626 may then undergo sorting and processing. The state and profiling engine 626, for example, may identify the entities within the IT infrastructure as well as their dependency on one another, based on messages received from the platform. In addition, state and profiling engine 626 may perform further processing to determine the state of one or more entities. The states may be based on a threshold that has been defined, for example, by the system administrator. The threshold may be based on a metric that either exceeds or underperforms in a specific area of interest to the system administrator. An example would be a server operating in a network that is exceeding a specified CPU utilization percentage. The threshold may be set to 80% CPU utilization and if the server is operating at 81%, the threshold is being exceeded.
  • Example embodiments for determining a required resource allocation of a virtual machine based on thresholds are discussed below. The web application server business logic creates a message request to provide the necessary changes in virtual machine performance allocation variables to create a condition of no critical low and/or no critical high conditions for the next 24 hours. If the recommended change is not successful, the cycle repeats by incrementing the 24 hour period with no critical low and/or no critical high warning by the service tier threshold system. Another 24 hour monitoring period may then begin.
  • A recommendation of a change in a variable by a factor of 10% (increase or reduction) may be a general modification used to satisfy a threshold condition that has been exceeded/underperformed. The 10% factor modification may be used until the virtual machine exceeds a performance request, which results in the web browser 102 initiating a message to the web application 111 and controllers 627 of the virtual machine. This modification, in turn, creates a message driven entity bean that contains the request, which is transferred to a rules engine. The rules engine sends a request to gather a historical period of information to the web browser 102. Such historical information may be for a period of 1 to 90 days. The rules engine (not shown) may be part of creation engine 613 and/or EJBs 612.
  • The rules engine message is sent to a database (not shown) to gather the data tables requested. The database sends the data back to the rules engine. The rules engine factors the data resulting in a recommendation to increase or decrease the allocation for each of the performance threshold criteria, which may include, for example, CPU utilization, memory utilization, data storage utilization, and network resource utilization.
  • The resource modification recommendation is created by the creation engine, which may also be referred to as a rules engine 613. The rules engine 613 may perform averaging the actual threshold observed by the service tier threshold integer (0-100 scale). The average is taken from metrics observed while the virtual machine is observed in its normal operating range. If no normal range is observed, than the rules engine will increment the recommended change by increasing or decreasing the allocated resource(s) by 20% until a normal range is observed over a period of 24 hours. According to one example, the recommended increase or decrease is only 10% for a period following 24 hours if the data gathered does contain “normal” range input data.
  • A proxy agent (not shown) may be part of the local agent that is used to collect data. In operation, the proxy agent collects data from the virtual infrastructure management provider. The user will utilize the default thresholds or adjust them as deemed necessary. Thresholds are used by the state and profiling engine 626 for tracking the “state” of the nodes that make up the components for a business application process. The inventory in the database may be updated by the proxy agent with a list of virtual machines, storage, hosts, and network devices.
  • The agent may be deployed via the physical hosts connected directly to the virtual machine's O/S. The state and profiling engine 626 assigns the “state” of the various network components and receives additional input from the proxy agent to factor into the “state” (e.g., alarms, network, and “communicates_with” relationship status, etc.) and updates the RDF API knowledge base 620 ontologies to reflect the assignments. The agent tracks executable applications to see what other nodes are communicating with the virtual machines (VMs) in the enterprise.
  • The network traffic analysis engine 625 determines which executable applications and services are communicating with other nodes that constitute a “communicates_with relationship.” A determination may be made as to whether any pairs of nodes have a “communicates_with relationship.” Upon the assignment of a “communicates_with” relationship to the ontology of a node and its direct and indirect relationships, the state and profiling engine 626 assigns the group of nodes as a “service group.”
  • The RDF API knowledge base 620 stores an ontology for each individual node. The model and structure the system uses to create and update the knowledge base is contained within the ontology web language (OWL) file present on the application server 101. The state and profiling engine 626 tracks the “state” continually of the components and receives additional input from the proxy agent to factor into the “state” (e.g., alarms, network, and “Communication_with” relationship status).
  • The user may identify a “service group” of network nodes as a business application service group (BASG) by selecting a name for the group of nodes and the executables that are the basis for the “communicates_with” relationship. The user may also add nodes that the system did not auto-detect as a component of the service group. Those added nodes will be recorded and stored in the ontology model 621.
  • A determination may then be made as to whether the user has assigned additional nodes and/or names to the service group. The ontology itself provides the direct and indirect dependency information of the nodes that the SPARQL query engine 622 requires to infer the impact a change in “state” will have on the rest of the service group. For instance, if a storage device's (component) state is changed to “RED” because it is almost full (e.g., only two gigabytes left of a 1500 gigabyte memory) then this may cause the physical host to start the paging memory, which will effect the performance of any and all virtual machines running on that physical host.
  • The SPARQL query engine 622 parses the service group ontology for the components that have a “communicates_with” relationship, which forms the basis for a primary application. The state and profiling engine 626 tracks the “state” of the BASG by requesting the current “state” from the RDF knowledge base 620 and updating the ontology when any new messages are received from the business logic EJB factory 624. The ontology itself provides the direct and indirect dependency information that the SPARQL query engine 622 requires to infer the impact a change in “state” will have on the rest of the BASG. SPARQL query engine 622 parses the BASG ontology for the components that have a “communicates_with” relationship, which forms the basis for a primary application.
  • For example, SPARQL query engine 622 provides a list of candidate BASG members for base-lining and adjusting what may be needed to achieve “normal” acceptable performance levels. By parsing the BASG ontology for primary applications that have “communicates_with” relationships with “virtual machines” that have operated in a “normal” level of threshold for 3 consecutive business cycles, a list of qualifying components may be produced. SPARQL query engine 622 may parse the BASG ontology to determine the components that have a “communicates_with” relationship. Such components may be used to form the basis for a primary application. SPARQL query engine 622 may generate a list of virtual machine and BASG member pairing recommendations.
  • Web application server 101 may receive the message to survey the virtual machines for their CPU and/or memory usage over the past 30 days. Web application server 101 may send a request to the state and profiling engine 626 to compile the usage data from the database. The state and profiling engine 626 sends a message to the business logic 624 that compiles the database query. The business logic 624 generates an entity Java Bean (EJB) based query that includes a request for CPU and memory usage data for the last 30 days.
  • A ranking may be performed by the SPARQL query engine 622. The ranking may be performed by sorting a list of the observed performance metrics averaged over time. The best candidate may be generated as being available on top of the generated list. The user may drag and drop the best candidate virtual machine to create a pair with the BASG. As a result of the pairing operation, the next available candidate becomes the top candidate.
  • The performance data is averaged over the total number of virtual machines (VMs) returned to create the ranking list. The ranked virtual machines are then assigned a profile by the state and profiling engine 626. The profiles may include high availability, high capacity, high speed, moderate capacity, moderate speed, moderate availability, low capacity, low speed, and low availability. The VMs that are operating closest to within the thresholds are ranked in order with the closest matched VM placed on top or in first position in the table of FIG. 3B. The breakpoints may be established as the points that the threshold metrics dictate the profile characteristics.
  • Once all of the virtual machines have been assigned a profile based on their usage, the state and profiling engine 626 sends this list via a profile EJB to the RDF API knowledge base 620. Once completed, the system 100 initiates the process to compile a candidate list of BASG dependencies, such as, CPU usage, uptime, memory usage and network device usage. The virtual machines that reside in the described ontological structures are then processed for the BASG candidate process, which may be initiated by the state and profiling engine 626.
  • The state and profiling engine 626 sends a JMS message to the business logic to compile a list of candidate hosts, networks, and storage groups that are configured within the presently operating BASGs. The request is contained within a profile EJB. This results in a database query being generated for usage data for the last 30 days from the database. The business logic 624 sends a request to the RDF API knowledge base 620 for state data for hosts, network, and storage roll-up data for 24 hour roll-ups for the last 30 days. The state data may contain warnings and/or errors that resulted in a “red” state for certain network nodes. The usage and state information are sent back to the state and profiling engine 626 where they are used to rank and profile the BASGs. The ranking is based on the service tier threshold performance results (see FIG. 3B).
  • The ranked BASGs are then assigned a profile by the state and profiling engine 626. The profiles are high availability, high capacity, high speed, moderate capacity, moderate speed, moderate availability, low capacity, low speed, and low availability. The breakpoints for the profiles match the service tier thresholds previously assigned by the system 100. The state information for each BASG is considered when assigning a profile. For example, automatically assigning a “low” profile to any BASG that has been observed to have a warning and/or error (red indication) for exceeding a service tier threshold by more than 20% based on a 24-hour data roll-up for a the time period of 30 days.
  • Each of the virtual machines (VMs) may be ranked in the virtual machine profile process. Once all BASGs have been profiled, the state and profiling engine 626 may use a standard matching algorithm to pair VMs with BASGs. The ranked VMs are ranked and then sorted to be paired with the hosts that contain the matching BASG types (see FIG. 3B).
  • The state and profiling engine 626 generates a report that details the recommended change in virtual machine assignments to BASGs. This list is formatted in XML to be utilized by an orchestration system and/or to be completed manually by a user. A determination may be made as to whether the change in allocation was successful. Regardless, the cycle of reassigning the VMs may be repeated every 30 days by default.
  • One example method of operation may include a method of assigning virtual machines operating in a network, as illustrated in FIG. 6. The method of FIG. 6 may be performed by processing logic that may comprise hardware (e.g., circuitry, dedicated logic, programmable logic, microcode, etc.), software (such as instructions run on a processing device), firmware, or a combination thereof. In one embodiment, the method is performed by a server (e.g., application server 101 of FIG. 1).
  • The method may include generating a list of the virtual machines currently operating in the network, at operation 601. The method may also include surveying the virtual machines to determine their current resource usage data, at operation 602, and ranking the virtual machines based on their current resource usage data to indicate available resources of the virtual machines, at operation 603. The method may further include assigning the virtual machines to at least one business application service group (BASG) that requires the available resources of the virtual machines, at operation 604.
  • FIG. 7 illustrates a diagrammatic representation of a machine in the exemplary form of a computer system 1000 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 may be connected (e.g., networked) to other machines in a Local Area Network (LAN), an intranet, an extranet, or the Internet. The machine may operate in the capacity of a server or a client machine in a client-server 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 server, 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 (e.g., computers) that individually or jointly execute a set (or multiple sets) of instructions to perform any one or more of the methodologies discussed herein.
  • The exemplary computer system 1000 includes a processing device 1002, a main memory 1004 (e.g., read-only memory (ROM), flash memory, dynamic random access memory (DRAM) such as synchronous DRAM (SDRAM) or Rambus DRAM (RDRAM), etc.), a static memory 1006 (e.g., flash memory, static random access memory (SRAM), etc.), and a secondary memory 1016 (e.g., a data storage device), which communicate with each other via a bus 1008.
  • Processing device 1002 represents one or more general-purpose processing devices such as a microprocessor, central processing unit, or the like. More particularly, the processing device 1002 may be a complex instruction set computing (CISC) microprocessor, reduced instruction set computing (RISC) microprocessor, very long instruction word (VLIW) microprocessor, processor implementing other instruction sets, or processors implementing a combination of instruction sets. Processing device 1002 may also be one or more special-purpose processing devices such as an application specific integrated circuit (ASIC), a field programmable gate array (FPGA), a digital signal processor (DSP), network processor, or the like. Processing device 1002 is configured to execute instructions 1026 for performing the operations and steps discussed herein.
  • The computer system 1000 may further include a network interface device 1022. The computer system 1000 also may include a video display unit 1010 (e.g., a liquid crystal display (LCD) or a cathode ray tube (CRT)), an alphanumeric input device 1012 (e.g., a keyboard), a cursor control device 1014 (e.g., a mouse), and a signal generation device 1020 (e.g., a speaker).
  • The secondary memory 1016 may include a machine-readable storage medium (or more specifically a computer-readable storage medium) 1024 on which is stored one or more sets of instructions 1026 embodying any one or more of the methodologies or functions described herein. The instructions 1026 may also reside, completely or at least partially, within the main memory 1004 and/or within the processing device 1002 during execution thereof by the computer system 1000, the main memory 1004 and the processing device 1002 also constituting machine-readable storage media.
  • The machine-readable storage medium 1024 may also be used to store software performing the operations discussed herein, and/or a software library containing methods that call this software. While the machine-readable storage medium 1024 is shown in an exemplary embodiment to be a single medium, the term “machine-readable storage 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 storage medium” shall also be taken to include any medium that is capable of storing or encoding 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. The term “machine-readable storage medium” shall accordingly be taken to include, but not be limited to, solid-state memories, and optical and magnetic media.
  • Some portions of the detailed description above are presented in terms of algorithms and symbolic representations of operations on data bits within a computer memory. These algorithmic descriptions and representations are the means used by those skilled in the data processing arts to most effectively convey the substance of their work to others skilled in the art. An algorithm is here, and generally, conceived to be a self-consistent sequence of steps leading to a desired result. The steps are those requiring physical manipulations of physical quantities. Usually, though not necessarily, these quantities take the form of electrical or magnetic signals capable of being stored, transferred, combined, compared, and otherwise manipulated. It has proven convenient at times, principally for reasons of common usage, to refer to these signals as bits, values, elements, symbols, characters, terms, numbers, or the like.
  • It should be borne in mind, however, that all of these and similar terms are to be associated with the appropriate physical quantities and are merely convenient labels applied to these quantities. Unless specifically stated otherwise as apparent from the following discussion, it is appreciated that throughout the description, discussions utilizing terms such as “receiving”, “determining”, “encrypting”, “decrypting”, “sending” or the like, refer to the actions and processes of a computer system, or similar electronic computing device, that manipulates and transforms data represented as physical (e.g., electronic) quantities within the computer system's registers and memories into other data similarly represented as physical quantities within the computer system memories or registers or other such information storage devices.
  • Embodiments of the invention also relate to an apparatus for performing the operations herein. This apparatus may be specially constructed for the required purposes, or it may comprise a general purpose computer selectively activated or reconfigured by a computer program stored in the computer. Such a computer program may be stored in a computer readable storage medium, such as, but not limited to, any type of disk including floppy disks, optical disks, CD-ROMs, and magnetic-optical disks, read-only memories (ROMs), random access memories (RAMs), EPROMs, EEPROMs, magnetic or optical cards, or any type of media suitable for storing electronic instructions.
  • The algorithms and displays presented herein are not inherently related to any particular computer or other apparatus. Various general purpose systems may be used with programs in accordance with the teachings herein, or it may prove convenient to construct a more specialized apparatus to perform the required method steps. The required structure for a variety of these systems will appear from the description below. In addition, the present invention is not described with reference to any particular programming language. It will be appreciated that a variety of programming languages may be used to implement the teachings of the invention as described herein.
  • The operations of a method or algorithm described in connection with the embodiments disclosed herein may be embodied directly in hardware, in a computer program executed by a processor, or in a combination of the two. A computer program may be embodied on a computer readable medium, such as a storage medium. For example, a computer program may reside in random access memory (“RAM”), flash memory, read-only memory (“ROM”), erasable programmable read-only memory (“EPROM”), electrically erasable programmable read-only memory (“EEPROM”), registers, hard disk, a removable disk, a compact disk read-only memory (“CD-ROM”), or any other form of storage medium known in the art.
  • An exemplary storage medium may be coupled to the processor such that the processor may read information from, and write information to, the storage medium. In the alternative, the storage medium may be integral to the processor. The processor and the storage medium may reside in an application specific integrated circuit (“ASIC”). In the alternative, the processor and the storage medium may reside as discrete components.
  • It is to be understood that the above description is intended to be illustrative, and not restrictive. Many other embodiments will be apparent to those of skill in the art upon reading and understanding the above description. Although the present invention has been described with reference to specific exemplary embodiments, it will be recognized that the invention is not limited to the embodiments described, but can be practiced with modification and alteration within the spirit and scope of the appended claims. Accordingly, the specification and drawings are to be regarded in an illustrative sense rather than a restrictive sense. The scope of the invention should, therefore, be determined with reference to the appended claims, along with the full scope of equivalents to which such claims are entitled.
  • While preferred embodiments of the present invention have been described, it is to be understood that the embodiments described are illustrative only and the scope of the invention is to be defined solely by the appended claims when considered with a full range of equivalents and modifications (e.g., protocols, hardware devices, software platforms etc.) thereto.

Claims (20)

1. A computer-implemented method comprising:
generating a list of virtual machines currently operating in a network;
surveying the virtual machines to determine their current resource usage data;
ranking the virtual machines based on their current resource usage data to indicate available resources of the virtual machines; and
assigning the virtual machines to at least one business application service group (BASG) that requires the available resources of the virtual machines.
2. The method of claim 1, further comprising:
assigning a profile to the virtual machines based on their current resource usage data.
3. The method of claim 2, wherein the profile is at least one of a high availability, high capacity, high speed, moderate capacity, moderate speed, moderate availability, low capacity, low speed and low availability, and the profile is based on at least one of CPU usage, memory usage and disk usage.
4. The method of claim 1, further comprising:
compiling a list of candidate BASGs prior to assigning the virtual machines to the at least one business application service group (BASG).
5. The method of claim 1, wherein the virtual machines are currently operating as part of an established BASG prior to assigning the virtual machines to the at least one business application service group (BASG).
6. The method of claim 1, wherein the ranking the virtual machines based on their current resource usage data comprises averaging the virtual machines over the total number of virtual machines.
7. The method of claim 1, wherein the current resource usage data is obtained over a period of 30 days.
8. An apparatus comprising:
a memory to store a list of virtual machines currently operating in a network; and
a processor, coupled to the memory, to generate the list of the virtual machines currently operating in the network, store the list in the memory, survey the virtual machines to determine their current resource usage data, rank the virtual machines based on their current resource usage data to indicate available resources of the virtual machines, and assign the virtual machines to at least one business application service group (BASG) that requires the available resources of the virtual machines.
9. The apparatus of claim 8, wherein a profile is assigned to the virtual machines based on the current resource usage data of the virtual machines.
10. The apparatus of claim 9, wherein the profile is at least one of a high availability, high capacity, high speed, moderate capacity, moderate speed, moderate availability, low capacity, low speed and low availability, and the profile is based on at least one of CPU usage, memory usage and disk usage.
11. The apparatus of claim 8, wherein the processor is further configured to compile a list of candidate BASGs prior to assigning the virtual machines to the at least one business application service group (BASG).
12. The apparatus of claim 8, wherein the virtual machines are currently operating as part of an established BASG prior to assigning the virtual machines to the at least one business application service group (BASG).
13. The apparatus of claim 8, wherein the ranking the virtual machines based on their current resource usage data comprises the processor performing an average of the virtual machines over the total number of virtual machines.
14. The apparatus of claim 8, wherein the current resource usage data is obtained over a period of 30 days.
15. A non-transitory computer readable storage medium comprising instructions that when executed cause a processor to perform operations comprising:
generating a list of virtual machines currently operating in a network;
surveying the virtual machines to determine their current resource usage data;
ranking the virtual machines based on their current resource usage data to indicate available resources of the virtual machines; and
assigning the virtual machines to at least one business application service group (BASG) that requires the available resources of the virtual machines.
16. The non-transitory computer readable storage medium of claim 15, wherein the operations further comprise:
assigning a profile to the virtual machines based on their current resource usage data.
17. The non-transitory computer readable storage medium of claim 16, wherein the profile is at least one of a high availability, high capacity, high speed, moderate capacity, moderate speed, moderate availability, low capacity, low speed and low availability, and the profile is based on at least one of CPU usage, memory usage and disk usage.
18. The non-transitory computer readable storage medium of claim 15, wherein the operations further comprise:
compiling a list of candidate BASGs prior to assigning the virtual machines to the at least one business application service group (BASG).
19. The non-transitory computer readable storage medium of claim 15, wherein the virtual machines are currently operating as part of an established BASG prior to assigning the virtual machines to the at least one business application service group (BASG).
20. The non-transitory computer readable storage medium of claim 15, wherein the ranking the virtual machines based on their current resource usage data comprises averaging the virtual machines over the total number of virtual machines.
US12/979,237 2007-06-22 2010-12-27 Assigning virtual machines to business application service groups based on ranking of the virtual machines Active 2033-02-17 US9354960B2 (en)

Priority Applications (5)

Application Number Priority Date Filing Date Title
US12/979,229 US9588821B2 (en) 2007-06-22 2010-12-27 Automatic determination of required resource allocation of virtual machines
US12/979,255 US9477572B2 (en) 2007-06-22 2010-12-27 Performing predictive modeling of virtual machine relationships
US12/979,237 US9354960B2 (en) 2010-12-27 2010-12-27 Assigning virtual machines to business application service groups based on ranking of the virtual machines
US12/979,245 US9495152B2 (en) 2007-06-22 2010-12-27 Automatic baselining of business application service groups comprised of virtual machines
US12/979,259 US9727440B2 (en) 2007-06-22 2010-12-27 Automatic simulation of virtual machine performance

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
US12/979,237 US9354960B2 (en) 2010-12-27 2010-12-27 Assigning virtual machines to business application service groups based on ranking of the virtual machines

Publications (2)

Publication Number Publication Date
US20120167083A1 true US20120167083A1 (en) 2012-06-28
US9354960B2 US9354960B2 (en) 2016-05-31

Family

ID=46318645

Family Applications (1)

Application Number Title Priority Date Filing Date
US12/979,237 Active 2033-02-17 US9354960B2 (en) 2007-06-22 2010-12-27 Assigning virtual machines to business application service groups based on ranking of the virtual machines

Country Status (1)

Country Link
US (1) US9354960B2 (en)

Cited By (81)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20120089980A1 (en) * 2010-10-12 2012-04-12 Richard Sharp Allocating virtual machines according to user-specific virtual machine metrics
US20120272234A1 (en) * 2011-04-20 2012-10-25 Cisco Technology, Inc. Scoring of Computing Equipment for Virtualized Computing Environments
US20130073730A1 (en) * 2011-09-20 2013-03-21 International Business Machines Corporation Virtual machine placement within a server farm
US20140181813A1 (en) * 2012-12-21 2014-06-26 Commvault Systems, Inc. Archiving virtual machines in a data storage system
US20140189104A1 (en) * 2012-12-28 2014-07-03 Calxeda, Inc. System And Method For Continuous Low-Overhead Monitoring Of Distributed Applications Running On A Cluster Of Data Processing Nodes
US20140196033A1 (en) * 2013-01-10 2014-07-10 International Business Machines Corporation System and method for improving memory usage in virtual machines
US20140215073A1 (en) * 2013-01-28 2014-07-31 International Business Machines Corporation Computing optimized virtual machine allocations using equivalence combinations
US20140245297A1 (en) * 2013-02-27 2014-08-28 International Business Machines Corporation Managing allocation of hardware resources in a virtualized environment
WO2014150715A1 (en) * 2013-03-15 2014-09-25 Centurylink Intellectual Property Llc Virtualization congestion control framework
WO2014159740A1 (en) * 2013-03-13 2014-10-02 Cloubrain, Inc. Feedback system for optimizing the allocation of resources in a data center
US20150169673A1 (en) * 2012-12-12 2015-06-18 Sk Planet Co., Ltd. Method for providing immediate result for user input, and apparatus therefor
US9215142B1 (en) * 2011-04-20 2015-12-15 Dell Software Inc. Community analysis of computing performance
US20150370682A1 (en) * 2014-06-24 2015-12-24 Vmware, Inc. Data-agnostic adjustment of hard thresholds based on user feedback
US9286110B2 (en) 2013-01-14 2016-03-15 Commvault Systems, Inc. Seamless virtual machine recall in a data storage system
US9417968B2 (en) 2014-09-22 2016-08-16 Commvault Systems, Inc. Efficiently restoring execution of a backed up virtual machine based on coordination with virtual-machine-file-relocation operations
US9430259B2 (en) 2013-03-15 2016-08-30 Centurylink Intellectual Property Llc Virtualization congestion control framework for modifying execution of applications on virtual machine based on mass congestion indicator in host computing system
US9436555B2 (en) 2014-09-22 2016-09-06 Commvault Systems, Inc. Efficient live-mount of a backed up virtual machine in a storage management system
US9495404B2 (en) 2013-01-11 2016-11-15 Commvault Systems, Inc. Systems and methods to process block-level backup for selective file restoration for virtual machines
US9531607B1 (en) 2012-06-20 2016-12-27 Amazon Technologies, Inc. Resource manager
US9575781B1 (en) * 2011-05-23 2017-02-21 Open Invention Network Llc Automatic determination of a virtual machine's dependencies on storage virtualization
US20170171092A1 (en) * 2014-04-08 2017-06-15 AppDynamics, Inc. Network analysis and monitoring tool
US9703584B2 (en) 2013-01-08 2017-07-11 Commvault Systems, Inc. Virtual server agent load balancing
US9710465B2 (en) 2014-09-22 2017-07-18 Commvault Systems, Inc. Efficiently restoring execution of a backed up virtual machine based on coordination with virtual-machine-file-relocation operations
US9740702B2 (en) 2012-12-21 2017-08-22 Commvault Systems, Inc. Systems and methods to identify unprotected virtual machines
US20170302586A1 (en) * 2013-06-28 2017-10-19 Pepperdata, Inc. Systems, methods, and devices for dynamic resource monitoring and allocation in a cluster system
US9823977B2 (en) 2014-11-20 2017-11-21 Commvault Systems, Inc. Virtual machine change block tracking
US9864623B2 (en) 2013-11-21 2018-01-09 Centurylink Intellectual Property Llc Physical to virtual network transport function abstraction
US9882833B2 (en) 2015-09-28 2018-01-30 Centurylink Intellectual Property Llc Intent-based services orchestration
US9898318B2 (en) 2014-08-15 2018-02-20 Centurylink Intellectual Property Llc Multi-line/multi-state virtualized OAM transponder
US9939981B2 (en) 2013-09-12 2018-04-10 Commvault Systems, Inc. File manager integration with virtualization in an information management system with an enhanced storage manager, including user control and storage management of virtual machines
US10152251B2 (en) 2016-10-25 2018-12-11 Commvault Systems, Inc. Targeted backup of virtual machine
US10162528B2 (en) 2016-10-25 2018-12-25 Commvault Systems, Inc. Targeted snapshot based on virtual machine location
US20190158425A1 (en) * 2017-11-21 2019-05-23 International Business Machines Corporation Diagonal scaling of resource allocations and application instances in a distributed computing environment
US10387073B2 (en) 2017-03-29 2019-08-20 Commvault Systems, Inc. External dynamic virtual machine synchronization
US10389577B2 (en) 2013-08-14 2019-08-20 Centurylink Intellectual Property Llc Ethernet carrier group alarm (CGA)
US10387181B2 (en) * 2016-01-12 2019-08-20 International Business Machines Corporation Pre-deployment of particular virtual machines based on performance and due to service popularity and resource cost scores in a cloud environment
US10417102B2 (en) 2016-09-30 2019-09-17 Commvault Systems, Inc. Heartbeat monitoring of virtual machines for initiating failover operations in a data storage management system, including virtual machine distribution logic
US10474542B2 (en) 2017-03-24 2019-11-12 Commvault Systems, Inc. Time-based virtual machine reversion
US10481938B2 (en) 2015-05-06 2019-11-19 Centurylink Intellectual Property Llc System and method for implementing network experience shifting
US10565067B2 (en) 2016-03-09 2020-02-18 Commvault Systems, Inc. Virtual server cloud file system for virtual machine backup from cloud operations
US10635501B2 (en) 2017-11-21 2020-04-28 International Business Machines Corporation Adaptive scaling of workloads in a distributed computing environment
US10650057B2 (en) 2014-07-16 2020-05-12 Commvault Systems, Inc. Volume or virtual machine level backup and generating placeholders for virtual machine files
US10666772B2 (en) 2014-04-03 2020-05-26 Centurylink Intellectual Property Llc System and method for implementing extension of customer LAN at provider network service point
US10673978B2 (en) 2015-05-06 2020-06-02 Centurylink Intellectual Property Llc Method and system for implementing network experience shifting using shared objects
US10678758B2 (en) 2016-11-21 2020-06-09 Commvault Systems, Inc. Cross-platform virtual machine data and memory backup and replication
US10705871B2 (en) 2015-10-06 2020-07-07 Centurylink Intellectual Property Llc Virtual machine-to-port peripheral device driver for implementing communications between virtual machines and client devices
US10721179B2 (en) 2017-11-21 2020-07-21 International Business Machines Corporation Adaptive resource allocation operations based on historical data in a distributed computing environment
US10733015B2 (en) 2017-11-21 2020-08-04 International Business Machines Corporation Prioritizing applications for diagonal scaling in a distributed computing environment
US10768971B2 (en) 2019-01-30 2020-09-08 Commvault Systems, Inc. Cross-hypervisor live mount of backed up virtual machine data
US10776209B2 (en) 2014-11-10 2020-09-15 Commvault Systems, Inc. Cross-platform virtual machine backup and replication
US10812407B2 (en) 2017-11-21 2020-10-20 International Business Machines Corporation Automatic diagonal scaling of workloads in a distributed computing environment
US10877928B2 (en) 2018-03-07 2020-12-29 Commvault Systems, Inc. Using utilities injected into cloud-based virtual machines for speeding up virtual machine backup operations
US10887250B2 (en) 2017-11-21 2021-01-05 International Business Machines Corporation Reducing resource allocations and application instances in diagonal scaling in a distributed computing environment
US10992734B2 (en) 2014-08-13 2021-04-27 Centurylink Intellectual Property Llc Remoting application servers
US10996974B2 (en) 2019-01-30 2021-05-04 Commvault Systems, Inc. Cross-hypervisor live mount of backed up virtual machine data, including management of cache storage for virtual machine data
US11003475B2 (en) * 2013-04-30 2021-05-11 Splunk Inc. Interface for presenting performance data for hierarchical networked components represented in an expandable visualization of nodes
US11163599B2 (en) 2013-04-30 2021-11-02 Splunk Inc. Determination of performance state of a user-selected parent component in a hierarchical computing environment based on performance states of related child components
US20210382760A1 (en) * 2020-06-05 2021-12-09 Fujitsu Limited Resource adjustment device, non-transitory computer-readable medium and resource adjustment method
US11212159B2 (en) 2014-04-03 2021-12-28 Centurylink Intellectual Property Llc Network functions virtualization interconnection gateway
US11321189B2 (en) 2014-04-02 2022-05-03 Commvault Systems, Inc. Information management by a media agent in the absence of communications with a storage manager
US11416278B2 (en) * 2014-09-23 2022-08-16 Splunk Inc. Presenting hypervisor data for a virtual machine with associated operating system data
US11436210B2 (en) 2008-09-05 2022-09-06 Commvault Systems, Inc. Classification of virtualization data
US11442768B2 (en) 2020-03-12 2022-09-13 Commvault Systems, Inc. Cross-hypervisor live recovery of virtual machines
US11449394B2 (en) 2010-06-04 2022-09-20 Commvault Systems, Inc. Failover systems and methods for performing backup operations, including heterogeneous indexing and load balancing of backup and indexing resources
US11467883B2 (en) 2004-03-13 2022-10-11 Iii Holdings 12, Llc Co-allocating a reservation spanning different compute resources types
US11467753B2 (en) 2020-02-14 2022-10-11 Commvault Systems, Inc. On-demand restore of virtual machine data
US11487562B2 (en) * 2014-06-27 2022-11-01 Amazon Technologies, Inc. Rolling resource credits for scheduling of virtual computer resources
US11494235B2 (en) 2004-11-08 2022-11-08 Iii Holdings 12, Llc System and method of providing system jobs within a compute environment
US11496415B2 (en) 2005-04-07 2022-11-08 Iii Holdings 12, Llc On-demand access to compute resources
US11500669B2 (en) 2020-05-15 2022-11-15 Commvault Systems, Inc. Live recovery of virtual machines in a public cloud computing environment
US11522952B2 (en) 2007-09-24 2022-12-06 The Research Foundation For The State University Of New York Automatic clustering for self-organizing grids
US11526304B2 (en) 2009-10-30 2022-12-13 Iii Holdings 2, Llc Memcached server functionality in a cluster of data processing nodes
US11550680B2 (en) 2018-12-06 2023-01-10 Commvault Systems, Inc. Assigning backup resources in a data storage management system based on failover of partnered data storage resources
US11630704B2 (en) 2004-08-20 2023-04-18 Iii Holdings 12, Llc System and method for a workload management and scheduling module to manage access to a compute environment according to local and non-local user identity information
US11652706B2 (en) 2004-06-18 2023-05-16 Iii Holdings 12, Llc System and method for providing dynamic provisioning within a compute environment
US11650857B2 (en) 2006-03-16 2023-05-16 Iii Holdings 12, Llc System and method for managing a hybrid computer environment
US11658916B2 (en) 2005-03-16 2023-05-23 Iii Holdings 12, Llc Simple integration of an on-demand compute environment
US11656951B2 (en) 2020-10-28 2023-05-23 Commvault Systems, Inc. Data loss vulnerability detection
US11663099B2 (en) 2020-03-26 2023-05-30 Commvault Systems, Inc. Snapshot-based disaster recovery orchestration of virtual machine failover and failback operations
US11720290B2 (en) 2009-10-30 2023-08-08 Iii Holdings 2, Llc Memcached server functionality in a cluster of data processing nodes
US11960937B2 (en) 2004-03-13 2024-04-16 Iii Holdings 12, Llc System and method for an optimizing reservation in time of compute resources based on prioritization function and reservation policy parameter

Families Citing this family (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2019135773A1 (en) 2018-01-08 2019-07-11 Hewlett-Packard Development Company, L.P. Brokering servers based on remote access performance
US11755394B2 (en) * 2020-01-31 2023-09-12 Salesforce, Inc. Systems, methods, and apparatuses for tenant migration between instances in a cloud based computing environment
CN111813556B (en) * 2020-07-21 2021-04-09 北京东方通软件有限公司 Elastic expansion method of virtual cluster in cloud computing environment

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20080320123A1 (en) * 2007-06-21 2008-12-25 John Richard Houlihan Process and methodology for generic analysis of metrics related to resource utilization and performance
US20090172666A1 (en) * 2007-12-31 2009-07-02 Netapp, Inc. System and method for automatic storage load balancing in virtual server environments
US20100146503A1 (en) * 2008-12-10 2010-06-10 Institute For Information Industry Scheduler of virtual machine module, scheduling method therefor, and device containing computer software
US20100269109A1 (en) * 2009-04-17 2010-10-21 John Cartales Methods and Systems for Evaluating Historical Metrics in Selecting a Physical Host for Execution of a Virtual Machine
US20100293544A1 (en) * 2009-05-13 2010-11-18 Verizon Patent And Licensing Inc. Integrated virtual and physical resource provisioning system
US20110225277A1 (en) * 2010-03-11 2011-09-15 International Business Machines Corporation Placement of virtual machines based on server cost and network cost

Family Cites Families (157)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5440719A (en) 1992-10-27 1995-08-08 Cadence Design Systems, Inc. Method simulating data traffic on network in accordance with a client/sewer paradigm
US6658465B1 (en) 1997-08-25 2003-12-02 Intel Corporation Method and apparatus for monitoring and controlling programs in a network
US6836800B1 (en) 1998-09-30 2004-12-28 Netscout Systems, Inc. Managing computer resources
US6901442B1 (en) 2000-01-07 2005-05-31 Netiq Corporation Methods, system and computer program products for dynamic filtering of network performance test results
US7624172B1 (en) 2000-03-17 2009-11-24 Aol Llc State change alerts mechanism
US7082463B1 (en) 2000-06-07 2006-07-25 Cisco Technology, Inc. Time-based monitoring of service level agreements
US6513059B1 (en) 2000-08-24 2003-01-28 Cambira Corporation Adaptive collaborative intelligent network system
US7181769B1 (en) 2000-08-25 2007-02-20 Ncircle Network Security, Inc. Network security system having a device profiler communicatively coupled to a traffic monitor
US6871223B2 (en) 2001-04-13 2005-03-22 Hewlett-Packard Development Company, L.P. System and method for agent reporting in to server
US20030101170A1 (en) 2001-05-25 2003-05-29 Joseph Edelstein Data query and location through a central ontology model
US7228566B2 (en) 2001-07-10 2007-06-05 Core Sdi, Incorporated Automated computer system security compromise
US7243225B2 (en) 2001-07-13 2007-07-10 Certicom Corp. Data handling in IPSec enabled network stack
US20030046586A1 (en) 2001-09-05 2003-03-06 Satyam Bheemarasetti Secure remote access to data between peers
US20050044206A1 (en) 2001-09-07 2005-02-24 Staffan Johansson Method and arrangements to achieve a dynamic resource distribution policy in packet based communication networks
DE10147446A1 (en) 2001-09-26 2003-04-17 Bosch Gmbh Robert Method and device for monitoring a bus system and bus system
US7197762B2 (en) 2001-10-31 2007-03-27 Hewlett-Packard Development Company, L.P. Method, computer readable medium, and node for a three-layered intrusion prevention system for detecting network exploits
US7188163B2 (en) 2001-11-26 2007-03-06 Sun Microsystems, Inc. Dynamic reconfiguration of applications on a server
GB0130531D0 (en) 2001-12-20 2002-02-06 Marconi Comm Ltd Duplicate address detection in networks
US7398389B2 (en) 2001-12-20 2008-07-08 Coretrace Corporation Kernel-based network security infrastructure
US7222366B2 (en) 2002-01-28 2007-05-22 International Business Machines Corporation Intrusion event filtering
US7225183B2 (en) 2002-01-28 2007-05-29 Ipxl, Inc. Ontology-based information management system and method
US20030225876A1 (en) 2002-05-31 2003-12-04 Peter Oliver Method and apparatus for graphically depicting network performance and connectivity
US7562393B2 (en) 2002-10-21 2009-07-14 Alcatel-Lucent Usa Inc. Mobility access gateway
EP1418501A1 (en) 2002-11-08 2004-05-12 Dunes Technologies S.A. Method of administration of applications on virtual machines
US7761917B1 (en) 2002-11-21 2010-07-20 Vmware, Inc. Method and apparatus for the detection and prevention of intrusions, computer worms, and denial of service attacks
US20040122937A1 (en) 2002-12-18 2004-06-24 International Business Machines Corporation System and method of tracking messaging flows in a distributed network
US7483972B2 (en) 2003-01-08 2009-01-27 Cisco Technology, Inc. Network security monitoring system
US8209680B1 (en) 2003-04-11 2012-06-26 Vmware, Inc. System and method for disk imaging on diverse computers
US7308711B2 (en) 2003-06-06 2007-12-11 Microsoft Corporation Method and framework for integrating a plurality of network policies
US7203944B1 (en) 2003-07-09 2007-04-10 Veritas Operating Corporation Migrating virtual machines among computer systems to balance load caused by virtual machines
US7546598B2 (en) 2003-09-03 2009-06-09 Sap Aktiengesellschaft Measuring software system performance using benchmarks
US8539081B2 (en) 2003-09-15 2013-09-17 Neopath Networks, Inc. Enabling proxy services using referral mechanisms
US8356349B2 (en) 2003-10-30 2013-01-15 Telecom Italia S.P.A. Method and system for intrusion prevention and deflection
US7483986B2 (en) 2003-12-03 2009-01-27 International Business Machines Corporation Dynamically tuning networks of relationships in self-organizing multi-agent systems
US20050240558A1 (en) 2004-04-13 2005-10-27 Reynaldo Gil Virtual server operating on one or more client devices
PT1735983E (en) 2004-04-14 2008-05-15 Telecom Italia Spa Method and system for handling content delivery in communication networks
US7257811B2 (en) 2004-05-11 2007-08-14 International Business Machines Corporation System, method and program to migrate a virtual machine
US7769720B2 (en) 2004-06-16 2010-08-03 Hewlett-Packard Development Company, L.P. Systems and methods for migrating a server from one physical platform to a different physical platform
US7788713B2 (en) 2004-06-23 2010-08-31 Intel Corporation Method, apparatus and system for virtualized peer-to-peer proxy services
US7724657B2 (en) 2004-07-23 2010-05-25 Citrix Systems, Inc. Systems and methods for communicating a lossy protocol via a lossless protocol
US20060023638A1 (en) 2004-07-29 2006-02-02 Solutions4Networks Proactive network analysis system
US20060074833A1 (en) 2004-09-03 2006-04-06 Biowisdom Limited System and method for notifying users of changes in multi-relational ontologies
US9055092B2 (en) 2004-09-10 2015-06-09 Riverbed Technology, Inc. Method and system for grouping diagnostic information
US20060123133A1 (en) 2004-10-19 2006-06-08 Hrastar Scott E Detecting unauthorized wireless devices on a wired network
US7826602B1 (en) 2004-10-22 2010-11-02 Juniper Networks, Inc. Enabling incoming VoIP calls behind a network firewall
US7409719B2 (en) 2004-12-21 2008-08-05 Microsoft Corporation Computer security management, such as in a virtual machine or hardened operating system
US7886294B2 (en) 2004-12-28 2011-02-08 Sap Ag Virtual machine monitoring
US7979889B2 (en) 2005-01-07 2011-07-12 Cisco Technology, Inc. Methods and apparatus providing security to computer systems and networks
US7730486B2 (en) 2005-02-28 2010-06-01 Hewlett-Packard Development Company, L.P. System and method for migrating virtual machines on cluster systems
US7506052B2 (en) 2005-04-11 2009-03-17 Microsoft Corporation Network experience rating system and method
US20060271557A1 (en) 2005-05-25 2006-11-30 Terracotta, Inc. Database Caching and Invalidation Based on Detected Database Updates
US7600259B2 (en) 2005-06-08 2009-10-06 Symantec Corporation Critical period protection
JP4674502B2 (en) 2005-07-22 2011-04-20 ソニー株式会社 Information communication system, information communication apparatus, information communication method, and computer program
WO2007021836A2 (en) 2005-08-15 2007-02-22 Toutvirtual Inc. Virtual systems management
US7953696B2 (en) 2005-09-09 2011-05-31 Microsoft Corporation Real-time synchronization of XML data between applications
US8601159B2 (en) 2005-09-27 2013-12-03 Microsoft Corporation Distributing and arbitrating media access control addresses on ethernet network
WO2007038713A2 (en) 2005-09-28 2007-04-05 Epacris Inc. Search engine determining results based on probabilistic scoring of relevance
US20070118394A1 (en) 2005-11-12 2007-05-24 Cahoon Kyle A Value synthesis infrastructure and ontological analysis system
CA2569750A1 (en) 2005-12-27 2007-06-27 Solana Networks Inc. Real-time network analyzer
US7877781B2 (en) 2005-12-29 2011-01-25 Nextlabs, Inc. Enforcing universal access control in an information management system
WO2007092651A2 (en) 2006-01-04 2007-08-16 Nytor, Inc. Trusted host platform
US20070174429A1 (en) 2006-01-24 2007-07-26 Citrix Systems, Inc. Methods and servers for establishing a connection between a client system and a virtual machine hosting a requested computing environment
US7975058B2 (en) 2006-01-31 2011-07-05 Cisco Technology, Inc. Systems and methods for remote access of network devices having private addresses
US8042108B2 (en) 2006-03-18 2011-10-18 International Business Machines Corporation Virtual machine migration between servers
US7480656B2 (en) 2006-03-20 2009-01-20 Sony Computer Entertainment America Inc. Active validation of network devices
KR100748246B1 (en) 2006-03-29 2007-08-10 한국전자통신연구원 Multi-step integrated security monitoring system and method using intrusion detection system log collection engine and traffic statistic generation engine
US20070234412A1 (en) 2006-03-29 2007-10-04 Smith Ned M Using a proxy for endpoint access control
US7698545B1 (en) 2006-04-24 2010-04-13 Hewlett-Packard Development Company, L.P. Computer configuration chronology generator
US8117654B2 (en) 2006-06-30 2012-02-14 The Invention Science Fund I, Llc Implementation of malware countermeasures in a network device
US7890612B2 (en) 2006-05-08 2011-02-15 Electro Guard Corp. Method and apparatus for regulating data flow between a communications device and a network
US20140373144A9 (en) 2006-05-22 2014-12-18 Alen Capalik System and method for analyzing unauthorized intrusion into a computer network
EP2030124A4 (en) 2006-05-24 2012-12-12 Safend Ltd Method and system for defending security application in a user's computer
US7949404B2 (en) 2006-06-26 2011-05-24 Medtronic, Inc. Communications network for distributed sensing and therapy in biomedical applications
US20080016115A1 (en) 2006-07-17 2008-01-17 Microsoft Corporation Managing Networks Using Dependency Analysis
US20080047009A1 (en) 2006-07-20 2008-02-21 Kevin Overcash System and method of securing networks against applications threats
US8145760B2 (en) 2006-07-24 2012-03-27 Northwestern University Methods and systems for automatic inference and adaptation of virtualized computing environments
WO2008014800A1 (en) 2006-07-31 2008-02-07 Telecom Italia S.P.A. A system for implementing security on telecommunications terminals
US8098658B1 (en) 2006-08-01 2012-01-17 Hewett-Packard Development Company, L.P. Power-based networking resource allocation
US8272048B2 (en) 2006-08-04 2012-09-18 Apple Inc. Restriction of program process capabilities
US8151277B2 (en) 2007-05-15 2012-04-03 Dynatrace Software Gmbh Method and system for dynamic remote injection of in-process agents into virtual machine based applications
US7571349B2 (en) 2006-08-18 2009-08-04 Microsoft Corporation Configuration replication for system recovery and migration
US8136162B2 (en) 2006-08-31 2012-03-13 Broadcom Corporation Intelligent network interface controller
US8161475B2 (en) 2006-09-29 2012-04-17 Microsoft Corporation Automatic load and balancing for virtual machines to meet resource requirements
US20080089338A1 (en) 2006-10-13 2008-04-17 Robert Campbell Methods for remotely creating and managing virtual machines
US8458695B2 (en) 2006-10-17 2013-06-04 Manageiq, Inc. Automatic optimization for virtual systems
US9038062B2 (en) 2006-10-17 2015-05-19 Manageiq, Inc. Registering and accessing virtual systems for use in a managed system
US7774498B1 (en) 2006-11-06 2010-08-10 Cisco Technology, Inc. Methods and apparatus for trusted application centric QoS provisioning
US8069216B2 (en) 2006-12-08 2011-11-29 Motorola Solutions, Inc. Method and apparatus for alerting nodes of a malicious node in a mobile ad-hoc communication system
US7716146B2 (en) 2006-12-22 2010-05-11 Verizon Patent And Licensing Inc. Network management system utilizing a neural network
US8336046B2 (en) 2006-12-29 2012-12-18 Intel Corporation Dynamic VM cloning on request from application based on mapping of virtual hardware configuration to the identified physical hardware resources
US7996836B1 (en) 2006-12-29 2011-08-09 Symantec Corporation Using a hypervisor to provide computer security
US8613080B2 (en) 2007-02-16 2013-12-17 Veracode, Inc. Assessment and analysis of software security flaws in virtual machines
ATE504995T1 (en) 2007-02-20 2011-04-15 Siemens Ag OPERATION OF A COMMUNICATIONS NETWORK
US8838755B2 (en) 2007-03-23 2014-09-16 Microsoft Corporation Unified service management
US8011010B2 (en) 2007-04-17 2011-08-30 Microsoft Corporation Using antimalware technologies to perform offline scanning of virtual machine images
US20080271019A1 (en) 2007-04-24 2008-10-30 Stratton Robert J System and Method for Creating a Virtual Assurance System
US20080271025A1 (en) 2007-04-24 2008-10-30 Stacksafe, Inc. System and method for creating an assurance system in a production environment
US7890318B2 (en) 2007-05-23 2011-02-15 Xerox Corporation Informing troubleshooting sessions with device data
US8949827B2 (en) 2007-06-22 2015-02-03 Red Hat, Inc. Tracking a virtual machine
US8656009B2 (en) 2010-10-15 2014-02-18 Red Hat, Inc. Indicating an impact of a change in state of a node
US9678803B2 (en) 2007-06-22 2017-06-13 Red Hat, Inc. Migration of network entities to a cloud infrastructure
US8429748B2 (en) 2007-06-22 2013-04-23 Red Hat, Inc. Network traffic analysis using a dynamically updating ontological network description
US8191141B2 (en) 2007-06-22 2012-05-29 Red Hat, Inc. Method and system for cloaked observation and remediation of software attacks
US8938489B2 (en) 2007-06-22 2015-01-20 Red Hat, Inc. Monitoring system performance changes based on configuration modification
US8156378B1 (en) 2010-10-15 2012-04-10 Red Hat, Inc. System and method for determination of the root cause of an overall failure of a business application service
US8336108B2 (en) 2007-06-22 2012-12-18 Red Hat, Inc. Method and system for collaboration involving enterprise nodes
US8984504B2 (en) 2007-06-22 2015-03-17 Red Hat, Inc. Method and system for determining a host machine by a virtual machine
US8539570B2 (en) 2007-06-22 2013-09-17 Red Hat, Inc. Method for managing a virtual machine
US8825838B2 (en) 2010-10-15 2014-09-02 Red Hat, Inc. Identification of business process application service groups
US8127290B2 (en) 2007-06-22 2012-02-28 Red Hat, Inc. Method and system for direct insertion of a virtual machine driver
CA2691666C (en) 2007-06-26 2014-03-18 Core Sdi Incorporated System and method for simulating computer network attacks
US8295277B2 (en) 2007-06-29 2012-10-23 Cisco Technology, Inc. Analyzing a network with a cache advance proxy
US8208381B2 (en) 2007-07-27 2012-06-26 Eg Innovations Pte. Ltd. Root-cause approach to problem diagnosis in data networks
US7984449B2 (en) 2007-08-15 2011-07-19 International Business Machines Corporation In-band communication with virtual machines via a hypervisor message bus
US7793162B2 (en) 2007-08-16 2010-09-07 International Business Machines Corporation Method for reporting the status and drill-down of a control application in an automated manufacturing environment
US8694990B2 (en) 2007-08-27 2014-04-08 International Business Machines Corporation Utilizing system configuration information to determine a data migration order
US8326970B2 (en) 2007-11-05 2012-12-04 Hewlett-Packard Development Company, L.P. System and method for modeling a session-based system with a transaction-based analytic model
US7962738B2 (en) 2007-12-20 2011-06-14 Intel Corporation Hypervisor runtime integrity support
US8001228B2 (en) 2008-01-15 2011-08-16 Oracle International Corporation System and method to dynamically extend a management information base using SNMP in an application server environment
US7676573B2 (en) 2008-02-08 2010-03-09 Microsoft Corporation Node monitor client cache synchronization for mobile device management
US20090210427A1 (en) 2008-02-15 2009-08-20 Chris Eidler Secure Business Continuity and Disaster Recovery Platform for Multiple Protected Systems
US8458419B2 (en) 2008-02-27 2013-06-04 International Business Machines Corporation Method for application backup in the VMware consolidated backup framework
US8230069B2 (en) 2008-03-04 2012-07-24 International Business Machines Corporation Server and storage-aware method for selecting virtual machine migration targets
US8397225B2 (en) 2008-04-24 2013-03-12 International Business Machines Corporation Optimizing just-in-time compiling for a java application executing on a compute node
US20090307772A1 (en) 2008-05-21 2009-12-10 Honeywell International Inc. framework for scalable state estimation using multi network observations
US9501124B2 (en) 2008-05-22 2016-11-22 Microsoft Technology Licensing, Llc Virtual machine placement based on power calculations
US9262194B2 (en) 2008-06-10 2016-02-16 Apple Inc. Virtual machine communications
US9069599B2 (en) 2008-06-19 2015-06-30 Servicemesh, Inc. System and method for a cloud computing abstraction layer with security zone facilities
JP5628799B2 (en) 2008-07-11 2014-11-19 バークレイズ・キャピタル・インコーポレーテッド Personal information file management tool
US20100017801A1 (en) 2008-07-18 2010-01-21 Vmware, Inc. Profile based creation of virtual machines in a virtualization environment
JP5222651B2 (en) 2008-07-30 2013-06-26 株式会社日立製作所 Virtual computer system and control method of virtual computer system
US8102781B2 (en) 2008-07-31 2012-01-24 Cisco Technology, Inc. Dynamic distribution of virtual machines in a communication network
US8185442B2 (en) 2008-08-25 2012-05-22 Oracle International Corporation Extensible attributes model for business applications
US8065714B2 (en) 2008-09-12 2011-11-22 Hytrust, Inc. Methods and systems for securely managing virtualization platform
GB0819985D0 (en) 2008-10-31 2008-12-10 Intergence Systems Ltd Network visualistion systems
US8250182B2 (en) 2008-11-30 2012-08-21 Red Hat Israel, Ltd. Dynamic loading between a server and a client
US20100161604A1 (en) 2008-12-23 2010-06-24 Nice Systems Ltd Apparatus and method for multimedia content based manipulation
US8966082B2 (en) 2009-02-10 2015-02-24 Novell, Inc. Virtual machine address management
US8340633B1 (en) 2009-04-09 2012-12-25 Mobile Iron, Inc. Mobile activity intelligence
US8261266B2 (en) 2009-04-30 2012-09-04 Microsoft Corporation Deploying a virtual machine having a virtual hardware configuration matching an improved hardware profile with respect to execution of an application
US8751627B2 (en) 2009-05-05 2014-06-10 Accenture Global Services Limited Method and system for application migration in a cloud
US20100318609A1 (en) 2009-06-15 2010-12-16 Microsoft Corporation Bridging enterprise networks into cloud
US8234377B2 (en) 2009-07-22 2012-07-31 Amazon Technologies, Inc. Dynamically migrating computer networks
US8850423B2 (en) 2009-10-29 2014-09-30 International Business Machines Corporation Assisting server migration
US9552497B2 (en) 2009-11-10 2017-01-24 Mcafee, Inc. System and method for preventing data loss using virtual machine wrapped applications
US8392497B2 (en) 2009-11-25 2013-03-05 Framehawk, LLC Systems and algorithm for interfacing with a virtualized computing service over a network using a lightweight client
US8627309B2 (en) 2010-02-25 2014-01-07 Microsoft Corporation Automated deployment and servicing of distributed applications
US9626206B2 (en) 2010-03-18 2017-04-18 Microsoft Technology Licensing, Llc Virtual machine homogenization to enable migration across heterogeneous computers
US8396946B1 (en) 2010-03-31 2013-03-12 Amazon Technologies, Inc. Managing integration of external nodes into provided computer networks
US9342373B2 (en) 2010-05-20 2016-05-17 International Business Machines Corporation Virtual machine management among networked servers
EP2583211B1 (en) 2010-06-15 2020-04-15 Oracle International Corporation Virtual computing infrastructure
US8909786B2 (en) 2010-08-26 2014-12-09 Futurewei Technologies, Inc. Method and system for cross-stratum optimization in application-transport networks
JP2014038364A (en) 2010-10-27 2014-02-27 Hitachi Ltd Resource management server, resource management method and resource management program
US9606831B2 (en) 2010-11-30 2017-03-28 Red Hat, Inc. Migrating virtual machine operations
US9043785B1 (en) 2011-05-23 2015-05-26 Open Invention Network, Llc Dynamic consolidation of virtual machines
US8850442B2 (en) 2011-10-27 2014-09-30 Verizon Patent And Licensing Inc. Virtual machine allocation in a computing on-demand system
EP2867771A4 (en) 2012-06-29 2016-06-29 Hewlett Packard Entpr Dev L P Optimizing placement of virtual machines

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20080320123A1 (en) * 2007-06-21 2008-12-25 John Richard Houlihan Process and methodology for generic analysis of metrics related to resource utilization and performance
US20090172666A1 (en) * 2007-12-31 2009-07-02 Netapp, Inc. System and method for automatic storage load balancing in virtual server environments
US20100146503A1 (en) * 2008-12-10 2010-06-10 Institute For Information Industry Scheduler of virtual machine module, scheduling method therefor, and device containing computer software
US20100269109A1 (en) * 2009-04-17 2010-10-21 John Cartales Methods and Systems for Evaluating Historical Metrics in Selecting a Physical Host for Execution of a Virtual Machine
US20100293544A1 (en) * 2009-05-13 2010-11-18 Verizon Patent And Licensing Inc. Integrated virtual and physical resource provisioning system
US20110225277A1 (en) * 2010-03-11 2011-09-15 International Business Machines Corporation Placement of virtual machines based on server cost and network cost

Cited By (186)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11467883B2 (en) 2004-03-13 2022-10-11 Iii Holdings 12, Llc Co-allocating a reservation spanning different compute resources types
US11960937B2 (en) 2004-03-13 2024-04-16 Iii Holdings 12, Llc System and method for an optimizing reservation in time of compute resources based on prioritization function and reservation policy parameter
US11652706B2 (en) 2004-06-18 2023-05-16 Iii Holdings 12, Llc System and method for providing dynamic provisioning within a compute environment
US11630704B2 (en) 2004-08-20 2023-04-18 Iii Holdings 12, Llc System and method for a workload management and scheduling module to manage access to a compute environment according to local and non-local user identity information
US11709709B2 (en) 2004-11-08 2023-07-25 Iii Holdings 12, Llc System and method of providing system jobs within a compute environment
US11656907B2 (en) 2004-11-08 2023-05-23 Iii Holdings 12, Llc System and method of providing system jobs within a compute environment
US11494235B2 (en) 2004-11-08 2022-11-08 Iii Holdings 12, Llc System and method of providing system jobs within a compute environment
US11762694B2 (en) 2004-11-08 2023-09-19 Iii Holdings 12, Llc System and method of providing system jobs within a compute environment
US11861404B2 (en) 2004-11-08 2024-01-02 Iii Holdings 12, Llc System and method of providing system jobs within a compute environment
US11537434B2 (en) 2004-11-08 2022-12-27 Iii Holdings 12, Llc System and method of providing system jobs within a compute environment
US11886915B2 (en) 2004-11-08 2024-01-30 Iii Holdings 12, Llc System and method of providing system jobs within a compute environment
US11537435B2 (en) 2004-11-08 2022-12-27 Iii Holdings 12, Llc System and method of providing system jobs within a compute environment
US11658916B2 (en) 2005-03-16 2023-05-23 Iii Holdings 12, Llc Simple integration of an on-demand compute environment
US11496415B2 (en) 2005-04-07 2022-11-08 Iii Holdings 12, Llc On-demand access to compute resources
US11765101B2 (en) 2005-04-07 2023-09-19 Iii Holdings 12, Llc On-demand access to compute resources
US11533274B2 (en) 2005-04-07 2022-12-20 Iii Holdings 12, Llc On-demand access to compute resources
US11831564B2 (en) 2005-04-07 2023-11-28 Iii Holdings 12, Llc On-demand access to compute resources
US11522811B2 (en) 2005-04-07 2022-12-06 Iii Holdings 12, Llc On-demand access to compute resources
US11650857B2 (en) 2006-03-16 2023-05-16 Iii Holdings 12, Llc System and method for managing a hybrid computer environment
US11522952B2 (en) 2007-09-24 2022-12-06 The Research Foundation For The State University Of New York Automatic clustering for self-organizing grids
US11436210B2 (en) 2008-09-05 2022-09-06 Commvault Systems, Inc. Classification of virtualization data
US11526304B2 (en) 2009-10-30 2022-12-13 Iii Holdings 2, Llc Memcached server functionality in a cluster of data processing nodes
US11720290B2 (en) 2009-10-30 2023-08-08 Iii Holdings 2, Llc Memcached server functionality in a cluster of data processing nodes
US11449394B2 (en) 2010-06-04 2022-09-20 Commvault Systems, Inc. Failover systems and methods for performing backup operations, including heterogeneous indexing and load balancing of backup and indexing resources
US8856783B2 (en) * 2010-10-12 2014-10-07 Citrix Systems, Inc. Allocating virtual machines according to user-specific virtual machine metrics
US9069438B2 (en) * 2010-10-12 2015-06-30 Citrix Systems, Inc. Allocating virtual machines according to user-specific virtual machine metrics
US20150007180A1 (en) * 2010-10-12 2015-01-01 Citrix Systems, Inc. Allocating virtual machines according to user-specific virtual machine metrics
US20120089980A1 (en) * 2010-10-12 2012-04-12 Richard Sharp Allocating virtual machines according to user-specific virtual machine metrics
US9215142B1 (en) * 2011-04-20 2015-12-15 Dell Software Inc. Community analysis of computing performance
US9069890B2 (en) * 2011-04-20 2015-06-30 Cisco Technology, Inc. Ranking of computing equipment configurations for satisfying requirements of virtualized computing environments based on an overall performance efficiency
US20120272234A1 (en) * 2011-04-20 2012-10-25 Cisco Technology, Inc. Scoring of Computing Equipment for Virtualized Computing Environments
US10423439B1 (en) 2011-05-23 2019-09-24 Open Invention Network Llc Automatic determination of a virtual machine's dependencies on storage virtualization
US10089137B1 (en) * 2011-05-23 2018-10-02 Open Invention Network Llc Automatic determination of a virtual machine's dependencies on storage virtualization
US9575781B1 (en) * 2011-05-23 2017-02-21 Open Invention Network Llc Automatic determination of a virtual machine's dependencies on storage virtualization
US8825863B2 (en) * 2011-09-20 2014-09-02 International Business Machines Corporation Virtual machine placement within a server farm
US20130073730A1 (en) * 2011-09-20 2013-03-21 International Business Machines Corporation Virtual machine placement within a server farm
US10374919B2 (en) 2012-06-20 2019-08-06 Amazon Technologies, Inc. Resource manager
US9531607B1 (en) 2012-06-20 2016-12-27 Amazon Technologies, Inc. Resource manager
US10747755B2 (en) * 2012-12-12 2020-08-18 Sk Planet Co., Ltd. Method for providing immediate result for user input, and apparatus therefor
US20150169673A1 (en) * 2012-12-12 2015-06-18 Sk Planet Co., Ltd. Method for providing immediate result for user input, and apparatus therefor
US9311121B2 (en) 2012-12-21 2016-04-12 Commvault Systems, Inc. Archiving virtual machines in a data storage system
US9684535B2 (en) 2012-12-21 2017-06-20 Commvault Systems, Inc. Archiving virtual machines in a data storage system
US20140181813A1 (en) * 2012-12-21 2014-06-26 Commvault Systems, Inc. Archiving virtual machines in a data storage system
US9740702B2 (en) 2012-12-21 2017-08-22 Commvault Systems, Inc. Systems and methods to identify unprotected virtual machines
US10824464B2 (en) 2012-12-21 2020-11-03 Commvault Systems, Inc. Archiving virtual machines in a data storage system
US9223597B2 (en) * 2012-12-21 2015-12-29 Commvault Systems, Inc. Archiving virtual machines in a data storage system
US11468005B2 (en) 2012-12-21 2022-10-11 Commvault Systems, Inc. Systems and methods to identify unprotected virtual machines
US11544221B2 (en) 2012-12-21 2023-01-03 Commvault Systems, Inc. Systems and methods to identify unprotected virtual machines
US10684883B2 (en) 2012-12-21 2020-06-16 Commvault Systems, Inc. Archiving virtual machines in a data storage system
US10733143B2 (en) 2012-12-21 2020-08-04 Commvault Systems, Inc. Systems and methods to identify unprotected virtual machines
US9965316B2 (en) 2012-12-21 2018-05-08 Commvault Systems, Inc. Archiving virtual machines in a data storage system
US11099886B2 (en) 2012-12-21 2021-08-24 Commvault Systems, Inc. Archiving virtual machines in a data storage system
US9286086B2 (en) 2012-12-21 2016-03-15 Commvault Systems, Inc. Archiving virtual machines in a data storage system
US11188433B2 (en) 2012-12-28 2021-11-30 Iii Holdings 2, Llc System, method and computer readable medium for offloaded computation of distributed application protocols within a cluster of data processing nodes
US11132277B2 (en) * 2012-12-28 2021-09-28 Iii Holdings 2, Llc System and method for continuous low-overhead monitoring of distributed applications running on a cluster of data processing nodes
US10311014B2 (en) 2012-12-28 2019-06-04 Iii Holdings 2, Llc System, method and computer readable medium for offloaded computation of distributed application protocols within a cluster of data processing nodes
US20220114070A1 (en) * 2012-12-28 2022-04-14 Iii Holdings 2, Llc System, Method and Computer Readable Medium for Offloaded Computation of Distributed Application Protocols within a Cluster of Data Processing Nodes
US20140189104A1 (en) * 2012-12-28 2014-07-03 Calxeda, Inc. System And Method For Continuous Low-Overhead Monitoring Of Distributed Applications Running On A Cluster Of Data Processing Nodes
US9977687B2 (en) 2013-01-08 2018-05-22 Commvault Systems, Inc. Virtual server agent load balancing
US10896053B2 (en) 2013-01-08 2021-01-19 Commvault Systems, Inc. Virtual machine load balancing
US11734035B2 (en) 2013-01-08 2023-08-22 Commvault Systems, Inc. Virtual machine load balancing
US9703584B2 (en) 2013-01-08 2017-07-11 Commvault Systems, Inc. Virtual server agent load balancing
US10474483B2 (en) 2013-01-08 2019-11-12 Commvault Systems, Inc. Virtual server agent load balancing
US11922197B2 (en) 2013-01-08 2024-03-05 Commvault Systems, Inc. Virtual server agent load balancing
US20140196033A1 (en) * 2013-01-10 2014-07-10 International Business Machines Corporation System and method for improving memory usage in virtual machines
US20140196049A1 (en) * 2013-01-10 2014-07-10 International Business Machines Corporation System and method for improving memory usage in virtual machines
US9430289B2 (en) * 2013-01-10 2016-08-30 International Business Machines Corporation System and method improving memory usage in virtual machines by releasing additional memory at the cost of increased CPU overhead
US9836328B2 (en) 2013-01-10 2017-12-05 International Business Machines Corporation System and method for improving memory usage in virtual machines at a cost of increasing CPU usage
US9256469B2 (en) * 2013-01-10 2016-02-09 International Business Machines Corporation System and method for improving memory usage in virtual machines
US9495404B2 (en) 2013-01-11 2016-11-15 Commvault Systems, Inc. Systems and methods to process block-level backup for selective file restoration for virtual machines
US10108652B2 (en) 2013-01-11 2018-10-23 Commvault Systems, Inc. Systems and methods to process block-level backup for selective file restoration for virtual machines
US9286110B2 (en) 2013-01-14 2016-03-15 Commvault Systems, Inc. Seamless virtual machine recall in a data storage system
US9489244B2 (en) 2013-01-14 2016-11-08 Commvault Systems, Inc. Seamless virtual machine recall in a data storage system
US9766989B2 (en) 2013-01-14 2017-09-19 Commvault Systems, Inc. Creation of virtual machine placeholders in a data storage system
US9652283B2 (en) 2013-01-14 2017-05-16 Commvault Systems, Inc. Creation of virtual machine placeholders in a data storage system
US20140215073A1 (en) * 2013-01-28 2014-07-31 International Business Machines Corporation Computing optimized virtual machine allocations using equivalence combinations
US9329888B2 (en) * 2013-01-28 2016-05-03 International Business Machines Corporation Computing optimized virtual machine allocations using equivalence combinations
US20140245297A1 (en) * 2013-02-27 2014-08-28 International Business Machines Corporation Managing allocation of hardware resources in a virtualized environment
US9336031B2 (en) * 2013-02-27 2016-05-10 International Business Machines Corporation Managing allocation of hardware resources in a virtualized environment
WO2014159740A1 (en) * 2013-03-13 2014-10-02 Cloubrain, Inc. Feedback system for optimizing the allocation of resources in a data center
US10365940B2 (en) 2013-03-13 2019-07-30 Cloubrain, Inc. Feedback system for optimizing the allocation of resources in a data center
US9471394B2 (en) 2013-03-13 2016-10-18 Cloubrain, Inc. Feedback system for optimizing the allocation of resources in a data center
US9141416B2 (en) 2013-03-15 2015-09-22 Centurylink Intellectual Property Llc Virtualization congestion control framework for modifying execution of applications on virtual machine based on mass congestion indicator in host computing system
US9430259B2 (en) 2013-03-15 2016-08-30 Centurylink Intellectual Property Llc Virtualization congestion control framework for modifying execution of applications on virtual machine based on mass congestion indicator in host computing system
US10572284B2 (en) 2013-03-15 2020-02-25 Centurylink Intellectual Property Llc Virtualization Congestion Control Framework for Modifying Execution of Applications on Virtual Machine Based on Mass Congestion Indicator in Host Computing System
WO2014150715A1 (en) * 2013-03-15 2014-09-25 Centurylink Intellectual Property Llc Virtualization congestion control framework
US9582305B2 (en) 2013-03-15 2017-02-28 Centurylink Intellectual Property Llc Virtualization congestion control framework for modifying execution of applications on virtual machine based on mass congestion indicator in host computing system
US11003475B2 (en) * 2013-04-30 2021-05-11 Splunk Inc. Interface for presenting performance data for hierarchical networked components represented in an expandable visualization of nodes
US11163599B2 (en) 2013-04-30 2021-11-02 Splunk Inc. Determination of performance state of a user-selected parent component in a hierarchical computing environment based on performance states of related child components
US20170302586A1 (en) * 2013-06-28 2017-10-19 Pepperdata, Inc. Systems, methods, and devices for dynamic resource monitoring and allocation in a cluster system
US10389577B2 (en) 2013-08-14 2019-08-20 Centurylink Intellectual Property Llc Ethernet carrier group alarm (CGA)
US11010011B2 (en) 2013-09-12 2021-05-18 Commvault Systems, Inc. File manager integration with virtualization in an information management system with an enhanced storage manager, including user control and storage management of virtual machines
US9939981B2 (en) 2013-09-12 2018-04-10 Commvault Systems, Inc. File manager integration with virtualization in an information management system with an enhanced storage manager, including user control and storage management of virtual machines
US10713076B2 (en) 2013-11-21 2020-07-14 Centurylink Intellectual Property Llc Physical to virtual network transport function abstraction
US9864623B2 (en) 2013-11-21 2018-01-09 Centurylink Intellectual Property Llc Physical to virtual network transport function abstraction
US11321189B2 (en) 2014-04-02 2022-05-03 Commvault Systems, Inc. Information management by a media agent in the absence of communications with a storage manager
US11212159B2 (en) 2014-04-03 2021-12-28 Centurylink Intellectual Property Llc Network functions virtualization interconnection gateway
US10897523B2 (en) 2014-04-03 2021-01-19 Centurylink Intellectual Property Llc System and method for implementing isolated service overlays between provider network service point and customer premises
US10666772B2 (en) 2014-04-03 2020-05-26 Centurylink Intellectual Property Llc System and method for implementing extension of customer LAN at provider network service point
US11381669B2 (en) 2014-04-03 2022-07-05 Centurylink Intellectual Property Llc System and method for implementing extension of customer LAN at provider network service point
US20170171092A1 (en) * 2014-04-08 2017-06-15 AppDynamics, Inc. Network analysis and monitoring tool
US10594584B2 (en) * 2014-04-08 2020-03-17 Cisco Technology, Inc. Network analysis and monitoring tool
US10467119B2 (en) * 2014-06-24 2019-11-05 Vmware, Inc. Data-agnostic adjustment of hard thresholds based on user feedback
US9632905B2 (en) * 2014-06-24 2017-04-25 Vmware, Inc. Data-agnostic adjustment of hard thresholds based on user feedback
US20170255537A1 (en) * 2014-06-24 2017-09-07 Vmware, Inc. Data-agnostic adjustment of hard thresholds based on user feedback
US20150370682A1 (en) * 2014-06-24 2015-12-24 Vmware, Inc. Data-agnostic adjustment of hard thresholds based on user feedback
US11487562B2 (en) * 2014-06-27 2022-11-01 Amazon Technologies, Inc. Rolling resource credits for scheduling of virtual computer resources
US10650057B2 (en) 2014-07-16 2020-05-12 Commvault Systems, Inc. Volume or virtual machine level backup and generating placeholders for virtual machine files
US11625439B2 (en) 2014-07-16 2023-04-11 Commvault Systems, Inc. Volume or virtual machine level backup and generating placeholders for virtual machine files
US10992734B2 (en) 2014-08-13 2021-04-27 Centurylink Intellectual Property Llc Remoting application servers
US10929172B2 (en) 2014-08-15 2021-02-23 Centurylink Intellectual Property Llc Multi-line/multi-state virtualized OAM transponder
US9898318B2 (en) 2014-08-15 2018-02-20 Centurylink Intellectual Property Llc Multi-line/multi-state virtualized OAM transponder
US10613892B2 (en) 2014-08-15 2020-04-07 Centurylink Intellectual Property Llc Multi-line/multi-state virtualized OAM transponder
US10437505B2 (en) 2014-09-22 2019-10-08 Commvault Systems, Inc. Efficiently restoring execution of a backed up virtual machine based on coordination with virtual-machine-file-relocation operations
US9436555B2 (en) 2014-09-22 2016-09-06 Commvault Systems, Inc. Efficient live-mount of a backed up virtual machine in a storage management system
US9996534B2 (en) 2014-09-22 2018-06-12 Commvault Systems, Inc. Efficiently restoring execution of a backed up virtual machine based on coordination with virtual-machine-file-relocation operations
US9928001B2 (en) 2014-09-22 2018-03-27 Commvault Systems, Inc. Efficiently restoring execution of a backed up virtual machine based on coordination with virtual-machine-file-relocation operations
US9710465B2 (en) 2014-09-22 2017-07-18 Commvault Systems, Inc. Efficiently restoring execution of a backed up virtual machine based on coordination with virtual-machine-file-relocation operations
US10048889B2 (en) 2014-09-22 2018-08-14 Commvault Systems, Inc. Efficient live-mount of a backed up virtual machine in a storage management system
US9417968B2 (en) 2014-09-22 2016-08-16 Commvault Systems, Inc. Efficiently restoring execution of a backed up virtual machine based on coordination with virtual-machine-file-relocation operations
US10572468B2 (en) 2014-09-22 2020-02-25 Commvault Systems, Inc. Restoring execution of a backed up virtual machine based on coordination with virtual-machine-file-relocation operations
US10452303B2 (en) 2014-09-22 2019-10-22 Commvault Systems, Inc. Efficient live-mount of a backed up virtual machine in a storage management system
US11416278B2 (en) * 2014-09-23 2022-08-16 Splunk Inc. Presenting hypervisor data for a virtual machine with associated operating system data
US10776209B2 (en) 2014-11-10 2020-09-15 Commvault Systems, Inc. Cross-platform virtual machine backup and replication
US11422709B2 (en) 2014-11-20 2022-08-23 Commvault Systems, Inc. Virtual machine change block tracking
US9983936B2 (en) 2014-11-20 2018-05-29 Commvault Systems, Inc. Virtual machine change block tracking
US9823977B2 (en) 2014-11-20 2017-11-21 Commvault Systems, Inc. Virtual machine change block tracking
US9996287B2 (en) 2014-11-20 2018-06-12 Commvault Systems, Inc. Virtual machine change block tracking
US10509573B2 (en) 2014-11-20 2019-12-17 Commvault Systems, Inc. Virtual machine change block tracking
US10481938B2 (en) 2015-05-06 2019-11-19 Centurylink Intellectual Property Llc System and method for implementing network experience shifting
US11099883B2 (en) 2015-05-06 2021-08-24 Centurylink Intellectual Property Llc System and method for implementing network experience shifting
US10673978B2 (en) 2015-05-06 2020-06-02 Centurylink Intellectual Property Llc Method and system for implementing network experience shifting using shared objects
US11740924B2 (en) 2015-05-06 2023-08-29 Centurylink Intellectual Property Llc System and method for implementing network experience shifting
US11934860B2 (en) 2015-05-06 2024-03-19 Centurylink Intellectual Property Llc System and method for implementing network experience shifting
US11544101B2 (en) 2015-05-06 2023-01-03 Centurylink Intellectual Property Llc System and method for implementing network experience shifting
US10880399B2 (en) 2015-05-06 2020-12-29 Centurylink Intellectual Property Llc Method and system for implementing network experience shifting using shared objects
US10673777B2 (en) 2015-09-28 2020-06-02 Centurylink Intellectual Property Llc Intent-based services orchestration
US9882833B2 (en) 2015-09-28 2018-01-30 Centurylink Intellectual Property Llc Intent-based services orchestration
US10250525B2 (en) 2015-09-28 2019-04-02 Centurylink Intellectual Property Llc Intent-based services orchestration
US10705871B2 (en) 2015-10-06 2020-07-07 Centurylink Intellectual Property Llc Virtual machine-to-port peripheral device driver for implementing communications between virtual machines and client devices
US11442764B2 (en) 2016-01-12 2022-09-13 Kyndryl, Inc. Optimizing the deployment of virtual resources and automating post-deployment actions in a cloud environment
US10387181B2 (en) * 2016-01-12 2019-08-20 International Business Machines Corporation Pre-deployment of particular virtual machines based on performance and due to service popularity and resource cost scores in a cloud environment
US11403125B2 (en) 2016-01-12 2022-08-02 Kyndryl, Inc. Optimizing the deployment of virtual resources and automating post-deployment actions in a cloud environment
US10565067B2 (en) 2016-03-09 2020-02-18 Commvault Systems, Inc. Virtual server cloud file system for virtual machine backup from cloud operations
US10592350B2 (en) 2016-03-09 2020-03-17 Commvault Systems, Inc. Virtual server cloud file system for virtual machine restore to cloud operations
US10747630B2 (en) 2016-09-30 2020-08-18 Commvault Systems, Inc. Heartbeat monitoring of virtual machines for initiating failover operations in a data storage management system, including operations by a master monitor node
US10896104B2 (en) 2016-09-30 2021-01-19 Commvault Systems, Inc. Heartbeat monitoring of virtual machines for initiating failover operations in a data storage management system, using ping monitoring of target virtual machines
US10417102B2 (en) 2016-09-30 2019-09-17 Commvault Systems, Inc. Heartbeat monitoring of virtual machines for initiating failover operations in a data storage management system, including virtual machine distribution logic
US10474548B2 (en) 2016-09-30 2019-11-12 Commvault Systems, Inc. Heartbeat monitoring of virtual machines for initiating failover operations in a data storage management system, using ping monitoring of target virtual machines
US11429499B2 (en) 2016-09-30 2022-08-30 Commvault Systems, Inc. Heartbeat monitoring of virtual machines for initiating failover operations in a data storage management system, including operations by a master monitor node
US10824459B2 (en) 2016-10-25 2020-11-03 Commvault Systems, Inc. Targeted snapshot based on virtual machine location
US11416280B2 (en) 2016-10-25 2022-08-16 Commvault Systems, Inc. Targeted snapshot based on virtual machine location
US10152251B2 (en) 2016-10-25 2018-12-11 Commvault Systems, Inc. Targeted backup of virtual machine
US11934859B2 (en) 2016-10-25 2024-03-19 Commvault Systems, Inc. Targeted snapshot based on virtual machine location
US10162528B2 (en) 2016-10-25 2018-12-25 Commvault Systems, Inc. Targeted snapshot based on virtual machine location
US11436202B2 (en) 2016-11-21 2022-09-06 Commvault Systems, Inc. Cross-platform virtual machine data and memory backup and replication
US10678758B2 (en) 2016-11-21 2020-06-09 Commvault Systems, Inc. Cross-platform virtual machine data and memory backup and replication
US10877851B2 (en) 2017-03-24 2020-12-29 Commvault Systems, Inc. Virtual machine recovery point selection
US10983875B2 (en) 2017-03-24 2021-04-20 Commvault Systems, Inc. Time-based virtual machine reversion
US10896100B2 (en) 2017-03-24 2021-01-19 Commvault Systems, Inc. Buffered virtual machine replication
US11526410B2 (en) 2017-03-24 2022-12-13 Commvault Systems, Inc. Time-based virtual machine reversion
US10474542B2 (en) 2017-03-24 2019-11-12 Commvault Systems, Inc. Time-based virtual machine reversion
US11669414B2 (en) 2017-03-29 2023-06-06 Commvault Systems, Inc. External dynamic virtual machine synchronization
US10387073B2 (en) 2017-03-29 2019-08-20 Commvault Systems, Inc. External dynamic virtual machine synchronization
US11249864B2 (en) 2017-03-29 2022-02-15 Commvault Systems, Inc. External dynamic virtual machine synchronization
US20190158425A1 (en) * 2017-11-21 2019-05-23 International Business Machines Corporation Diagonal scaling of resource allocations and application instances in a distributed computing environment
US10721179B2 (en) 2017-11-21 2020-07-21 International Business Machines Corporation Adaptive resource allocation operations based on historical data in a distributed computing environment
US10635501B2 (en) 2017-11-21 2020-04-28 International Business Machines Corporation Adaptive scaling of workloads in a distributed computing environment
US10893000B2 (en) * 2017-11-21 2021-01-12 International Business Machines Corporation Diagonal scaling of resource allocations and application instances in a distributed computing environment
US10812407B2 (en) 2017-11-21 2020-10-20 International Business Machines Corporation Automatic diagonal scaling of workloads in a distributed computing environment
US10887250B2 (en) 2017-11-21 2021-01-05 International Business Machines Corporation Reducing resource allocations and application instances in diagonal scaling in a distributed computing environment
US10733015B2 (en) 2017-11-21 2020-08-04 International Business Machines Corporation Prioritizing applications for diagonal scaling in a distributed computing environment
US10877928B2 (en) 2018-03-07 2020-12-29 Commvault Systems, Inc. Using utilities injected into cloud-based virtual machines for speeding up virtual machine backup operations
US11550680B2 (en) 2018-12-06 2023-01-10 Commvault Systems, Inc. Assigning backup resources in a data storage management system based on failover of partnered data storage resources
US11467863B2 (en) 2019-01-30 2022-10-11 Commvault Systems, Inc. Cross-hypervisor live mount of backed up virtual machine data
US10768971B2 (en) 2019-01-30 2020-09-08 Commvault Systems, Inc. Cross-hypervisor live mount of backed up virtual machine data
US11947990B2 (en) 2019-01-30 2024-04-02 Commvault Systems, Inc. Cross-hypervisor live-mount of backed up virtual machine data
US10996974B2 (en) 2019-01-30 2021-05-04 Commvault Systems, Inc. Cross-hypervisor live mount of backed up virtual machine data, including management of cache storage for virtual machine data
US11467753B2 (en) 2020-02-14 2022-10-11 Commvault Systems, Inc. On-demand restore of virtual machine data
US11714568B2 (en) 2020-02-14 2023-08-01 Commvault Systems, Inc. On-demand restore of virtual machine data
US11442768B2 (en) 2020-03-12 2022-09-13 Commvault Systems, Inc. Cross-hypervisor live recovery of virtual machines
US11663099B2 (en) 2020-03-26 2023-05-30 Commvault Systems, Inc. Snapshot-based disaster recovery orchestration of virtual machine failover and failback operations
US11748143B2 (en) 2020-05-15 2023-09-05 Commvault Systems, Inc. Live mount of virtual machines in a public cloud computing environment
US11500669B2 (en) 2020-05-15 2022-11-15 Commvault Systems, Inc. Live recovery of virtual machines in a public cloud computing environment
US20210382760A1 (en) * 2020-06-05 2021-12-09 Fujitsu Limited Resource adjustment device, non-transitory computer-readable medium and resource adjustment method
US11656951B2 (en) 2020-10-28 2023-05-23 Commvault Systems, Inc. Data loss vulnerability detection

Also Published As

Publication number Publication date
US9354960B2 (en) 2016-05-31

Similar Documents

Publication Publication Date Title
US9354960B2 (en) Assigning virtual machines to business application service groups based on ranking of the virtual machines
US9495152B2 (en) Automatic baselining of business application service groups comprised of virtual machines
US9727440B2 (en) Automatic simulation of virtual machine performance
US9569330B2 (en) Performing dependency analysis on nodes of a business application service group
US8656219B2 (en) System and method for determination of the root cause of an overall failure of a business application service
US10133607B2 (en) Migration of network entities to a cloud infrastructure
US11165631B1 (en) Identifying a root cause of alerts within virtualized computing environment monitoring system
US10826757B2 (en) Operational analytics in managed networks
CA2998749C (en) Systems and methods for security and risk assessment and testing of applications
US8656009B2 (en) Indicating an impact of a change in state of a node
US8825838B2 (en) Identification of business process application service groups
EP3821337B1 (en) Methods and apparatus for safe and smart distribution of software patches
US9235491B2 (en) Systems and methods for installing, managing, and provisioning applications
US20140096129A1 (en) Systems and methods for installing, managing, and provisioning applications
US10592266B1 (en) Dynamic consolidation of virtual machines
US11256590B1 (en) Agent profiler to monitor activities and performance of software agents
US9317269B2 (en) Systems and methods for installing, managing, and provisioning applications
US9191285B1 (en) Automatic web service monitoring
WO2020180578A1 (en) Breaking down the load time of a web page into coherent components
US8949824B2 (en) Systems and methods for installing, managing, and provisioning applications
US20240073146A1 (en) Transaction-level network policies for online applications
US20230388208A1 (en) Collecting and visualizing health profile data of radio access network components

Legal Events

Date Code Title Description
AS Assignment

Owner name: RED HAT, INC., NORTH CAROLINA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:SUIT, JOHN M.;REEL/FRAME:025540/0276

Effective date: 20101220

STCF Information on status: patent grant

Free format text: PATENTED CASE

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 4TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1551); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 4

FEPP Fee payment procedure

Free format text: MAINTENANCE FEE REMINDER MAILED (ORIGINAL EVENT CODE: REM.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY