Cloud computing refers to the delivery of scalable and pooled computing, storage and networking capacity as a service to a network of end-recipients. The name comes from the use of clouds as an abstraction for the complex infrastructure of networks and associated hardware operative within the cloud. Cloud computing provides services for a user's data, software and computation over a network, for example. Such computing capability relies on sharing of resources to achieve coherence and economies of scale similar to a utility (like the electricity grid) over a network (typically the Internet). Applications deployed on resources supporting the cloud presently often have to be manually deployed and that consumes considerable administrative time. The manual steps of deploying the application include the provisioning and instantiation of the infrastructure. This requires linking the installation of the application or deployment of an image to the full knowledge of the deployed infrastructure. Manual deployment typically requires numerous sequences of steps usually launched by the user who attempts to deploy the application.
After such matching of resources (e.g., an absolute or closest match) to application requirements, then the components of the application 110 can be deployed on the cloud 130 (or non-cloud local execution environment). Infrastructure capabilities of the cloud 130 can be determined via resource offerings and metadata 160 associated with the cloud. For instance, a plurality of service providers supporting the cloud 130 can provide files that specify what types of resources they have available and metadata that describe properties of interest for the respective resource offerings (e.g., resource offering of three servers available with metadata specifying memory size and processor speeds, load (if already instantiated), location, tenancy terms, service level agreements (SLAs), scheduled maintenances, and so forth).
A test manager 170 is provided to configure and launch a test suite of application deployments for the given application 110 via the deployment manager. The test manager 170 can configure a plurality of tests associated to a plurality of different operational deployment scenarios for the application 110. The configuration and resultant application deployments can be administered across organizational boundaries to suit various organizational needs. For example, development may have one set of needs and production may have a separate set of needs. In some cases, public deployments for the application are configured and launched and in other cases, private deployments are launched such as shown via local testing and storage 180. In other cases, a combination of public and private deployments are launched as configured by the test manager 170 and deployed via the deployment manager 120.
The test manager 170 enables automated development testing, development for operations, and application security development, for example, based on determining best matching infrastructure by matching of application models 140 and policies 150 to infrastructure models as specified by the resource offerings and metadata 160. Application models 140 can be specified for specific deployments or tests. When selecting which model to use, this can be achieved via selecting from different models in a set of models or via matching of a label associated to different model types specified in policy, for example. The matching infrastructure can then be employed to test or facilitate production staging while also running various test suites and at different stages of testing (and/or monitoring at production stages). For development testing, the test manager 170 allows developers to follow development of any software with tests in the cloud 130 where they can deploy and run the software in multiple deployment scenarios and execute target test cases without the usual delays and cost to setup deployment and test. After developing and testing of software elements (e.g., applications components), they can then be deployed and operated in production (and monitored similarly). This enables also testing security aspects of the application 110 since security can also be tested in a secure development and production environment such as on the local testing and storage 180. Feedback of bugs, security breaches and other detected events can be easily monitored and fed back (e.g., via monitor components and listeners) to development agents such as for diagnostics and repair. When problems are reported in production, the deployment conditions and context can be reproduced with a bug/problem report for developers (or support) to diagnose and correct) which can then lead to test and patch/updates which can then be staged and/or tested.
The test manager 170 and deployment manager 120 can be employed to automate testing in accordance with a user interface (UI) (e.g., See
The test manager 170 provides a centralized application management platform for managing and automating within and across application teams and throughout the complete process of developing an application, all within a single workflow. The test manager 170 can support the stakeholders responsible for delivering applications as they progress through their lifecycle. It focuses on the core lifecycle from design through readiness for delivery to operations. This can include requirements management, test planning and functional testing, performance testing, developer management, and defect management. Such application lifecycle activities can be connected together from a workflow perspective with a common management console, layer of project tracking and planning, and built on a common software foundation containing a consistent repository and open integration architecture with a supported software development kit (SDK).
As will be described below with respect to
Using the test manager 170, specified application requirements guide the development of the applications. Application developers and the specified requirements can be stored in memory to guide the setup of test cases and test suites. These are defined in terms configurations, deployments and usage scenarios, for example. The different test cases and scenarios can be captured as applications models 140 and policies 150. Representative deployments can be captured as infrastructure templates. Test suites can be run automatically in target configurations at the push of a button (e.g., via web site that points to templates, models, policies, artifacts and executes the code). Periodically or after changes have occurred with the application, or via manual or scheduled changes, such changes can be automated via the test manager 170, such as calling APIs to pass new artifacts and run the tests. Security tests may also test or enable security challenges at various steps of development. Development operations can be enabled by changing the policies to migrate to a production environment with a selected or determined deployment.
When an application has been deployed based on the matching, the deployment manager 120 further can manage other aspects of the lifecycle of the application. For example, the deployment manager 120 can monitor feedback, and adjust the infrastructure resources based on such feedback. Additionally or alternatively, the deployment manager 120 can dynamically adjust the application model and corresponding policies based on such feedback or other detected events. Similarly, this can also include retiring older versions of application components (e.g., code, middleware (MW), databases, operating system (OS), and so forth) and installing new versions of components to enable continued deployment of the application in the cloud infrastructure 130.
The cloud 130 can be a hybrid such that it can be a combination of traditional Data Centers that are made to behave like infrastructure resources, private clouds (cloud technology developed on premise), public clouds (offered by service providers and managed cloud configurations (managed on premise or in a public cloud/virtual private cloud). As used herein, the term application applies to a collection of components. In addition, the application can be characterized for each of its components by a set of artifacts (e.g., installer, executable, configurations and so forth, and a set of components that are installed and interact with each other (e.g., code, middleware (MW), databases, operating system (OS), and so forth). Also, as used herein, the term determining can include compiling, enumerating, and matching.
As used herein, the term “substantially” is intended to indicate that while the function or results of the term being modified are a desired or intended result that some variation can result. In this context, for example, the term “substantially match” or variants thereof describes a situation that the resulting analysis and comparison is performed to identify resources that are the same; however, in practice the match can correspond to a set of resources that sufficiently similar to enable deployment (identified above as an absolute or best efforts match). Where more than one such set of resources might correspond to a match, the deployment manager can select a best matching set of available resources. Other approaches for selecting such match can be utilized.
The application model 140 can be employed to characterize a given application 110 for deployment on the cloud infrastructure 130, such as though metadata descriptions for various components of the application. The deployment manager 120 can be implemented via instructions executable or data readable by a processor to analyze an application requirement for the given application 110 based on the application model 140 and a policy 150 (or policies) associated with the given application. As will be described below, the policy 150 can be provided to describe additional operating context for the application 110 (e.g., operate application after midnight, use only east coast servers, maintain load balancing between servers, deploy within a given network domain, ensure load is between specified limits on servers, ensure there are no upcoming maintenances within a given window, and so forth as well techniques to “measure closeness” of the matches). The deployment manager 120 can then determine infrastructure resources in the cloud infrastructure sufficient to fulfill the application requirement of the application 110 as specified by the model 140 and policy 150.
In one example, the deployment manager 120 can automatically deploy the given application 110 on the cloud infrastructure 130 after the matching of application requirements of the application 110 to the capabilities of the cloud as specified by the resource offerings and metadata 160. In this type of example, it usually amounts to executing the instructions of other following examples described below (possibly by calling external systems that manage the lifecycle of the infrastructure and/or of the applications). As used herein, the term “application” (e.g., including the application 110) can include a set of components that are to be installed and executed. Examples of such components include multiple tiered logic, user interface (UI), middleware (MW), database (DB), operating system (OS) in addition to the code to install and configure or uninstall such components. Thus, the application 110 refers to these sets of components and artifacts which can also include repositories of such components and artifacts. The application 110 can also be identified by pointers to the components and artifacts including individual pointers or pointers to a set of components. In another example, the deployment manager 120 can generate instructions to inform a system (or user) on how to deploy the given application 110 on the cloud infrastructure 130. In either example, the deployment manager 120 can automatically match requirements of the application 110 as specified by the model 140 and policy 150 with capabilities of the cloud 130 as specified by the resource offerings and metadata 160.
The system 100 utilizes a policy and model-driven approach to automate deployment as opposed to manual procedures of conventional systems. The system 100 can dynamically (or statically) optimize and bind infrastructure resources (characterized by metadata properties) to applications 110 based on models 140 and policies 150 that characterize their requirements in terms of infrastructure properties. This can include matching application metadata to resource metadata as well as taking into account policies and context to automate optimized or preferred/labeled deployment of applications and their components/dependencies on the cloud 130 without also requiring manual deployment steps. In one example, the system 100 allows tracking of instances while also supporting automated management of such instances (e.g., automated monitoring and feedback described below). Different techniques are provided to ingest, author, and design metadata that can also describe infrastructure templates, application models, and policies. Such instances can be stored in a database or repository (not shown) along with the application 110, application model 140, and policy 150.
The system 100 can employ closed feedback loops (See
The system 100 can be implemented on one or across multiple hardware platforms, wherein the modules in the system can be executed on one or across multiple platforms. Such modules can run on cloud technology (various forms/and hybrid clouds) or offered as a SaaS (Software as a service) that can be implemented on or off the cloud. Complex applications can be automatically deployed on required infrastructure resources without also requiring users to understand how to perform such operations. Policies 150 provide automated instructions for operating guidelines that help administrators mitigate deployment errors. Metadata can also be associated with the application by identifying the type of application (e.g., via UI or API), then the user does not need to understand the application characteristics. This approach allows “best practice”, recommended or imposed deployment models for applications based on their association to metadata.
Policies also allow separating the application characteristics from other contextual considerations (e.g., about user, about application, about infrastructure, about context, about that specific user, about that specific application, and so forth. This facilitates the reuse of the application models across numerous applications. Particularization (e.g., specify a particular set of policies for one application versus another) can also be achieved via policies. This is also how for example the system imposes that a specific set of characteristic values are fixed for a given application or version. For example, the system could apply a generic application model for web applications, yet in another case, explicitly specify a different model or certain values for the attributes of the model. Resources can also be provided from hybrid clouds (e.g., some resources provided from local databases and servers and some resources provided from Internet services).
For purposes of simplification of explanation, in the example of
An application lifecycle manager 224 can include options for designing, modeling, building, and testing application including composite or hybrid applications. A service fulfillment component 230 enables service design composition and fulfillment, application modeling, deployment, and workload management, along with infrastructure design and fulfillment. An application performance module (APM) enables performance testing, analytics, and sizing of the deployed applications. A service operation and bridge component 240 enables event processing, monitoring, analytics, and reporting along with interaction with a real time service model (RTSM) repository. An infrastructure management component 250 provides options for defining/searching system components, network components, and storage components. This includes options for processing/analyzing faults, analyzing application, network, and/or system performance, and providing various configuration interfaces for configuring the options. A resources pane 260 includes options for specifying how applications are to be deployed including options for deployment on public clouds, managed clouds, private clouds, virtual operation, and traditional deployments (e.g., according to a standard deployment scenario).
The interface 200 and associated test manager described herein (e.g., test manager 170 of
Operations developers are also provided full automation for the deployment of applications from development and testing to production. This includes full automation of the life cycle management under operation. Model-based automation enables building and reusing models created from similar applications and/or used at development and testing. This also includes testing of hybrid delivery models including public and/or private cloud deployments and testing as previously described. This can include monitoring the source repository to detect changes and to launch tests automatically. This can also include options for periodic, manual and scheduled testing, as well.
An instance database 334 can be employed to store realized target instances of the application. An application user interface 340 can be employed to design the application and configure metadata for operating the application, whereas an infrastructure user interface 244 can be employed to specify infrastructure requirements for deploying the application in the cloud. Deployment components 350 can include a deployment application programming interface (API) and instructions such as may be specified via a deployment recipe, for example. One or more call-outs 354 can specify customized operating instructions for a given application. Provisioning components 360 can include a provisioning API and plug-ins for interacting with various cloud infrastructure components.
The system 300 can be utilized as a designer tool to build/deploy infrastructure and application templates. It also allows application developers, testers, or other administrators or designers to build application models. Similarly, they can design policies and rules for execution and deployment of an application. Some or all of the infrastructure and application data can be ingested into the repositories shown as database 330 and 340, respectively. Alternatively, such infrastructure or application data can be passed via APIs. Application artifacts (code, executable, installation packages, and the like) can be also ingested or referred to via the databases or API's. The APIs or portal user interfaces 340 and 344 can be used to associate or upload requests to match and deploy while also specifying application templates and policies to use, for example. Such APIs and user interfaces can be implemented as part of a designer tool to define metadata and associate the metadata to infrastructure (e.g., via infrastructure templates and topologies).
Preparation and setup of agent and monitoring tools/can be provided such that applications can discover the instances (which have been instrumented and with agents if needed). This can be achieved via instruction/recipes utilized to deploy infrastructure and application elements after binding the application and its associated components to the infrastructure resources. Events/reports allow closed feedback loops that can be used to scale up/scale out (based on policy) or update context/policies for future changes if allowed by policies as well as notify appropriate parties or systems (See
A computer 480 can operate one or more interfaces 484 to program application models 490 and stored in databases 494. The computer can also interact with the deployment tool 420 to alter deployment and facilitate lifecycle management of applications. The interfaces 484 can also configure infrastructure templates, alter operating requirements, configure the monitor component 470, and interact with events and alerts that are generated within the system 400. As noted previously, along with being executed on the cloud, the deployed application 430 can be spread across unrelated clouds or provided as part of a hybrid application. For example, the deployed application 430 could be executed in part on the cloud infrastructure 440 and in part on the databases 494 which are a different entity (e.g., local server databases versus network databases) than the cloud.
In view of the foregoing structural and functional features described above, an example method will be better appreciated with reference to
The method 500 can be automatically executed as part of a system such as the example depicted in
The resource metadata 760 can be associated to any resource designed or added to the resource pool by the resource design or ingestion process. Metadata describing the applications models and resource offerings can be captured via a designer (e.g., a tool, Portal UI or APIs) to describe the metadata. Metadata including recipes (e.g., corresponding to instructions for deployment and other lifecycle management functions such as un-deployment and monitoring) can constitute resource templates. The resource metadata 760 and the associated resource offerings 750 that are specified by the metadata can be provided as part of a template (e.g., data file of metadata and offerings) that can be utilized by other applications.
The application requirement 740 of the given application can be specified via application metadata 770 that can be defined at or after application design. This can include components to be individually deployed (e.g., multiple applications in multiple tiers). The application metadata 770 can also specify requirements/preferences on resources. This can include generic deployment scripts as workflow or processes (asynchronous or synchronous). The deployment scripts can further include deployment instructions for each component (e.g., script to run on allocated resource, instruction to services, and so forth). This can include associated instructions to deploy agents or prepare for monitoring and/or management. Instructions can be applied across components. In general, the application metadata 770 can represent the application models described above with respect to
As shown, additional policies 780 can be provided that apply to the application/Infrastructure and refer to context for operating an application. For example, a policy may specify a location for an application (e.g., only operate on east coast servers), a time (e.g., operate after midnight and before 6:00 AM), a processing requirement (e.g., processing speed and memory needs specified), and/or a load balancing requirement (e.g., no server is to operate with over 50% load), SLAs, availability requirements (e.g. no scheduled maintenance within next x days etc), security (e.g. a particular network domain or security domain).
Applications can be deployed by the deployment manager 710 by retrieving the associated metadata 770 and matching resource offerings 750 available in the pool of resources based on best match (can be exact labeling if for example imposed by policies). Matching of resource metadata 760 to application metadata 770 can be according to strict specifications (e.g., processors must operate at 1 GHZ) or can be matched according to threshold specification (e.g., any processor operating over 500 MHZ is acceptable). Thus, matching can be absolute matching or can be substantial matching where the matching is best fit or close to the desired match criteria. Recipes can be processed by the deployment manager 710 and refer to the code/artifact to use for application deployments. Such recipes can be made available via a known repository location or referred to via a pointer to the recipe, for example. Topologies of composite resources that correspond to an application can be saved as a new resource type by the deployment manager 710 for reuse when similar application metadata is used by another application, for example. Multiple releases of the same applications or similar applications can reuse the same application metadata but, for example, with different policies to relate to operating context.
What have been described above are examples. It is, of course, not possible to describe every conceivable combination of components or methods, but one of ordinary skill in the art will recognize that many further combinations and permutations are possible. Accordingly, the invention is intended to embrace all such alterations, modifications, and variations that fall within the scope of this application, including the appended claims. Additionally, where the disclosure or claims recite “a,” “an,” “a first,” or “another” element, or the equivalent thereof, it should be interpreted to include one or more than one such element, neither requiring nor excluding two or more such elements. As used herein, the term “includes” means includes but not limited to, and the term “including” means including but not limited to. The term “based on” means based at least in part on.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/US2012/041637 | 6/8/2012 | WO | 00 | 10/9/2014 |