1. Field of the Invention
This invention generally relates to a framework for resource configuration management database design. The framework provides structures that can be used as the basis for the persistent storage of data required to enable auto-provisioning systems used in the automated allocation and configuration of computing resources.
2. Background Art
Auto-provisioning systems are intended to alleviate operations personnel of the burden of managing specific, individual computing resources. This is accomplished, in part, by providing standard, selectable resource configurations, and standard tools and procedures for managing the types of resources required to support each computing environment. This approach should decrease the cost of infrastructure management and shorten the time needed for delivery of service.
The workflow processing engine at the core of the auto-provisioning system automates the allocation and configuration of individual resources based on the standard resource configurations selected to meet the requirements of each environment. In order to do this, the processing engine requires a database of the standard resource configurations, as well as the specific resource configuration of each environment and the individual resources available for allocation.
The database design required to fully enable an auto-provisioning system must leverage the concept of standard resource configurations in order to gain the intended benefits. Existing products (e.g. Think Dynamics) have incorporated partial solutions. These products provide the ability to implement workflow-based resource allocation and configuration processes, including the allocation and configuration of individual resource instances. In order to address product shortfalls, the base functionality is sometimes supplemented by the ability for the user to create and execute additional workflows and to incorporate user-defined variables in existing workflow processes.
Known solutions do not fully support a comprehensive, auto-provisioning workflow design. They fail to leverage the concept of standard resource configurations, providing resource selection only at the resource instance level. While the ability to incorporate user-defined processes may extend product functionality, the user of user-defined variables lacks the rigor required for data validation and requires repeated entry of common data by the user, with, among other disadvantages, the inherent risk of error.
An object of this invention is to support fully a comprehensive, auto-provisioning workflow design for the configuration management of computing resources.
Another object of the invention is to define explicitly a set of classifications, referred to as Resource Type, Resource Specification and Resource Instance, and to use these classifications in the design of databases that enable auto- provisioning systems for configuring computing resources.
In order to achieve these, and other, objectives, the present invention provides generalized database tables to implement the classifications of Resource Type, Resource Specification, and Resource Instance, supplemented by individual tables specific to each type of resource, and by the associations and dependencies between them.
More specifically, this invention provides database tables comprising a group of structures including Resource Type, Resource Specification and Resource Instance. The Resource Instance is a representation of an individual computing resource, each Resource Instance relates to a physical or logical instance of one Resource Specification. A Resource Specification is a collection of features and functions of a given resource, belonging to one Resource Type which can have zero, one or more resource instances associated with it. A Resource Type, being the highest level of the Resource Model can have zero, one or many resource specifications associated with it.
The Resource Instance has, related to it, only that which is required to enumerate specific details about the given instance of a resource. So all instances of a given resource will share a common set of features/functions described in its associated Resource Specification. A Resource Specification with zero instances associated with, it in this model, can still be utilized by a provisioning application in designing request for provisioning. This change in data management allows the provisioning application not only to drive direct provisioning requests but also to drive procurement processes when resources are required but not currently available. In this manner, developing environments can incorporate into their provisioning solution designs all resources which are supported by the provisioning engine, not just the ones which are currently on hand. This allows for added efficiencies in procurement (getting only what you need when you need it) and personal management. For example, architects can design the environment to be provisioned and submit it before resources are ordered, build teams are not cabling physical resources, or working with logical resources which are not currently slated for provisioning, etc.
Further benefits and advantages of the invention will become apparent from a consideration of the following detailed description, given with reference to the accompanying drawings, which specify and show preferred embodiments of the invention.
As illustrated in
Resource Type
A Resource Type 12 is a high-level categorization of the set of computing resources supported by the auto-provisioning system. As represented in
In the preferred embodiment of this invention, the following resources and categories are considered without excluding other resources and categories of resources defined by skilled personnel in the field:
A Resource Specification 14 is a more detailed categorization of the set of computing resources within each Resource Type. This level of categorization, illustrated in
Each Resource Specification represents a standard configuration of the type of resource, and includes a predefined statement of specific properties relevant to resources of the same type. For example, within the resource type “server” there may be multiple standard configurations based on number of processors, processor speed, memory size, and other properties.
The Resource Specification may also identify specific associations and dependencies on the resource specification of other resource types. For example, within the resource type “software” there may be a dependency on the server configuration required to run the software. This would be represented by a relationship between specific resource specifications of type “server” and the dependent resource specifications of type “software.”
The dependency between resource specification may also be required at a subtype level. For example, software application packages may have a dependency on a specific operating system. With reference to
In the preferred embodiment of this invention, this is the level at which the selection of computing resource is specified. The auto-provisioning system user identifies the specification of the required computing resource from the set of selectable resource specifications. The allocation and configuration workflow processes then act at the individual resource (i.e., resource instance) level to satisfy the requirement.
The defined resource specifications are also used to drive the dynamic rendering of the user interface, including:
The Resource Instance 16 is a representation of the individual computing resource. With reference to
For example, a resource instance of type “server” 52 would represent a discrete, computing resource comprising processors, memory, etc. Each resource instance of type “software” 54 would represent the installation of that software package on a server resource, having a given set of specific configuration parameters.
Instances of each resource type are allocated to the environment based on the identification of required resource specifications.
The preferred embodiment of the invention, as described above in detail, provides a number of important advantages. For example, this embodiment of the invention enables the use of standard resource configurations in the allocation and configuration of computing resources, and fully enables automated workflow processing and an interactive user interface, including rigorous data validation. In addition, the preferred embodiment of the invention enables the use of common modules/routines in the capture and management of resource-related data and in the execution of automated workflow processing. Also, this embodiment of the invention enables the dynamic rendering of resource configuration choices to reflect the specific type of environment and resources being provisioned.
While it is apparent that the invention herein disclosed is well calculated to fulfill the objects stated above, it will be appreciated that numerous modifications and embodiments may be devised by those skilled in the art, and it is intended that the appended claims cover all such modifications and embodiments as fall within the true spirit and scope of the present invention.