Computer systems and related technology affect many aspects of society. Indeed, the computer system's ability to process information has transformed the way we live and work. More recently, computer systems have been coupled to one another and to other electronic devices to form both wired and wireless computer networks over which the computer systems and other electronic devices can transfer electronic data. Accordingly, the performance of many computing tasks is distributed across a number of different computer systems and/or a number of different computing environments. For example, distributed applications can have components at a number of different computer systems.
In some environments, a group of resources is configured in a “cloud”. Often, resources in a data center are grouped and configured into a cloud for use by a customer or other user. As such, cloud computing provides users and enterprises with various capabilities to process and store their data in third-party data centers.
However, managing the lifecycle of a cloud can be a highly technical and complex process. Each user or enterprise may desire to use a different configuration of hardware and software components. Transitioning between different lifecycle states can also cause different hardware and software components to be dependent on one another. If lifecycle management operations related to dependent hardware and software resources are not executed in an appropriate sequence, a resulting cloud may not function as intended. As such, a user or enterprise may be constantly challenged with managing new and evolving component dependencies within their cloud.
Unfortunately, it can be extremely difficult for a user or enterprise to be aware of all possible dependencies between a group of hardware and software components to be utilized in a cloud. Even developers of hardware and/or software components may be aware of only some dependencies for their components. Thus, each time a lifecycle state is changed, (potentially extensive) experimentation may be needed to resolve dependencies and settle on intended cloud functionality. The experimentation can be time consuming resulting in downtime for a user or enterprise.
Examples extend to methods, systems, and computer program products for using declarative configuration data to manage cloud lifecycle. A request to implement a lifecycle management command is received. The lifecycle management command is for transitioning a cloud to a specified lifecycle state.
Aggregate declarative configuration data for the cloud is access. The aggregate declarative configuration data defines configuration for the cloud. The aggregate declarative configuration data includes one or more declared roles and including one or more declared action plans. Each of the one or more role declarations declares one or more interfaces for functions corresponding to one or more lifecycle management commands Each of the one or more functions is associated with an executable scrip. Each of the one or more declared action plans specifies a sequence of execution for implementing a corresponding lifecycle management command.
The aggregate declarative configuration data is referred to to identify an action plan, from among the one or more declared action plans, corresponding to the requested lifecycle management command. The identified action plan specifies a sequence of execution for executing a plurality functions from one or more declared roles to account for dependencies between the plurality of functions. Scripts are executed by cross-referencing each of the plurality of functions in accordance with the specified sequence of execution to transition the cloud to the specified life cycle state.
This summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used as an aid in determining the scope of the claimed subject matter.
Additional features and advantages will be set forth in the description which follows, and in part will be obvious from the description, or may be learned by practice. The features and advantages may be realized and obtained by means of the instruments and combinations particularly pointed out in the appended claims. These and other features and advantages will become more fully apparent from the following description and appended claims, or may be learned by practice as set forth hereinafter.
In order to describe the manner in which the above-recited and other advantages and features can be obtained, a more particular description will be rendered by reference to specific implementations thereof which are illustrated in the appended drawings. Understanding that these drawings depict only some implementations and are not therefore to be considered to be limiting of its scope, implementations will be described and explained with additional specificity and detail through the use of the accompanying drawings in which:
Examples extend to methods, systems, and computer program products for using declarative configuration data to manage cloud lifecycle. A request to implement a lifecycle management command is received. The lifecycle management command is for transitioning a cloud to a specified lifecycle state.
Aggregate declarative configuration data for the cloud is access. The aggregate declarative configuration data defines configuration for the cloud. The aggregate declarative configuration data includes one or more declared roles and including one or more declared action plans. Each of the one or more role declarations declares one or more interfaces for functions corresponding to one or more lifecycle management commands Each of the one or more functions is associated with an executable script. Each of the one or more declared action plans specifies a sequence of execution for implementing a corresponding lifecycle management command.
The aggregate declarative configuration data is referred to to identify an action plan, from among the one or more declared action plans, corresponding to the requested lifecycle management command. The identified action plan specifies a sequence of execution for executing a plurality functions from one or more declared roles to account for dependencies between the plurality of functions. Scripts are executed by cross-referencing each of the plurality of functions in accordance with the specified sequence of execution to transition the cloud to the specified life cycle state.
Implementations may comprise or utilize a special purpose or general-purpose computer including computer hardware, such as, for example, one or more processors (including Central Processing Units (CPUs) and/or Graphical Processing Units (GPUs)) and system memory, as discussed in greater detail below. Implementations also include physical and other computer-readable media for carrying or storing computer-executable instructions and/or data structures. Such computer-readable media can be any available media that can be accessed by a general purpose or special purpose computer system. Computer-readable media that store computer-executable instructions are computer storage media (devices). Computer-readable media that carry computer-executable instructions are transmission media. Thus, by way of example, and not limitation, implementations of can comprise at least two distinctly different kinds of computer-readable media: computer storage media (devices) and transmission media.
Computer storage media (devices) includes RAM, ROM, EEPROM, CD-ROM, solid state drives (“SSDs”) (e.g., based on RAM), Flash memory, phase-change memory (“PCM”), other types of memory, other optical disk storage, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store desired program code means in the form of computer-executable instructions or data structures and which can be accessed by a general purpose or special purpose computer.
A “network” is defined as one or more data links that enable the transport of electronic data between computer systems and/or modules and/or other electronic devices. When information is transferred or provided over a network or another communications connection (either hardwired, wireless, or a combination of hardwired or wireless) to a computer, the computer properly views the connection as a transmission medium. Transmissions media can include a network and/or data links which can be used to carry desired program code means in the form of computer-executable instructions or data structures and which can be accessed by a general purpose or special purpose computer. Combinations of the above should also be included within the scope of computer-readable media.
Further, upon reaching various computer system components, program code means in the form of computer-executable instructions or data structures can be transferred automatically from transmission media to computer storage media (devices) (or vice versa). For example, computer-executable instructions or data structures received over a network or data link can be buffered in RAM within a network interface module (e.g., a “NIC”), and then eventually transferred to computer system RAM and/or to less volatile computer storage media (devices) at a computer system. Thus, it should be understood that computer storage media (devices) can be included in computer system components that also (or even primarily) utilize transmission media.
Computer-executable instructions comprise, for example, instructions and data which, in response to execution at a processor, cause a general purpose computer, special purpose computer, or special purpose processing device to perform a certain function or group of functions. The computer executable instructions may be, for example, binaries, intermediate format instructions such as assembly language, or even source code. Although the subject matter has been described in language specific to structural features and/or methodological acts, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to the described features or acts described above. Rather, the described features and acts are disclosed as example forms of implementing the claims.
Those skilled in the art will appreciate that the described aspects may be practiced in network computing environments with many types of computer system configurations, including, personal computers, desktop computers, laptop computers, message processors, hand-held devices, wearable devices, multicore processor systems, multi-processor systems, microprocessor-based or programmable consumer electronics, network PCs, minicomputers, mainframe computers, mobile telephones, PDAs, tablets, pagers, watches, fitness monitors, eye glasses, routers, switches, and the like. The described aspects may also be practiced in distributed system environments where local and remote computer systems, which are linked (either by hardwired data links, wireless data links, or by a combination of hardwired and wireless data links) through a network, both perform tasks. In a distributed system environment, program modules may be located in both local and remote memory storage devices.
The described aspects can also be implemented in cloud computing environments. In this description and the following claims, “cloud computing” is defined as a model for enabling on-demand network access to a shared pool of configurable computing resources. For example, cloud computing can be employed in the marketplace to offer ubiquitous and convenient on-demand access to the shared pool of configurable computing resources (e.g., compute resources, networking resources, and storage resources). The shared pool of configurable computing resources can be provisioned via virtualization and released with low effort or service provider interaction, and then scaled accordingly.
A cloud computing model can be composed of various characteristics such as, for example, on-demand self-service, broad network access, resource pooling, rapid elasticity, measured service, and so forth. A cloud computing model can also expose various service models, such as, for example, Software as a Service (“SaaS”), Platform as a Service (“PaaS”), and Infrastructure as a Service (“IaaS”). A cloud computing model can also be deployed using different deployment models such as private cloud, community cloud, public cloud, hybrid cloud, and so forth. In this description and in the following claims, a “cloud computing environment” is an environment in which cloud computing is employed.
In this description and the following claims, a “hybrid cloud” is defined as composition of two or more clouds (e.g., private, community or public) that remain distinct entities but are bound together, offering the benefits of multiple deployment models. A hybrid cloud service can cross isolation and provider boundaries, allowing extension of the capacity and/or the capability of one cloud service, by aggregation, integration, or customization with another cloud service.
In one aspect, a hybrid cloud includes a private cloud and a public cloud. An entity can configure the private cloud on compute resources, networking resources, and storage resources owned by the entity. The entity can also configure a public cloud on public compute resources, networking resources, and storage resources owned by 3rd party. In one aspect, the public cloud is configured essentially on demand, in anticipation of or when workloads within the private cloud exceed allocated resource capabilities. The private cloud and public cloud can be configured using the same cloud stack so that workloads can be easily transitioned from the private cloud and the public cloud and vice versa.
In this description and in the following claims, a “workflow” is defined as an orchestrated and repeatable pattern of (e.g., computing) activity, such as, for example, a sequence of operations.
In this description and in the following claims, a “workflow definition” is defined as the definition of a workflow. In one aspect, a script is an example of a workflow definition.
Aspects of the invention include a declarative language for cloud computing. The declarative language can be used to declare physical and logical topology as well as cloud lifecycle commands at multiple topology hierarchies. Developers of different cloud components can declare roles and cloud operations in compliance with a declaration model. Accordingly, functionality to implement any of plurality of different cloud lifecycle commands can be consolidated within declarative configuration data.
Compliance with the declaration model allows aggregation and cross-referencing among commands and topology elements declared by different developers. Compliance with the declaration model also facilitates interoperability with a lifecycle state manager for declarations made by different developers. As such, dependencies between components can be efficiently identified and accounted for when implementing cloud operation commands.
Further, declarative configuration data can be used to onboard additional components to a cloud without code changes to an underlying lifecycle state manager.
In one aspect, a lifecycle state manager is a set of software services that provide lifecycle management capabilities for a cloud stack. The lifecycle state manager allows users to specify an intended topology and components of the end state of a cloud deployment. The lifecycle state manager orchestrates lifecycle management commands for cloud infrastructure.
As described, functionality for a plurality of different lifecycle management commands can be consolidated within declarative configuration data. Lifecycle management commands can include but are not limited to: deployment of a cloud, configure services and/or components in a cloud, patch a cloud, update a cloud, scale-out a cloud, scale-in a cloud, startup up a cloud, shutdown of a cloud, build the package of a given cloud component, backup services and/or components in a cloud, restore services and/or components in a cloud, validate services and/or components in a cloud, check prerequisites for services and/or components in a cloud, automate Field Replacement Unit (FRU) process, etc.
One or more lifecycle management commands can be performed to transition a cloud to a desired state. For example, to transition to a cloud to a deployed state, prerequisites for one or more services and/or components can be checked, the one or more services and/or components can deployed, and the one or more services and/or components can be configured. Cloud states can include, but are not limited to: deployed, started, stopped, validated, shutdown, scaled out, configured, and updated.
Cloud infrastructure 101 includes computer resources 106, storage resources 107, and network resources 108. Computer resources 106, storage resources 107, and network resources 108 can be physically located in one or more data centers. In one aspect, entity 104 owns cloud infrastructure 101. In another aspect, some other entity owns cloud infrastructure 101.
Entities can send lifecycle commands to cloud infrastructure 101 requesting instances of a cloud within cloud infrastructure 101. The entities can be associated with or separate from the owner of cloud infrastructure 101. In response, one or more entity created clouds, including cloud 103 (e.g., a private cloud portion or a public cloud portion of a hybrid cloud), can be instantiated within cloud infrastructure 101. Portions of compute resources 106, storage resources 107, and network resources 108 can be allocated for each cloud. For example, compute resources 106A and 106D, storage resources 107B, and network resources 108B can allocated for cloud 103.
Software components can be run on clouds instantiated within cloud infrastructure 101. For example, software components from among software components 112, including software component 112B, can be running on cloud 103.
As depicted, cloud 103 includes lifecycle state manager 102. In general, lifecycle state manager 102 is configured to receive lifecycle management commands. In response to the lifecycle management commands, lifecycle state manager 102 can refer to aggregate declarative configuration data to determine how to implement the lifecycle management commands within cloud 103.
Scripts 111 includes scripts 111A, 111B, etc. Each of scripts 111 can define a workflow for computing activity to perform, for example, within cloud infrastructure 101. Other types of workflow definitions can also be utilized to define workflows for computing activity.
Method 200 includes receiving a request to implement a lifecycle management command to transition a cloud to a specified lifecycle state (201). For example, lifecycle state manager 102 can receive lifecycle management command 109 from entity 104. Lifecycle management command 109 can be a request to transition cloud 103 to lifecycle state 192. Cloud 103 may be in state 191 when lifecycle management command 109 is received. As such, lifecycle management command 109 is essentially a request to transition cloud 103 from state 191 (e.g., shutdown) to state 192 (e.g., deployed)
Method 200 includes accessing aggregate declarative configuration data defining configuration for the cloud, the aggregate declarative configuration data including one or more declared roles and including one or more declared action plans, each of the one or more role declarations declaring one or more interfaces for functions corresponding to one or more lifecycle management commands, each of the one or more functions associated with an executable script, each of the one or more declared action plans specifying a sequence of execution for implementing a corresponding lifecycle management command (202). For example, lifecycle state manager 102 can access aggregate configuration data 121. Aggregate configuration data 121 can define configuration for cloud 103. Aggregate configuration data 121 includes roles 122 and action plans 132. Roles 122 includes role 122A, role 122B, etc. Action plans 132 includes actions plans 132A, 132B, etc.
Each of roles 122 is useable in cloud 103 and includes one or more interfaces for functions corresponding to one or more lifecycle management commands. For example, role 122A includes interface 123A and script reference 124A, interface 126A and script reference 127A, etc. Similarly, role 122B includes interface 123B and script reference 124B, interface 126B and script reference 127B, etc. Script references refer to scripts that can be executed to implement functions corresponding to lifecycle management commands. In one aspect, one or more different lifecycle management commands use the same interfaces. As such, the one or more different lifecycle management commands can refer to at least some of the same scripts.
Each of action plans 132 can include a sequence of execution for implementing a corresponding lifecycle management command through reference to at least one interface in at least one declared role. For example, action plan 132A includes command type 133A and sequence 134A. Command type 133A corresponds to a specified type of lifecycle management command Sequence 134A defines a sequence of execution for executing interface types 136A, 137A, etc. to implement the specified type of lifecycle management command in cloud 103. Similarly, action plan 132B includes command type 133B and sequence 134B. Command type 133A corresponds to another specified type of lifecycle management command Sequence 134B defines a sequence of execution for executing interface types 136B, 137B, etc. to implement the other specified type of lifecycle management command in cloud 103.
Method 200 includes referring to the aggregate declarative configuration data to identify an action plan, from among the one or more declared action plans, corresponding to the requested lifecycle management command, the identified action plan specifying a sequence of execution for executing a plurality functions from one or more declared roles to account for dependencies between the plurality of function (203). For example, lifecycle state manager 102 can refer to aggregate configuration data 121 to identify action plan 132B corresponding to lifecycle management command 109. As depicted, action plan 132B specifies sequence 134B for executing functions from one or more of roles 122. Sequence 134B specifies an order of execution that accounts for dependencies between components associated with the functions indicated in sequence 134B.
Method 200 includes executing scripts (or other workflow definition) by cross-referencing each of the plurality of functions in accordance with the specified sequence of execution to transition the cloud to the specified life cycle state (204). For example, in accordance with sequence 134B, lifecycle state manager 102 can execute script 111C. Lifecycle state manager 102 can locate script 111C by cross-referencing interface type 136B to interface 123B and using script reference 124B to script 111C. Next, in accordance with sequence 134B, lifecycle state manager 102 can execute script 111A. Lifecycle state manager 102 can locate script 111A by cross-referencing interface type 137B to interface 126A and using script reference 127A to script 111A.
Additional scripts can be located and executed in accordance with sequence 134B. Sequence 134B can include executing at least some scripts in parallel with one another (e.g., when the results of scripts do not depend on one another). Due to dependencies, other scripts can be executed serially.
Implementing lifecycle manager command 109 through execution of scripts 111A, 111C, etc. transitions cloud 103 from state 191 to state 192. A state change can include changing hardware resources and/or software resources used in cloud 103. For example, compute resources 106B can be allocated to cloud 103 and compute resources 106A can be deallocated from cloud 103. Network resources 108B can allocated to cloud 103. Software component 112A can be run in cloud 103.
Accordingly, cloud 103 is transitioned from state 191 to state 192 without altering the code of lifecycle state manager 102.
In one aspect, aggregate configuration data 121 declares a software defined configuration for a portion of networking resources 108 and/or declares a software defined configuration for a portion of storage resources 107.
Aggregate configuration data 121 can also declare complete physical and logical topology declarations for cloud 103.
Role 311 is a role for storage. Role 311 includes private information 312, public information 313, and interfaces 314. Private information 312 can be configuration information that is private to the developer of role 311 (and is unlikely to vary between different instances of role 311). Public information 313 can be configuration information that is modifiable by an entity using role 311 in a cloud. Public information 313 can modified by an entity to tailor role 311 for use in a particular cloud infrastructure. Each of interfaces 313 include an interface type, a function, and a module (script reference).
As described, role 301 and 311 can be included in aggregate declarative configuration data for a cloud. Roles 311 can be developed by different developers and can also be stored in different locations and/or files. For example, role 301 can be declared by machine developer and role 311 can be declared by a storage developer. However, the different developers can declare roles 301 and 311 in compliance with a declaration model. Compliance with the declaration model allows action plans to appropriately access interface types declared within roles even when the roles are declared by different developers.
Private information in a role can include a variety of different information including but not limited to: execution context, default gateways, account information, login credentials, timeout values, storage pool names, directory paths, certificate names, certificate authorities, etc. Private information can be role specific. A script referenced within a role can refer to private information in the role during execution to implement an interface type. For example, the script referenced in interface type 314A can refer to private information 313. However, scripts referenced in other roles (e.g., role 301) may not access private information 313.
Public information in a role can also include a variety of different information including but not limited to: network addresses, stock keeping units (SKUs), cluster names, file server names, time servers, account quotas, Domain Name Services (DNS) information, port mappings, installation features, instance names, etc. A script referenced within a role can refer to public information in the role or public information in other roles during execution to implement an interface type. For example, the script referenced in interface type 314A can refer to public information 312. Script referenced in other roles (e.g., role 301) can also access public information 312.
Each step in steps 322 can cross-reference an interface type of a role. For example, step 343 cross-references a “Startup” interface type 314A for Storage. Referring back to
In general, action plan 321 can followed to transition a cloud to a “startedup” state.
In one aspect, one entity can extend aggregate declarative configuration of another entity.
Entity 401 can be data center provider that allocates compute, storage, and network resources to customers. Entity 401 can create aggregate configuration data 421 declaring roles 422 and action plans 423. Customers can use aggregate configuration data 421 to transition lifecycle states using compute, storage, and network resources of entity 401. For example, customers 402 and 403 can use aggregate configuration data 421 to implement lifecycle transitions 414 within clouds 412 and 413 respectively.
Entity 411 can be another provider that provides specialized storage solutions for customers. Entity 411 can extend aggregate configuration data 421 into aggregate configuration data 431. Extending aggregate configuration data 421 can include declaring at least one additional role in roles 422 and modifying at least one action plan in action plans 433 to cross-reference the additional role. Extending aggregate configuration data 421 can also include modifying a declared role in roles 432.
Accordingly, entity 411 can modify roles 422 into roles 432. Roles 432 can include roles tailored to the specialized storage solutions of entity 411. Entity 411 can also modify action plans 423 into action plans 433. Action plans 433 can be tailored to cross-reference interface types in roles 432 to implement specialized storage solutions of entity 411.
Customers can use aggregate configuration data 431 to transition lifecycle states using compute, storage, and network resources of entity 411. For example, customers 441 and 441 can use aggregate configuration data 422 to implement lifecycle transitions 454 within clouds 451 and 452 respectively.
Both entity 401 and entity 411 can declare roles and action plans in compliance with a declaration model. Compliance with the declaration model allows action plans to appropriately access interface types declared within a role.
In one aspect, a system includes a processor, system memory, storage resources, and a lifecycle state manager. The lifecycle state manager can use the processor to receive a request to implement a lifecycle management command to transition a cloud to a specified lifecycle state.
The lifecycle state manager can use the processor to access aggregate declarative configuration data defining configuration for the cloud. The aggregate declarative configuration data includes one or more declared roles and includes one or more declared action plans. Each of the one or more role declarations declares one or more interfaces for functions corresponding to one or more lifecycle management commands Each of the one or more functions is associated with an executable script. Each of the one or more declared action plans specifies a sequence of execution for implementing a corresponding lifecycle management command.
The lifecycle state manager can use the processor to refer to the aggregate declarative configuration data to identify an action plan, from among the one or more declared action plans, corresponding to the requested lifecycle management command. The identified action plan specifies a sequence of execution for executing a plurality functions from one or more declared roles to account for dependencies between the plurality of functions. The lifecycle state manager can use the processor to execute scripts by cross-referencing each of the plurality of functions in accordance with the specified sequence of execution to transition the cloud to the specified life cycle state.
In another aspect, a method for transitioning cloud lifescycle state is performed. A request to implement a lifecycle management command is received. The lifecycle management command is to transition a cloud to a specified lifecycle state.
Aggregate declarative configuration data defining configuration for the cloud is accessed. The aggregate declarative configuration data includes one or more declared roles and includes one or more declared action plans. Each of the one or more role declarations declares one or more interfaces for functions corresponding to one or more lifecycle management commands Each of the one or more functions is associated with an executable script. Each of the one or more declared action plans specifies a sequence of execution for implementing a corresponding lifecycle management command.
The aggregate declarative configuration data is referred to to identify an action plan, from among the one or more declared action plans, corresponding to the requested lifecycle management command. The identified action plan specifies a sequence of execution for executing a plurality functions from one or more declared roles to account for dependencies between the plurality of functions. Scripts are executed by cross-referencing each of the plurality of functions in accordance with the specified sequence of execution to transition the cloud to the specified life cycle state.
In a further aspect, a computer program product for use at a computer system includes one or more computer storage devices having stored thereon computer-executable instructions that, in response to execution at a processor, cause the computer system to implement a method for transitioning cloud lifescycle state.
The computer program product includes computer-executable instructions that, in response to execution at a processor, cause the computer system to receive a request to receive a request to implement a lifecycle management command to transition a cloud to a specified lifecycle state.
The computer program product includes computer-executable instructions that, in response to execution at a processor, cause the computer system to receive a request to access aggregate declarative configuration data defining configuration for the cloud. The aggregate declarative configuration data includes one or more declared roles and includes one or more declared action plans. Each of the one or more role declarations declares one or more interfaces for functions corresponding to one or more lifecycle management commands Each of the one or more functions is associated with an executable script. Each of the one or more declared action plans specifies a sequence of execution for implementing a corresponding lifecycle management command.
The computer program product includes computer-executable instructions that, in response to execution at a processor, cause the computer system to refer to the aggregate declarative configuration data to identify an action plan, from among the one or more declared action plans, corresponding to the requested lifecycle management command. The identified action plan specifies a sequence of execution for executing a plurality functions from one or more declared roles to account for dependencies between the plurality of functions. The computer program product includes computer-executable instructions that, in response to execution at a processor, cause the computer system to execute scripts by cross-referencing each of the plurality of functions in accordance with the specified sequence of execution to transition the cloud to the specified life cycle state.
The present described aspects may be implemented in other specific forms without departing from its spirit or essential characteristics. The described aspects are to be considered in all respects only as illustrative and not restrictive. The scope is, therefore, indicated by the appended claims rather than by the foregoing description. All changes which come within the meaning and range of equivalency of the claims are to be embraced within their scope.
This application claims the benefit of U.S. Provisional Patent Application Ser. No. 62/267,263, entitled “USING DECLARATIVE CONFIGURATION DATA TO IMPLEMENT CLOUD OPERATIONS”, filed Dec. 14, 2015, which is incorporated herein in its entirety.
Number | Date | Country | |
---|---|---|---|
62267263 | Dec 2015 | US |