1. Field of the Invention
The present invention relates to computing networks, and more specifically, to provision of management information and requests among management servers within a computing network.
2. Description of Related Art
An enterprise computing network can include multiple servers, networks, and computing devices distributed over a wide geography. Within an organization, an enterprise computing network can connect isolated departmental or workgroup networks into an intracompany network. As a result, computer users within the organization can access some or all available data or computing resources.
As an example, an enterprise computing network may include a data center that implements centralized management of various computing devices or nodes. In many cases, highly specialized systems management software and tools are used to track, monitor, and configured various computer systems and their peripherals. A problem can occur when a management server managing a computing device or node cannot meet requirements of the computing device or node. For example, a computing device may be moved behind a firewall such that communication between the management server and the computing device is dropped. As a result, the management server can no longer perform its management tasks with respect to the computing device. For this and other reasons, it is desired to provide improved systems and techniques for meeting requires of computing devices being managed by management servers.
Provision of management information and requests among management servers within a computing network are disclosed herein. According to an aspect, a method includes determining a requirement of a computing device that cannot be met by a first management server within a computing network. The method may also include communicating a request to a second management server within the computing network to assist with meeting the requirement of the computing device. Further, the method may include providing, to the second management server, access to management information associated with the computing device.
According to another aspect, a method may be implemented at a management server managing a computing device within a computing network. The method may include conducting a management activity with the computing device. Further, the method may include determining performance information that is based on a performance of the computing device in response to the management activity. The method may also include providing the performance information to one or more other management servers within the computing network.
Exemplary systems and methods for provisioning management information and requests among management servers within a computing network in accordance with embodiments of the present invention are disclosed herein. Particularly, described herein is a system including multiple management servers that each manages one or more computing devices or nodes. The management servers and computing devices may be part of an enterprise computing network or other computing network. A management server may determine a requirement of a computing device that cannot be met by the management server. For example, the management server may determine that its communication connection with the computing device has failed. Thus, the management server cannot, at least for the time being, provide the computing device with management and control functionality such as configuration information. In response to determining that the requirement cannot be met, the management server may request that another management server assist with meeting the requirement of the computing device. In addition, access to management information for the computing device may be provided to management servers within the computing network. Continuing the aforementioned example, the other management server may be provided with a request for assistance, and may access management information for assuming responsibility for meeting the requirement of the computing device.
It is noted that systems and methods disclosed herein may be practiced in various embodiments. For example, systems and methods disclosed herein may be implemented with network communications devices, servers, or other computing devices comprising hardware, software, firmware, and combinations thereof
The managed environment may be logically separated into different managed regions 106, each with its own management server 100 for managing local resources within the managed region 106. The network 102 may include other servers for carrying out other network functions. For example, the network 102 may include security servers, file servers, threads servers, name servers, time servers, and the like. Multiple management servers 100 may coordinate activities across the network 102 and permit remote site management and operation. Each management server 100 may serve a gateway machine 108, which in turn can support respective computing devices 104. Each management server 100 may coordinate all activity within its respective managed region 106.
It is noted that single management server 100 may combined the functionality of a server and gateway. References herein to a distinct server and one or more gateways should thus not be taken by way of limitation these elements may be combined into a single platform. For various implementations, more than one management server and/or more than one gateway may be used to balance load of computing devices.
A management server 100 may be the top-level authority over all gateway and computing devices within its respective managed region. The management server may maintain a list of computing devices for keeping track of every computing device in a managed region. This list may contain information for uniquely identifying and managing computing devices including, but not limited to, name, location, machine type, specifications, and the like. The management server may maintain a mapping between a gateway and its computing devices. A gateway 108 may include functions such as, but not limited to, listening for login requests of computing devices, listening for upcall requests of computing devices, and acting as a gateway for invocations on computing devices. A management server and gateway may be any suitable computer running any suitable operating system.
A computing device 104 may be a computer such as a personal computer (e.g., a desktop computer or notebook computer). A computing device 104 may be added to the network 102 in any suitable manner and its information added to a list maintained by a respective management server 100.
In accordance with embodiments of the present invention,
Referring to
In accordance with embodiments of the present invention, a management server may determine that assistance for meeting requirements of a computing device are needed by accessing current or pending diagnostic faults. The diagnostic faults may indicate that the management server needs to go down for maintenance such as, but not limited to, software upgrade. In this case, the computing device may require management from another management server.
In accordance with embodiments of the present disclosure, a management server may require assistance with managing a computing device on the loss of network connectivity to a centralized firmware provisioning server. For example, the management server may be set up to monitor and ensure that the assets, such as the computing device, it manages are maintained with their latest firmware levels. The management server may download firmware from the firmware provisioning server. On the loss of connectivity to the firmware provisioning server, the management server may determine that the requirements of the computing device cannot be met, and in response thereto, the management server may request that another management server assume management of the computing device and its other assets.
The method of
The method of
Referring to
The method of
The method of
The method of
The method of
In accordance with embodiments, a management server may determine whether another management server can establish a communication connection with a computing device in response to determining that assistance is needed for meeting the computing device's requirements. For example, management server 1100 may send a communication to management server 2100 to query whether the management server 2100 can establish a communication connection with the computing device 104. In response to determining that the management server 2100 can establish the communication connection, the management server 1100 can communicate a request to the management server 2100 to meet the requirements of the computing device 104. Management server 1100 may send queries and requests to other management servers if the query or request to management server 2100 is unsuccessful.
Referring to
The method of
The method of
A management server receiving the performance information may analyze the information and use it for changing how it manages computing devices within its managed region 106. For example, the management server may prevent implementing an activity with its computing devices in response to determining that the activity decreases performance of a like computing device. As an example, in response to determining that performance decreases if an activity is implemented, the management server may prevent implementation of the change at its computing devices.
In accordance with embodiments of the present invention, a management server may determine that a specification of one of its managed computing devices is the same or similar to a specification of another computing device managed by another management server. In response to determining that an implemented management action decreases performance at the computing device, the management server may send performance information to the other management server. As a result, the recipient management server may prevent implementation of the activity with its computing devices having the same or similar specification.
In accordance with embodiments of the present invention, a computer network as described herein may be any suitable type of enterprise computing network. As an example, a computer network as disclosed herein may be part of a data center environment. The components of the network may communicate via any suitable communications network, such as the Internet or wireless network. Management servers may communicate via a separate and dedicated communications network. Further, management servers may communicate via a known protocol or a specialized protocol for handling communications among management servers for providing management information and sending requests in accordance with embodiments of the present disclosure.
In accordance with embodiments of the present invention, a management server may request assistance with its managed computing devices based on any reason that may affect management activities. For example, assistance may be requested in response to determining, but not limited to, diminished computing resources of the server, diminished network bandwidth or quality, projected increases in workload during peak times, the like, and combinations thereof. A management server may prioritize various tasks and request assistance based on priority of the tasks. For example, requests for help on higher priority tasks may be sent prior to lower priority tasks.
As will be appreciated by one skilled in the art, aspects of the present invention may be embodied as a system, method or computer program product. Accordingly, aspects of the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to herein as a “circuit,” “module” or “system.” Furthermore, aspects of the present invention may take the form of a computer program product embodied in one or more computer readable medium(s) having computer readable program code embodied thereon.
Any combination of one or more computer readable medium(s) may be utilized. The computer readable medium may be a computer readable signal medium or a computer readable storage medium (including, but not limited to, non-transitory computer readable storage media). A computer readable storage medium may be, for example, but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, or device, or any suitable combination of the foregoing. More specific examples (a non-exhaustive list) of the computer readable storage medium would include the following: an electrical connection having one or more wires, a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an optical fiber, a portable compact disc read-only memory (CD-ROM), an optical storage device, a magnetic storage device, or any suitable combination of the foregoing. In the context of this document, a computer readable storage medium may be any tangible medium that can contain, or store a program for use by or in connection with an instruction execution system, apparatus, or device.
A computer readable signal medium may include a propagated data signal with computer readable program code embodied therein, for example, in baseband or as part of a carrier wave. Such a propagated signal may take any of a variety of forms, including, but not limited to, electro-magnetic, optical, or any suitable combination thereof. A computer readable signal medium may be any computer readable medium that is not a computer readable storage medium and that can communicate, propagate, or transport a program for use by or in connection with an instruction execution system, apparatus, or device.
Program code embodied on a computer readable medium may be transmitted using any appropriate medium, including but not limited to wireless, wireline, optical fiber cable, RF, etc., or any suitable combination of the foregoing.
Computer program code for carrying out operations for aspects of the present invention may be written in any combination of one or more programming languages, including an object oriented programming language such as Java, Smalltalk, C++or the like and conventional procedural programming languages, such as the “C” programming language or similar programming languages. The program code may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter situation scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider).
Aspects of the present invention are described below with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems) and computer program products according to embodiments of the invention. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer program instructions. These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
These computer program instructions may also be stored in a computer readable medium that can direct a computer, other programmable data processing apparatus, or other devices to function in a particular manner, such that the instructions stored in the computer readable medium produce an article of manufacture including instructions which implement the function/act specified in the flowchart and/or block diagram block or blocks.
The computer program instructions may also be loaded onto a computer, other programmable data processing apparatus, or other devices to cause a series of operational steps to be performed on the computer, other programmable apparatus or other devices to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide processes for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
The flowcharts and block diagrams in the Figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods and computer program products according to various embodiments of the present invention. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s). It should also be noted, in some alternative implementations, the functions noted in the block may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts, or combinations of special purpose hardware and computer instructions.
The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the invention. As used herein, the singular forms “a,” “an” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will be further understood that the terms “comprises” and/or “comprising,” when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof.
The corresponding structures, materials, acts, and equivalents of all means or step plus function elements in the claims below are intended to include any structure, material, or act for performing the function in combination with other claimed elements as specifically claimed. The description of the present invention has been presented for purposes of illustration and description, but is not intended to be exhaustive or limited to the invention in the form disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art without departing from the scope and spirit of the invention. The embodiment was chosen and described in order to best explain the principles of the invention and the practical application, and to enable others of ordinary skill in the art to understand the invention for various embodiments with various modifications as are suited to the particular use contemplated.
The descriptions of the various embodiments of the present invention have been presented for purposes of illustration, but are not intended to be exhaustive or limited to the embodiments disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art without departing from the scope and spirit of the described embodiments. The terminology used herein was chosen to best explain the principles of the embodiments, the practical application or technical improvement over technologies found in the marketplace, or to enable others of ordinary skill in the art to understand the embodiments disclosed herein.