WO2020200427A1 - Technique for simplifying management of a service in a cloud computing environment - Google Patents
Technique for simplifying management of a service in a cloud computing environment Download PDFInfo
- Publication number
- WO2020200427A1 WO2020200427A1 PCT/EP2019/058274 EP2019058274W WO2020200427A1 WO 2020200427 A1 WO2020200427 A1 WO 2020200427A1 EP 2019058274 W EP2019058274 W EP 2019058274W WO 2020200427 A1 WO2020200427 A1 WO 2020200427A1
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- service
- network infrastructure
- aggregated
- aggregation
- resources
- Prior art date
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/46—Multiprogramming arrangements
- G06F9/50—Allocation of resources, e.g. of the central processing unit [CPU]
- G06F9/5061—Partitioning or combining of resources
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/46—Multiprogramming arrangements
- G06F9/50—Allocation of resources, e.g. of the central processing unit [CPU]
- G06F9/5061—Partitioning or combining of resources
- G06F9/5077—Logical partitioning of resources; Management or configuration of virtualized resources
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/46—Multiprogramming arrangements
- G06F9/50—Allocation of resources, e.g. of the central processing unit [CPU]
- G06F9/5005—Allocation of resources, e.g. of the central processing unit [CPU] to service a request
- G06F9/5027—Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals
- G06F9/5044—Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals considering hardware capabilities
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/46—Multiprogramming arrangements
- G06F9/50—Allocation of resources, e.g. of the central processing unit [CPU]
- G06F9/5005—Allocation of resources, e.g. of the central processing unit [CPU] to service a request
- G06F9/5027—Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals
- G06F9/505—Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals considering the load
Definitions
- the present disclosure generally relates to the field of cloud computing.
- a technique for simplifying management of a service on a network infrastructure in a cloud computing environment is presented.
- the technique may be embodied in methods, computer programs, apparatuses and systems.
- cloud sites may be geographically distributed and interconnected through a wide area network (WAN).
- Figure 1 shows an exemplary cloud computing environment comprising a plurality of interconnected cloud sites, wherein a central orchestrator may establish communication with local orchestrators placed at the individual sites.
- Figure 2 schematically illustrates a more detailed view of a site and shows that cloud sites may essentially comprise cloud nodes as well as connections between cloud nodes.
- Cloud sites may become candidate hosting targets for virtualized network functions (VNFs) and services.
- Orchestrators may receive deployment descriptions of VNFs (or subsets thereof) and/or services to execute the actual deployment or instantiation thereof.
- VNFs and services may be deployed upon instructions from the central orchestrator, or locally using a local orchestrator without communication with the central orchestrator via the WAN.
- Open source projects employing local and central orchestrators include the Akraino Edge Stack project and the Open Networking Automation Platform (ONAP) project, for example.
- VNFs may be chained with other VNFs and/or physical network functions (PNFs) to realize a network service.
- a deployment description or service description may define deployment requirements and the operational behavior of the VNFs and services. Examples are the VNF descriptor (VNFD) and the network service descriptor (NSD) which are described in ETSI GS NFV-SOL 001, such as in ETSI GS NFV-SOL 001 V2.5.1 (2018-12), for example.
- VNFDs and NSDs may include constructs to model VNFs such as those defined in ETSI GS NFV 003 (e.g., ETSI GS NFV 003 Vl.4.1 (2018-08)) including constructs, such as the virtualization deployment unit (VDU) which may be mapped to a virtual machine (VM) or a container, for example, and the virtual link (VL) which may be used to connect two or more entities, such as VNFs or VNF components (VNFCs), for example.
- VDU virtualization deployment unit
- VL virtual link
- VNFs and services may be deployed or instantiated on infrastructure resources of cloud sites.
- infrastructure resources are typically represented in the form of a network inventory.
- Exemplary network inventories are illustrated in Figure 3 where cloud nodes (or "compute nodes") of the network infrastructure are associated with particular capacities, such as random access memory (RAM) and hard disk capacities, for example. While the left side of the figure shows an exemplary inventory of physical compute nodes, the right side of the figure illustrates that a network inventory may also include virtualized infrastructure resources, such as VMs, for example.
- VMs virtualized infrastructure resources
- a network inventory may generally correspond to a (e.g., real-time) representation (or "view") of available resources in a network infrastructure, which may include hardware resources (e.g., compute, storage), software resources (e.g., VNFs) and the connection/link resources therebetween.
- hardware resources e.g., compute, storage
- software resources e.g., VNFs
- Building a network inventory may form a fundamental step of any VNF or service deployment and may generally be required to solve the placement problem, i.e., to decide where to (e.g., best) instantiate VNF or service components on the available infrastructure.
- the size of a network inventory may be very large in distributed cloud and edge computing scenarios, however.
- the placement problem may become less tractable due to the inherent scalability and multi-dimensional nature of the optimization problem to be solved and it may therefore be difficult for engines (e.g., placement engines) to process the large amount of data from the inventory to deploy a VNF or service (or to perform more general network management tasks, such as rearranging or scaling VNFs or workloads, for example) in a short amount of time.
- a method for simplifying management of a service on a network infrastructure in a cloud computing environment is provided.
- the method is performed by an aggregation component and comprises generating, for a service to be managed on the network infrastructure and based on a representation of resources available in the network infrastructure, an aggregated representation of the resources available in the network infrastructure, wherein aggregated resources in the aggregated representation are computed to comply with one or more capacity- related requirements of the service to be managed, and providing the aggregated representation to an orchestration component for management of the service.
- the resources in the representation may comprise nodes and links of the network infrastructure each providing a particular capacity. Generating the aggregated representation of the resources may include determining whether at least one of node aggregation and link aggregation is required for the aggregated resources to comply with the one or more capacity-related requirements of the service. When it is determined that node aggregation is required, generating the aggregated
- representation of the resources may include aggregating at least two nodes of the network infrastructure to obtain an aggregated node that complies with the one or more capacity-related requirements of the service. Node aggregation may be performed under a constraint that nodes at different sites of the cloud computing environment are not to be aggregated.
- generating the aggregated representation of the resources may include aggregating at least two links of the network infrastructure to obtain an aggregated link that complies with the one or more capacity-related requirements of the service.
- Determining whether node aggregation is required may include determining a reference value of available node capacities in the network infrastructure, calculating a total of required node capacities from the one or more capacity-related
- the reference value of available node capacities may be determined as one of a sum of available node capacities and an average of available node capacities per site in the cloud computing environment.
- the one or more capacity-related requirements of the service may be derived from a deployment descriptor of the service.
- the deployment descriptor of the service may be obtained from a service catalog available in the cloud computing environment.
- the one or more capacity-related requirements of the service may be derived from a network service descriptor of the network service.
- the one or more capacity-related requirements of the service may be derived from a virtualized network function descriptor of the virtualized network function.
- Node- related requirements among the one or more capacity-related requirements of the service may be derived from at least one definition of a virtual deployment unit in the deployment descriptor.
- Link-related requirements among the one or more capacity-related requirements of the service may be derived from at least one definition of a virtual link in the deployment descriptor.
- the aggregation component may be executed as a component of the orchestration component, wherein the orchestration component may be a central orchestration component being centrally responsible for management of services on the network infrastructure in the cloud computing environment.
- the aggregation component may be executed in a distributed manner on at least one of a central orchestration component being centrally responsible for management of services on the network infrastructure in the cloud computing environment and one or more local orchestration components each being locally responsible for management of services on a local network infrastructure of a site of the cloud computing environment.
- a method for simplifying management of a service on a network infrastructure in a cloud computing environment is provided.
- the method is performed by an orchestration component and comprises obtaining, from an aggregation component, an aggregated representation of resources available in the network infrastructure, the aggregated representation being generated for a service to be managed on the network infrastructure and based on a representation of resources available in the network infrastructure, wherein aggregated resources in the aggregated representation comply with one or more capacity-related
- the method according to the second aspect defines a method from the perspective of an orchestration component which may be complementary to the method performed by the aggregation component according to the first aspect.
- the aggregation component and the orchestration component of the second aspect may thus correspond to the aggregation component and the orchestration component described above in relation to the first aspect.
- Triggering management of the service based on the aggregated representation may include calculating a placement of the service on the network infrastructure based on the aggregated representation of the resources, and triggering management of the service based on the calculated placement.
- a computer program product comprises program code portions for performing the method of at least one of the first aspect and the second aspect when the computer program product is executed on one or more computing devices (e.g., a processor or a distributed set of processors).
- the computer program product may be stored on a computer readable recording medium, such as a semiconductor memory, DVD, CD- ROM, and so on.
- a computing unit configured to execute an aggregation component for simplifying management of a service on a network infrastructure in a cloud computing environment.
- the computing unit comprises at least one processor and at least one memory, wherein the at least one memory contains instructions executable by the at least one processor such that the aggregation component is operable to perform any of the method steps presented herein with respect to the first aspect.
- a computing unit configured to execute an orchestration component for simplifying management of a service on a network infrastructure in a cloud computing environment.
- the computing unit comprises at least one processor and at least one memory, wherein the at least one memory contains instructions executable by the at least one processor such that the orchestration component is operable to perform any of the method steps presented herein with respect to the second aspect.
- a system comprising a computing unit according to the fourth aspect and a computing unit according to the fifth aspect.
- Fig. 1 illustrates an exemplary cloud computing environment comprising a plurality of interconnected cloud sites
- Fig. 2 illustrates a detailed schematic view of a cloud site
- Fig. 3 illustrates exemplary network inventories including cloud nodes and their associated capacities
- Figs. 4a and 4b illustrate exemplary compositions of a computing unit configured to execute an aggregation component and a computing unit configured to execute an orchestration component according to the present disclosure
- Fig. 5 illustrates a method which may be performed by the aggregation
- Fig. 6 illustrates an exemplary deployment descriptor in the form of a VNFD
- Figs. 7a and 7b illustrate exemplary system architectures in which the
- aggregation component is executed as part of a central orchestration component or in a distributed manner across several orchestration components according to the present disclosure
- Fig. 8 illustrates a method which may be performed by the orchestration
- Fig. 9 illustrates a more detailed method which may be performed by the
- Fig. 10 illustrates a sequence diagram providing an overview of an overall placement process using the aggregation component according to the present disclosure
- Fig. 11 illustrates a more detailed method of building up an aggregated network inventory for a plurality of services according to the present disclosure
- Fig. 12 illustrates an exemplary method of carrying out classification of a service as a service which requires node aggregation or not according to the present disclosure
- Fig. 13 illustrates an exemplary implementation of the technique presented herein using ONAP and OpenStack.
- FIG. 4a schematically illustrates an exemplary composition of a computing unit 400 configured to execute an aggregation component for simplifying management of a service on a network infrastructure in a cloud computing environment.
- the computing unit 400 comprises at least one processor 402 and at least one memory 404, wherein the at least one memory 404 contains instructions executable by the at least one processor 402 such that the aggregation component is operable to carry out the method steps described herein below with reference to the aggregation component.
- Figure 4b schematically illustrates an exemplary composition of a computing unit 410 configured to execute an orchestration component for simplifying management of a service on a network infrastructure in a cloud computing environment.
- computing unit 410 comprises at least one processor 412 and at least one memory 414, wherein the at least one memory 414 contains instructions executable by the at least one processor 412 such that the orchestration component is operable to carry out the method steps described herein below with reference to the orchestration component.
- each of the computing unit 400 and the computing unit 410 may be implemented on a physical computing unit or a virtualized computing unit, such as a virtual machine, for example. It will further be appreciated that each of the computing unit 400 and the computing unit 410 may not necessarily be implemented on a standalone computing unit, but may be implemented as
- Figure 5 illustrates a method which may be performed by the aggregation component executed on the computing unit 400 according to the present disclosure.
- the method is dedicated to simplifying management of a service on a network infrastructure in a cloud computing environment.
- the aggregation component may generate, for a service to be managed on the network infrastructure and based on a representation of resources available in the network infrastructure, an aggregated representation of the resources available in the network infrastructure, wherein aggregated resources in the aggregated representation are computed to comply with one or more capacity-related requirements of the service to be managed.
- the aggregation component may provide the aggregated representation to an orchestration component for management of the service.
- the representation of resources available in the network infrastructure may correspond to a conventional network inventory (e.g., a central network inventory maintained by a central orchestrator receiving topologies of nodes and links of different sites of the cloud computing environment from local orchestrators at the sites and building the centralized network inventory based thereon) and, by generating an aggregated representation of the resources available in the network infrastructure, an aggregated network inventory may be created to provide an aggregated view of the available resources.
- a conventional network inventory e.g., a central network inventory maintained by a central orchestrator receiving topologies of nodes and links of different sites of the cloud computing environment from local orchestrators at the sites and building the centralized network inventory based thereon
- an aggregated network inventory may be created to provide an aggregated view of the available resources.
- aggregation component may thus be seen as a method for performing network inventory aggregation.
- the aggregated representation of the resources may specifically be generated for a service to be managed, wherein aggregated resources in the aggregated
- the service itself may correspond to any service that is deployable on the network infrastructure of the cloud computing environment.
- the service may be a VNF or a network service, such as a network service which comprises one or more VNFs and/or PNFs, for example.
- the aggregated representation may be provided (e.g., sent) to an orchestration component which may effectively carry out the management of the service.
- the orchestration component may correspond to one of a central
- the management of the service may correspond to deployment of the service on the network infrastructure and, if the service is an existing service, the management of the service may relate to performing a life-cycle operation regarding the service, e.g., a rearrangement of service resources, such as scaling VNFs or workloads, for example.
- the aggregated representation of the resources available in the network infrastructure may - due to the aggregation being performed - comprise a reduced number of nodes and/or links as compared to the original representation of the resources available in the network infrastructure (e.g., as available in the
- management operations regarding the service may generally be simplified.
- the placement problem for a new service may be alleviated because less time may be required to calculate where to (e.g., best) instantiate the service on the available infrastructure.
- the same may apply to the management of existing services, i.e., when service resources are to be rearranged, for example.
- the resources in the representation may comprise nodes and links of the network infrastructure each providing a particular capacity, and the aggregated resources in the aggregated representation may thus correspond to aggregated nodes and aggregated links each providing a particular aggregated capacity.
- the aggregated resources may be computed to comply with the capacity-related requirements of the service to be managed.
- node-related capacities such as at least one of central processing unit (CPU), RAM and hard disk related capacities provided at a node (e.g., number of CPUs and their speeds, amount of RAM (e.g., 32 GB of RAM), amount of disk space (e.g., 10 TB of disk space), etc.), and/or link-related capacities, such as at least one of bandwidth characteristics and latency characteristics of a link (e.g., 100 Gbps of throughput, 1 ms round trip time, etc.).
- Node-related and link-related capacities may not only include capacities provided by physical nodes and links but also capacities provided by virtualized nodes and links, such as VMs and VLs, for example.
- An aggregated representation may be created for each service among a plurality of services to be managed so that multiple network views may generally be constructed over the same resource infrastructure. The views may then be used to form the aggregated network inventory. Every new service to be managed may trigger the creation of another aggregated representation that may become part of the aggregated inventory, which may then be used by placement engines and/or management systems as an optimized network inventory for optimized service placement and improved network management, as described above.
- a two-step procedure may generally be performed.
- a classification of the service may be carried out to determine, given the capacity-related requirements of the service, whether the service is a service which requires node aggregation and/or a service which requires link aggregation.
- the actual node aggregation and/or link aggregation may be executed based on the classification results, e.g., by grouping respective notes and/or links and summing up their individual capacities.
- Generating the aggregated representation of the resources may thus include determining whether at least one of node aggregation and link aggregation is required for the aggregated resources to comply with the one or more capacity- related requirements of the service.
- generating the aggregated representation of the resources may include aggregating at least two nodes of the network infrastructure to obtain an aggregated node that complies with the one or more capacity-related requirements of the service.
- the aggregated node may thus be determined in a manner so that the sum of the node-related capacities of the individual nodes which are grouped into the aggregated node comply with the service requirements. The same may generally apply to the generation of an aggregated link.
- generating the aggregated representation of the resources may include aggregating at least two links of the network infrastructure to obtain an aggregated link that complies with the one or more capacity-related requirements of the service.
- node aggregation may be performed under a constraint that nodes at different sites of the cloud computing environment are not to be aggregated.
- determining whether node aggregation is required may include determining a reference value of available node capacities in the network infrastructure, calculating a total of required node capacities from the one or more capacity-related requirements of the service, and determining whether node aggregation is required based on a comparison of the total of required node capacities with the reference value of available node capacities.
- the reference value may be indicative of actual hardware capabilities of cloud sites, for example, and by comparing the reference value with the total of required node capacities derived from the capacity-related requirements of the service, it may be determined whether the network infrastructure is overprovisioned (i.e., that resources are available in abundance in terms of their capacities) or whether the network infrastructure is underprovisioned (i.e., that not enough resources are available) and that, therefore, node aggregation is required to obtain an aggregated nodes complying with the capacity-related requirements of the service.
- the reference value of available node capacities may be determined as one of a sum of available node capacities and an average of available node capacities per site in the cloud computing environment.
- the reference value of available node capacities may also be determined differently per site in the cloud computing environment, e.g., according to the number of cloud sites and hardware configuration per cloud site. The above may similarly apply to the classification as a service which requires link aggregation or not, the difference being that, instead of node-related capacities, link-related capacities may be considered.
- Determining whether link aggregation is required may thus include determining a reference value of available link capacities in the network infrastructure, calculating a total of required link capacities from the one or more capacity-related requirements of the service, and determining whether link aggregation is required based on a comparison of the total of required link capacities with the reference value of available link capacities.
- deployment descriptors may be used to define deployment requirements and the operational behavior of services to be deployed on the network infrastructure.
- the capacity related requirements of the service may be derived from a deployment descriptor of the service.
- deployment descriptors may be stored in service catalogs, the deployment descriptor of the service may be obtained from a service catalog available in the cloud computing environment.
- An exemplary deployment descriptor is shown in Figure 6 for illustrative purposes, which, in the shown example, corresponds to a VNFD extracted from ETSI GS NFV-SOL 001, where the nodes are given by VDUs.
- the one or more capacity-related requirements of the service may be derived from a network service descriptor of the network service.
- the network service and the network service descriptor may be understood as a network service and as an NSD as defined in ETSI GS NFV-SOL 001, respectively, such as defined in ETSI GS NFV-SOL 001 V2.5.1 (2018-12) or successor versions thereof.
- the service corresponds to a virtualized network function to be managed on the network infrastructure
- the one or more capacity-related requirements of the service may be derived from a virtualized network function descriptor of the virtualized network function.
- the virtualized network function and the virtualized network function descriptor may be understood as a VNF and as a VNFD as defined in ETSI GS NFV-SOL 001, respectively, such as defined in ETSI GS NFV-SOL 001 V2.5.1 (2018-12) or successor versions thereof.
- Node-related requirements among the one or more capacity-related requirements of the service may be derived from at least one definition of a virtual deployment unit in the deployment descriptor.
- the virtual deployment unit may be a VDU as defined in ETSI GS NFV 003, such as defined in ETSI GS NFV 003 Vl.4.1 (2018-08) or successor versions thereof.
- link-related requirements among the one or more capacity-related requirements of the service may be derived from at least one definition of a virtual link in the deployment descriptor.
- the virtual link may be a VL as defined in ETSI GS NFV 003, such as defined in ETSI GS NFV 003 Vl.4.1 (2018- 08) or successor versions thereof.
- the aggregation component may be executed as a standalone component or may be comprised as a subcomponent of another component being executed in the cloud computing environment.
- the aggregated component may be executed as a component of the orchestration component, wherein the orchestration component may be a central orchestration component being centrally responsible for management of services on the network infrastructure in the cloud computing environment.
- the aggregation component may be executed in a distributed manner on at least one of a central orchestration component being centrally responsible for management of services on the network infrastructure in the cloud computing environment and one or more local orchestration components each being locally responsible for management of services on a local network
- Figures 7a and 7b Such variants are exemplarily depicted in Figures 7a and 7b, wherein Figure 7a illustrates an example in which the aggregation component 702 (denoted as
- aggregated network inventory in the figure is executed as part of a central orchestration component 704. As shown in the figure, the aggregation component 702 may receive as inputs (i) service requirements from a service catalog 706 and
- each local orchestration component 710 may additionally communicate with a virtual infrastructure manager (VIM) 714 of the local site (e.g., via an ETSI Or-Vi reference point) to build up the respective local network inventory 712.
- VIP virtual infrastructure manager
- Figure 7b illustrates another example in which the aggregation component 702 is not executed in a centralized manner by a service provider, but in a distributed manner across the service provider (hosting the central orchestration component 704) and several cloud providers (hosting the local orchestration component 710) so as to enable an application programming interface (API) based inventory creation and abstraction between a service provider and cloud providers.
- Respective APIs are denoted as "aggregation API" in the figure.
- aggregation API a full representation of the aggregation component 702 may be provided at the central orchestration component 704 and partial representations of the aggregation component 702 may be provided at the local orchestration components 710, for example.
- Figure 8 illustrates a method which may be performed by the orchestration component executed on the computing unit 410 according to the present disclosure.
- the method is dedicated to simplifying management of a service on a network infrastructure in a cloud computing environment.
- the operation of the orchestration component may be complementary to the operation of the aggregation component described above and, as such, aspects described above with regard to the operation of the orchestration component may be applicable to the operation of the
- the orchestration component may obtain, from an aggregation component, an aggregated representation of resources available in the network infrastructure, the aggregated representation being generated for a service to be managed on the network infrastructure and based on a representation of resources available in the network infrastructure, wherein aggregated resources in the aggregated representation comply with one or more capacity-related requirements of the service to be managed.
- the orchestration component may trigger management of the service based on the aggregated representation. Triggering management of the service based on the aggregated representation may include calculating a placement of the service on the network infrastructure based on the aggregated representation of the resources, and triggering management of the service based on the calculated placement.
- FIG. 9 illustrates a more detailed method which may be performed by the orchestration component.
- the orchestration component may receive the aggregated representation as described above in accordance with step S802. Triggering management of the service based on the aggregated representation in accordance with step S804 is exemplified in Figure 9 in that the orchestration component may receive, in step 2, a request to place a new service. Such request may be received from a placement engine of the cloud computing environment, for example.
- the orchestration component may then identify the aggregated resources related to the real resources so as to determine the real resources which may host the service (i.e., where to place the service). For the following step of performing (or triggering performing) the actual placement of the service, two variants are indicated in the figure.
- the orchestration component may directly access a management interface of the local orchestrator in charge of the aggregated resources and may perform the placement via the management interface.
- the second variant of step 4b relates to the case that the orchestration component is a central orchestration component. In this case, the orchestration component may delegate the placement to the local orchestrator in charge of the aggregated resources. It will be understood that, while such examples reflect a two-level hierarchy of orchestration, the technique presented herein may be practiced with orchestration hierarchies of more than two levels as well.
- Figure 10 illustrates a sequence diagram providing an overview of an overall placement process using the aggregation component 702.
- the central network inventory 708 provided at the central orchestration component 704 may request (or discover) resources from the local orchestration components 710 of different cloud sites and build up a central network inventory (cf. steps 1, 2 and 3 of the diagram).
- the aggregation component 702 may request the representation of resources from the central network inventory 708 and receive this representation as a "central view”.
- the placement engine may request an aggregated representation of the resources (denoted "A I view” in the figure) from the aggregation component 702 in step 7.
- the aggregation component 702 may request deployment descriptors, such as at least one of an NSD and a VNFD for the service from the service catalog 706 and generate the
- the aggregation component 702 may provide (e.g., send) the aggregated representation to the placement engine which may then proceed to calculate the optimal placement based on the aggregated representation of the resources and, once determined, may trigger the actual placement (e.g., deployment) of the service based on the determined optimal placement, as described above.
- the dashed rectangle surrounding steps 8, 9 and 10 generally indicates that, in one variant, these steps may be performed in an iterative process for a plurality of services (e.g., all services) contained in the service catalog 706 so that the aggregated network inventory maintained by the aggregation component 702 may not only be built up in a stepwise manner upon receipt of respective requests from a placement engine (such as the request in step 7), but in a single round for all services contained in the service catalog 706.
- a plurality of services e.g., all services
- Figure 11 illustrates a more detailed view of an iterative process of building up the aggregated network inventory for a plurality of services contained in the service catalog 706.
- the service requirements i.e., the capacity- related requirements of the service
- the service requirements may be obtained from the service catalog 706 for each service contained in the service catalog 706 in step 1.
- the service requirements may be obtained in the form of VDUs and VLs.
- each service may then be classified as a service which requires node aggregation and/or link aggregation.
- steps 3a and 3b may be executed mutually exclusive or that both steps 3a and 3b may be performed.
- the original representation of resources available in the network infrastructure and the aggregated representation thereof may be considered as graphs in which nodes correspond to vertices and links correspond to edges between two nodes.
- vertices of cloud sites may be aggregated (e.g., grouped) according to pools of node requirements (e.g., VDU requirements) of the service and the aggregated vertices may be annotated by the sum of the corresponding node resource capacities. Edges from merged vertices may be discarded.
- edges of cloud sites may be aggregated (e.g., grouped) according to pools of link requirements (e.g., VL requirements) of the service and the aggregated edges may be annotated by the sum of corresponding link resource capacities. Vertices from merged links may be discarded. If both node aggregation and link aggregation are required, vertices and edges of cloud sites may be aggregated (e.g., grouped) according to pools of node requirements (e.g., VDU requirements) and link requirements (e.g., VL requirements) of the service and the resulting graph may be annotated with both node and link capacities accordingly.
- Figure 12 illustrates an exemplary method of carrying out the classification of a service as a service which requires node aggregation or not, i.e., based on
- step 1 of the method hardware capabilities of the nodes may be obtained from the cloud sites.
- step 2 a hardware platform reference (HPR) value may be calculated as a reference value indicative of actual hardware capabilities of cloud sites.
- step 3 a summation of the capacity-related service may be computed (in the shown example, a summation of VDU requirements (SVDU)) and, based on the HPR and SVDU, an overprovisioning index (OI) may be calculated.
- HPR hardware platform reference
- OI overprovisioning index
- the calculated 01 then indicates hardware underprovisioning (i.e., indicating that not enough hardware resources are available for the service), it may be determined that the service requires node aggregation in step 5a, to thereby obtain aggregated nodes which comply with the capacity-related requirements of the service. If, on the other hand, the calculated OI indicates overprovisioning (i.e., indicating that hardware resources are available in abundance), it may be determined that the service does not require node aggregation in step 5b. It will be understood that the same procedure may generally be carried out to classify a service as a service which requires link aggregation or not, the only difference being that, instead of node resources, link resources may be used to determine the OI.
- FIG. 13 illustrates an exemplary implementation of the technique presented herein using ONAP and OpenStack.
- so called OpenStack flavors are used as features of node aggregation.
- flavors define the compute, memory and storage capacity of Nova computing instances.
- a flavor may thus correspond to an available hardware configuration for a server and defines the size of a virtual server that can be launched.
- OpenStack flavors may be used as follows: (1) for each VNFD, map the set of requirements (e.g., storage, memory) to an OpenStack flavor, compute a summation of VDU requirements, i.e., an SVDU, and map the SVDU to the flavor that minimally supports the deployment of the VNF described in the VNFD, (2) for each flavor identified in (1), obtain compute nodes of the respective flavor and aggregate them to create a single aggregated node, wherein compute nodes of different cloud regions may not be aggregated, and (3) expose the aggregated nodes created in (2) per OpenStack cloud region.
- FIG. 13 An example of such a scenario is illustrated in Figure 13 which shows that compute nodes CN1, CN2 and CN3 have been merged into the single aggregated node "flavor small" providing sufficient resources to comply with the capacity-related requirements of VNFD_1 and compute nodes CN8, CN9 and CN10 have been merged into the single aggregated node "flavor big” providing sufficient resources to comply with the capacity-related requirements of VNFD_2.
- the present disclosure provides a technique for simplifying management of a service on a network infrastructure in a cloud computing environment.
- the computational complexity of the placement problem i.e., where to best place a service on the available infrastructure, may be alleviated and both network management and service deployment operations may be executed more efficiently, so that the time to deploy a service and to perform life-cycle operations in which service resources are rearranged, such as scaling VNFs or workloads, may be reduced.
- an aggregated network inventory may be built up which is specifically optimized for the services contained in the service catalog of the cloud computing environment.
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
Abstract
A technique for simplifying management of a service on a network infrastructure in a cloud computing environment is disclosed. A method implementation of the technique is performed by an aggregation component and comprises generating (S502), for a service to be managed on the network infrastructure and based on a representation of resources available in the network infrastructure, an aggregated representation of the resources available in the network infrastructure, wherein aggregated resources in the aggregated representation are computed to comply with one or more capacity-related requirements of the service to be managed, and providing (S504) the aggregated representation to an orchestration component for management of the service.
Description
Technique for simplifying management of a service
in a cloud computing environment
Technical Field
The present disclosure generally relates to the field of cloud computing. In particular, a technique for simplifying management of a service on a network infrastructure in a cloud computing environment is presented. The technique may be embodied in methods, computer programs, apparatuses and systems.
Background
In distributed cloud environments, including edge computing and more centralized approaches, cloud sites may be geographically distributed and interconnected through a wide area network (WAN). Figure 1 shows an exemplary cloud computing environment comprising a plurality of interconnected cloud sites, wherein a central orchestrator may establish communication with local orchestrators placed at the individual sites. Figure 2 schematically illustrates a more detailed view of a site and shows that cloud sites may essentially comprise cloud nodes as well as connections between cloud nodes.
Cloud sites may become candidate hosting targets for virtualized network functions (VNFs) and services. Orchestrators (either central or local orchestrators) may receive deployment descriptions of VNFs (or subsets thereof) and/or services to execute the actual deployment or instantiation thereof. VNFs and services may be deployed upon instructions from the central orchestrator, or locally using a local orchestrator without communication with the central orchestrator via the WAN. Open source projects employing local and central orchestrators include the Akraino Edge Stack project and the Open Networking Automation Platform (ONAP) project, for example.
VNFs may be chained with other VNFs and/or physical network functions (PNFs) to realize a network service. A deployment description or service description may define deployment requirements and the operational behavior of the VNFs and services. Examples are the VNF descriptor (VNFD) and the network service descriptor (NSD) which are described in ETSI GS NFV-SOL 001, such as in ETSI GS NFV-SOL 001 V2.5.1 (2018-12), for example. VNFDs and NSDs may include constructs to model VNFs such as those defined in ETSI GS NFV 003 (e.g., ETSI GS NFV 003 Vl.4.1
(2018-08)) including constructs, such as the virtualization deployment unit (VDU) which may be mapped to a virtual machine (VM) or a container, for example, and the virtual link (VL) which may be used to connect two or more entities, such as VNFs or VNF components (VNFCs), for example.
As said, VNFs and services may be deployed or instantiated on infrastructure resources of cloud sites. Such infrastructure resources are typically represented in the form of a network inventory. Exemplary network inventories are illustrated in Figure 3 where cloud nodes (or "compute nodes") of the network infrastructure are associated with particular capacities, such as random access memory (RAM) and hard disk capacities, for example. While the left side of the figure shows an exemplary inventory of physical compute nodes, the right side of the figure illustrates that a network inventory may also include virtualized infrastructure resources, such as VMs, for example. A network inventory may generally correspond to a (e.g., real-time) representation (or "view") of available resources in a network infrastructure, which may include hardware resources (e.g., compute, storage), software resources (e.g., VNFs) and the connection/link resources therebetween.
Building a network inventory may form a fundamental step of any VNF or service deployment and may generally be required to solve the placement problem, i.e., to decide where to (e.g., best) instantiate VNF or service components on the available infrastructure. The size of a network inventory may be very large in distributed cloud and edge computing scenarios, however. As a result, the placement problem may become less tractable due to the inherent scalability and multi-dimensional nature of the optimization problem to be solved and it may therefore be difficult for engines (e.g., placement engines) to process the large amount of data from the inventory to deploy a VNF or service (or to perform more general network management tasks, such as rearranging or scaling VNFs or workloads, for example) in a short amount of time.
Summary
Accordingly, there is a need for a technique for simplifying network management in a cloud computing environment that avoids the problems discussed above, or other problems.
According to a first aspect, a method for simplifying management of a service on a network infrastructure in a cloud computing environment is provided. The method is
performed by an aggregation component and comprises generating, for a service to be managed on the network infrastructure and based on a representation of resources available in the network infrastructure, an aggregated representation of the resources available in the network infrastructure, wherein aggregated resources in the aggregated representation are computed to comply with one or more capacity- related requirements of the service to be managed, and providing the aggregated representation to an orchestration component for management of the service.
The resources in the representation may comprise nodes and links of the network infrastructure each providing a particular capacity. Generating the aggregated representation of the resources may include determining whether at least one of node aggregation and link aggregation is required for the aggregated resources to comply with the one or more capacity-related requirements of the service. When it is determined that node aggregation is required, generating the aggregated
representation of the resources may include aggregating at least two nodes of the network infrastructure to obtain an aggregated node that complies with the one or more capacity-related requirements of the service. Node aggregation may be performed under a constraint that nodes at different sites of the cloud computing environment are not to be aggregated. When it is determined that link aggregation is required, generating the aggregated representation of the resources may include aggregating at least two links of the network infrastructure to obtain an aggregated link that complies with the one or more capacity-related requirements of the service.
Determining whether node aggregation is required may include determining a reference value of available node capacities in the network infrastructure, calculating a total of required node capacities from the one or more capacity-related
requirements of the service, and determining whether node aggregation is required based on a comparison of the total of required node capacities with the reference value of available node capacities. The reference value of available node capacities may be determined as one of a sum of available node capacities and an average of available node capacities per site in the cloud computing environment. The reference value of available node capacities may be determined differently per site in the cloud computing environment. Determining whether link aggregation is required may include determining a reference value of available link capacities in the network infrastructure, calculating a total of required link capacities from the one or more capacity-related requirements of the service, and determining whether link aggregation is required based on a comparison of the total of required link capacities with the reference value of available link capacities.
The one or more capacity-related requirements of the service may be derived from a deployment descriptor of the service. The deployment descriptor of the service may be obtained from a service catalog available in the cloud computing environment. When the service corresponds to a network service to be managed on the network infrastructure, the one or more capacity-related requirements of the service may be derived from a network service descriptor of the network service. When the service corresponds to a virtualized network function to be managed on the network infrastructure, the one or more capacity-related requirements of the service may be derived from a virtualized network function descriptor of the virtualized network function. Node- related requirements among the one or more capacity-related requirements of the service may be derived from at least one definition of a virtual deployment unit in the deployment descriptor. Link-related requirements among the one or more capacity-related requirements of the service may be derived from at least one definition of a virtual link in the deployment descriptor.
The aggregation component may be executed as a component of the orchestration component, wherein the orchestration component may be a central orchestration component being centrally responsible for management of services on the network infrastructure in the cloud computing environment. Alternatively, the aggregation component may be executed in a distributed manner on at least one of a central orchestration component being centrally responsible for management of services on the network infrastructure in the cloud computing environment and one or more local orchestration components each being locally responsible for management of services on a local network infrastructure of a site of the cloud computing environment.
According to a second aspect, a method for simplifying management of a service on a network infrastructure in a cloud computing environment is provided. The method is performed by an orchestration component and comprises obtaining, from an aggregation component, an aggregated representation of resources available in the network infrastructure, the aggregated representation being generated for a service to be managed on the network infrastructure and based on a representation of resources available in the network infrastructure, wherein aggregated resources in the aggregated representation comply with one or more capacity-related
requirements of the service to be managed, and triggering management of the service based on the aggregated representation.
The method according to the second aspect defines a method from the perspective of an orchestration component which may be complementary to the method performed by the aggregation component according to the first aspect. The aggregation component and the orchestration component of the second aspect may thus correspond to the aggregation component and the orchestration component described above in relation to the first aspect. Triggering management of the service based on the aggregated representation may include calculating a placement of the service on the network infrastructure based on the aggregated representation of the resources, and triggering management of the service based on the calculated placement.
According to a third aspect, a computer program product is provided. The computer program product comprises program code portions for performing the method of at least one of the first aspect and the second aspect when the computer program product is executed on one or more computing devices (e.g., a processor or a distributed set of processors). The computer program product may be stored on a computer readable recording medium, such as a semiconductor memory, DVD, CD- ROM, and so on.
According to a fourth aspect, a computing unit configured to execute an aggregation component for simplifying management of a service on a network infrastructure in a cloud computing environment is provided. The computing unit comprises at least one processor and at least one memory, wherein the at least one memory contains instructions executable by the at least one processor such that the aggregation component is operable to perform any of the method steps presented herein with respect to the first aspect.
According to a fifth aspect, a computing unit configured to execute an orchestration component for simplifying management of a service on a network infrastructure in a cloud computing environment is provided. The computing unit comprises at least one processor and at least one memory, wherein the at least one memory contains instructions executable by the at least one processor such that the orchestration component is operable to perform any of the method steps presented herein with respect to the second aspect.
According to a sixth aspect, there is provided a system comprising a computing unit according to the fourth aspect and a computing unit according to the fifth aspect.
Brief Description of the Drawings
Implementations of the technique presented herein are described herein below with reference to the accompanying drawings, in which:
Fig. 1 illustrates an exemplary cloud computing environment comprising a plurality of interconnected cloud sites;
Fig. 2 illustrates a detailed schematic view of a cloud site;
Fig. 3 illustrates exemplary network inventories including cloud nodes and their associated capacities;
Figs. 4a and 4b illustrate exemplary compositions of a computing unit configured to execute an aggregation component and a computing unit configured to execute an orchestration component according to the present disclosure;
Fig. 5 illustrates a method which may be performed by the aggregation
component according to the present disclosure;
Fig. 6 illustrates an exemplary deployment descriptor in the form of a VNFD
according to the present disclosure;
Figs. 7a and 7b illustrate exemplary system architectures in which the
aggregation component is executed as part of a central orchestration component or in a distributed manner across several orchestration components according to the present disclosure;
Fig. 8 illustrates a method which may be performed by the orchestration
component according to the present disclosure;
Fig. 9 illustrates a more detailed method which may be performed by the
orchestration component according to the present disclosure;
Fig. 10 illustrates a sequence diagram providing an overview of an overall placement process using the aggregation component according to the present disclosure;
Fig. 11 illustrates a more detailed method of building up an aggregated network inventory for a plurality of services according to the present disclosure;
Fig. 12 illustrates an exemplary method of carrying out classification of a service as a service which requires node aggregation or not according to the present disclosure; and
Fig. 13 illustrates an exemplary implementation of the technique presented herein using ONAP and OpenStack.
Detailed Description
In the following description, for purposes of explanation and not limitation, specific details are set forth in order to provide a thorough understanding of the present disclosure. It will be apparent to one skilled in the art that the present disclosure may be practiced in other embodiments that depart from these specific details.
Those skilled in the art will further appreciate that the steps, services and functions explained herein below may be implemented using individual hardware circuitry, using software functioning in conjunction with a programmed micro-processor or general purpose computer, using one or more Application Specific Integrated Circuits (ASICs) and/or using one or more Digital Signal Processors (DSPs). It will also be appreciated that when the present disclosure is described in terms of a method, it may also be embodied in one or more processors and one or more memories coupled to the one or more processors, wherein the one or more memories are encoded with one or more programs that perform the steps, services and functions disclosed herein when executed by the one or more processors.
Figure 4a schematically illustrates an exemplary composition of a computing unit 400 configured to execute an aggregation component for simplifying management of a service on a network infrastructure in a cloud computing environment. The computing unit 400 comprises at least one processor 402 and at least one memory 404, wherein the at least one memory 404 contains instructions executable by the at least one processor 402 such that the aggregation component is operable to carry
out the method steps described herein below with reference to the aggregation component.
Figure 4b schematically illustrates an exemplary composition of a computing unit 410 configured to execute an orchestration component for simplifying management of a service on a network infrastructure in a cloud computing environment. The
computing unit 410 comprises at least one processor 412 and at least one memory 414, wherein the at least one memory 414 contains instructions executable by the at least one processor 412 such that the orchestration component is operable to carry out the method steps described herein below with reference to the orchestration component.
It will be understood that each of the computing unit 400 and the computing unit 410 may be implemented on a physical computing unit or a virtualized computing unit, such as a virtual machine, for example. It will further be appreciated that each of the computing unit 400 and the computing unit 410 may not necessarily be implemented on a standalone computing unit, but may be implemented as
components - realized in software and/or hardware - residing on multiple distributed computing units as well, such as in a cloud computing environment, for example.
Figure 5 illustrates a method which may be performed by the aggregation component executed on the computing unit 400 according to the present disclosure. The method is dedicated to simplifying management of a service on a network infrastructure in a cloud computing environment. In step S502, the aggregation component may generate, for a service to be managed on the network infrastructure and based on a representation of resources available in the network infrastructure, an aggregated representation of the resources available in the network infrastructure, wherein aggregated resources in the aggregated representation are computed to comply with one or more capacity-related requirements of the service to be managed. In step S504, the aggregation component may provide the aggregated representation to an orchestration component for management of the service.
The representation of resources available in the network infrastructure may correspond to a conventional network inventory (e.g., a central network inventory maintained by a central orchestrator receiving topologies of nodes and links of different sites of the cloud computing environment from local orchestrators at the sites and building the centralized network inventory based thereon) and, by generating an aggregated representation of the resources available in the network
infrastructure, an aggregated network inventory may be created to provide an aggregated view of the available resources. The method performed by the
aggregation component may thus be seen as a method for performing network inventory aggregation.
The aggregated representation of the resources may specifically be generated for a service to be managed, wherein aggregated resources in the aggregated
representation may be computed to comply with one or more capacity-related requirements of the particular service to be managed. The aggregated representation (or "view") may therefore be optimized for the service to be managed in terms of its requirements and the service requirements may as such be used to guide the level of aggregation (or "abstraction"). The service itself may correspond to any service that is deployable on the network infrastructure of the cloud computing environment. For example, the service may be a VNF or a network service, such as a network service which comprises one or more VNFs and/or PNFs, for example.
Once generated, the aggregated representation may be provided (e.g., sent) to an orchestration component which may effectively carry out the management of the service. The orchestration component may correspond to one of a central
orchestrator and a local orchestrator in the cloud computing environment, for example. If the service is a new service to be deployed, the management of the service may correspond to deployment of the service on the network infrastructure and, if the service is an existing service, the management of the service may relate to performing a life-cycle operation regarding the service, e.g., a rearrangement of service resources, such as scaling VNFs or workloads, for example.
As the aggregated representation of the resources available in the network infrastructure may - due to the aggregation being performed - comprise a reduced number of nodes and/or links as compared to the original representation of the resources available in the network infrastructure (e.g., as available in the
conventional network inventory), management operations regarding the service may generally be simplified. For example, the placement problem for a new service may be alleviated because less time may be required to calculate where to (e.g., best) instantiate the service on the available infrastructure. The same may apply to the management of existing services, i.e., when service resources are to be rearranged, for example.
The resources in the representation may comprise nodes and links of the network infrastructure each providing a particular capacity, and the aggregated resources in the aggregated representation may thus correspond to aggregated nodes and aggregated links each providing a particular aggregated capacity. As said, the aggregated resources may be computed to comply with the capacity-related requirements of the service to be managed. As such, the capacity-related
requirements may relate to capacities provided by nodes and/or links of the network infrastructure, including node-related capacities, such as at least one of central processing unit (CPU), RAM and hard disk related capacities provided at a node (e.g., number of CPUs and their speeds, amount of RAM (e.g., 32 GB of RAM), amount of disk space (e.g., 10 TB of disk space), etc.), and/or link-related capacities, such as at least one of bandwidth characteristics and latency characteristics of a link (e.g., 100 Gbps of throughput, 1 ms round trip time, etc.). Node-related and link-related capacities may not only include capacities provided by physical nodes and links but also capacities provided by virtualized nodes and links, such as VMs and VLs, for example.
An aggregated representation may be created for each service among a plurality of services to be managed so that multiple network views may generally be constructed over the same resource infrastructure. The views may then be used to form the aggregated network inventory. Every new service to be managed may trigger the creation of another aggregated representation that may become part of the aggregated inventory, which may then be used by placement engines and/or management systems as an optimized network inventory for optimized service placement and improved network management, as described above.
In order to generate an aggregated representation of the resources available in the network infrastructure for a particular service to be managed, a two-step procedure may generally be performed. In a first step of the procedure, a classification of the service may be carried out to determine, given the capacity-related requirements of the service, whether the service is a service which requires node aggregation and/or a service which requires link aggregation. In the second step of the procedure, the actual node aggregation and/or link aggregation may be executed based on the classification results, e.g., by grouping respective notes and/or links and summing up their individual capacities.
Generating the aggregated representation of the resources may thus include determining whether at least one of node aggregation and link aggregation is
required for the aggregated resources to comply with the one or more capacity- related requirements of the service. When it is determined that node aggregation is required, generating the aggregated representation of the resources may include aggregating at least two nodes of the network infrastructure to obtain an aggregated node that complies with the one or more capacity-related requirements of the service. The aggregated node may thus be determined in a manner so that the sum of the node-related capacities of the individual nodes which are grouped into the aggregated node comply with the service requirements. The same may generally apply to the generation of an aggregated link. Thus, when it is determined that link aggregation is required, generating the aggregated representation of the resources may include aggregating at least two links of the network infrastructure to obtain an aggregated link that complies with the one or more capacity-related requirements of the service. To avoid that nodes located at different cloud sites are aggregated, node aggregation may be performed under a constraint that nodes at different sites of the cloud computing environment are not to be aggregated.
In order to carry out the above-mentioned classification as a service which requires node aggregation or not, a procedure to determine whether - given the capacity- related requirements of the service - the network infrastructure is overprovisioned or underprovisioned may be performed. To this end, determining whether node aggregation is required may include determining a reference value of available node capacities in the network infrastructure, calculating a total of required node capacities from the one or more capacity-related requirements of the service, and determining whether node aggregation is required based on a comparison of the total of required node capacities with the reference value of available node capacities. The reference value may be indicative of actual hardware capabilities of cloud sites, for example, and by comparing the reference value with the total of required node capacities derived from the capacity-related requirements of the service, it may be determined whether the network infrastructure is overprovisioned (i.e., that resources are available in abundance in terms of their capacities) or whether the network infrastructure is underprovisioned (i.e., that not enough resources are available) and that, therefore, node aggregation is required to obtain an aggregated nodes complying with the capacity-related requirements of the service.
The reference value of available node capacities may be determined as one of a sum of available node capacities and an average of available node capacities per site in the cloud computing environment. The reference value of available node capacities may also be determined differently per site in the cloud computing environment,
e.g., according to the number of cloud sites and hardware configuration per cloud site. The above may similarly apply to the classification as a service which requires link aggregation or not, the difference being that, instead of node-related capacities, link-related capacities may be considered. Determining whether link aggregation is required may thus include determining a reference value of available link capacities in the network infrastructure, calculating a total of required link capacities from the one or more capacity-related requirements of the service, and determining whether link aggregation is required based on a comparison of the total of required link capacities with the reference value of available link capacities.
As described above, deployment descriptors may be used to define deployment requirements and the operational behavior of services to be deployed on the network infrastructure. Thus, in one implementation, the capacity related requirements of the service may be derived from a deployment descriptor of the service. Since, in conventional systems, deployment descriptors may be stored in service catalogs, the deployment descriptor of the service may be obtained from a service catalog available in the cloud computing environment. An exemplary deployment descriptor is shown in Figure 6 for illustrative purposes, which, in the shown example, corresponds to a VNFD extracted from ETSI GS NFV-SOL 001, where the nodes are given by VDUs.
When the service corresponds to a network service to be managed on the network infrastructure, the one or more capacity-related requirements of the service may be derived from a network service descriptor of the network service. The network service and the network service descriptor may be understood as a network service and as an NSD as defined in ETSI GS NFV-SOL 001, respectively, such as defined in ETSI GS NFV-SOL 001 V2.5.1 (2018-12) or successor versions thereof. Similarly, when the service corresponds to a virtualized network function to be managed on the network infrastructure, the one or more capacity-related requirements of the service may be derived from a virtualized network function descriptor of the virtualized network function. The virtualized network function and the virtualized network function descriptor may be understood as a VNF and as a VNFD as defined in ETSI GS NFV-SOL 001, respectively, such as defined in ETSI GS NFV-SOL 001 V2.5.1 (2018-12) or successor versions thereof.
Node-related requirements among the one or more capacity-related requirements of the service may be derived from at least one definition of a virtual deployment unit in the deployment descriptor. The virtual deployment unit may be a VDU as defined in
ETSI GS NFV 003, such as defined in ETSI GS NFV 003 Vl.4.1 (2018-08) or successor versions thereof. Similarly, link-related requirements among the one or more capacity-related requirements of the service may be derived from at least one definition of a virtual link in the deployment descriptor. The virtual link may be a VL as defined in ETSI GS NFV 003, such as defined in ETSI GS NFV 003 Vl.4.1 (2018- 08) or successor versions thereof.
The aggregation component may be executed as a standalone component or may be comprised as a subcomponent of another component being executed in the cloud computing environment. In one variant, the aggregated component may be executed as a component of the orchestration component, wherein the orchestration component may be a central orchestration component being centrally responsible for management of services on the network infrastructure in the cloud computing environment. In another variant, the aggregation component may be executed in a distributed manner on at least one of a central orchestration component being centrally responsible for management of services on the network infrastructure in the cloud computing environment and one or more local orchestration components each being locally responsible for management of services on a local network
infrastructure of a site of the cloud computing environment.
Such variants are exemplarily depicted in Figures 7a and 7b, wherein Figure 7a illustrates an example in which the aggregation component 702 (denoted as
"aggregated network inventory" in the figure) is executed as part of a central orchestration component 704. As shown in the figure, the aggregation component 702 may receive as inputs (i) service requirements from a service catalog 706 and
(ii) a representation of resources available in the network infrastructure from a central network inventory 708, which the central orchestration component 704 may build based on topologies of nodes and links of different sites of the cloud computing environment received from one or more local orchestration components 710 which each may maintain a local network inventory 712. As shown in the figure, each local orchestration component 710 may additionally communicate with a virtual infrastructure manager (VIM) 714 of the local site (e.g., via an ETSI Or-Vi reference point) to build up the respective local network inventory 712. Based on the above inputs (i) and (ii), the aggregation component 702 may then generate an aggregated representation as described above.
Figure 7b illustrates another example in which the aggregation component 702 is not executed in a centralized manner by a service provider, but in a distributed manner
across the service provider (hosting the central orchestration component 704) and several cloud providers (hosting the local orchestration component 710) so as to enable an application programming interface (API) based inventory creation and abstraction between a service provider and cloud providers. Respective APIs are denoted as "aggregation API" in the figure. In one such variant, a full representation of the aggregation component 702 may be provided at the central orchestration component 704 and partial representations of the aggregation component 702 may be provided at the local orchestration components 710, for example.
Figure 8 illustrates a method which may be performed by the orchestration component executed on the computing unit 410 according to the present disclosure. The method is dedicated to simplifying management of a service on a network infrastructure in a cloud computing environment. The operation of the orchestration component may be complementary to the operation of the aggregation component described above and, as such, aspects described above with regard to the operation of the orchestration component may be applicable to the operation of the
orchestration component executed on the computing unit 410 described in the following as well, and vice versa. Unnecessary repetitions are thus omitted in the following.
In step S802, the orchestration component may obtain, from an aggregation component, an aggregated representation of resources available in the network infrastructure, the aggregated representation being generated for a service to be managed on the network infrastructure and based on a representation of resources available in the network infrastructure, wherein aggregated resources in the aggregated representation comply with one or more capacity-related requirements of the service to be managed. In step S804, the orchestration component may trigger management of the service based on the aggregated representation. Triggering management of the service based on the aggregated representation may include calculating a placement of the service on the network infrastructure based on the aggregated representation of the resources, and triggering management of the service based on the calculated placement.
Figure 9 illustrates a more detailed method which may be performed by the orchestration component. In step 1 of the method, the orchestration component may receive the aggregated representation as described above in accordance with step S802. Triggering management of the service based on the aggregated representation in accordance with step S804 is exemplified in Figure 9 in that the orchestration
component may receive, in step 2, a request to place a new service. Such request may be received from a placement engine of the cloud computing environment, for example. In step 3, the orchestration component may then identify the aggregated resources related to the real resources so as to determine the real resources which may host the service (i.e., where to place the service). For the following step of performing (or triggering performing) the actual placement of the service, two variants are indicated in the figure. In the first variant of step 4a, the orchestration component may directly access a management interface of the local orchestrator in charge of the aggregated resources and may perform the placement via the management interface. The second variant of step 4b relates to the case that the orchestration component is a central orchestration component. In this case, the orchestration component may delegate the placement to the local orchestrator in charge of the aggregated resources. It will be understood that, while such examples reflect a two-level hierarchy of orchestration, the technique presented herein may be practiced with orchestration hierarchies of more than two levels as well.
Figure 10 illustrates a sequence diagram providing an overview of an overall placement process using the aggregation component 702. As described above, the central network inventory 708 provided at the central orchestration component 704 may request (or discover) resources from the local orchestration components 710 of different cloud sites and build up a central network inventory (cf. steps 1, 2 and 3 of the diagram). In steps 4 and 5, the aggregation component 702 may request the representation of resources from the central network inventory 708 and receive this representation as a "central view". When a request for placement of a new service is received by a placement engine (e.g., executed as part of the central orchestration component 704) in step 6, the placement engine may request an aggregated representation of the resources (denoted "A I view" in the figure) from the aggregation component 702 in step 7. Upon receipt of this request, the aggregation component 702 may request deployment descriptors, such as at least one of an NSD and a VNFD for the service from the service catalog 706 and generate the
aggregated representation of the resources in accordance with the technique presented herein (cf. steps 8, 9 and 10 of the diagram). In step 11, the aggregation component 702 may provide (e.g., send) the aggregated representation to the placement engine which may then proceed to calculate the optimal placement based on the aggregated representation of the resources and, once determined, may trigger the actual placement (e.g., deployment) of the service based on the determined optimal placement, as described above.
In Figure 10, the dashed rectangle surrounding steps 8, 9 and 10 generally indicates that, in one variant, these steps may be performed in an iterative process for a plurality of services (e.g., all services) contained in the service catalog 706 so that the aggregated network inventory maintained by the aggregation component 702 may not only be built up in a stepwise manner upon receipt of respective requests from a placement engine (such as the request in step 7), but in a single round for all services contained in the service catalog 706.
Figure 11 illustrates a more detailed view of an iterative process of building up the aggregated network inventory for a plurality of services contained in the service catalog 706. According to the process, the service requirements (i.e., the capacity- related requirements of the service) may be obtained from the service catalog 706 for each service contained in the service catalog 706 in step 1. As a mere example, the service requirements may be obtained in the form of VDUs and VLs. In step 2, each service may then be classified as a service which requires node aggregation and/or link aggregation. Subsequently, for each service which requires node aggregation, an aggregation of resources may be generated based on nodes in step 3a and, for each service which requires link aggregation, an aggregation of resources may be generated based on links. It will be understood that steps 3a and 3b may be executed mutually exclusive or that both steps 3a and 3b may be performed.
In a graphical form, the original representation of resources available in the network infrastructure and the aggregated representation thereof may be considered as graphs in which nodes correspond to vertices and links correspond to edges between two nodes. In this case, if only node aggregation is required, vertices of cloud sites may be aggregated (e.g., grouped) according to pools of node requirements (e.g., VDU requirements) of the service and the aggregated vertices may be annotated by the sum of the corresponding node resource capacities. Edges from merged vertices may be discarded. If only link aggregation is required, edges of cloud sites may be aggregated (e.g., grouped) according to pools of link requirements (e.g., VL requirements) of the service and the aggregated edges may be annotated by the sum of corresponding link resource capacities. Vertices from merged links may be discarded. If both node aggregation and link aggregation are required, vertices and edges of cloud sites may be aggregated (e.g., grouped) according to pools of node requirements (e.g., VDU requirements) and link requirements (e.g., VL requirements) of the service and the resulting graph may be annotated with both node and link capacities accordingly.
Figure 12 illustrates an exemplary method of carrying out the classification of a service as a service which requires node aggregation or not, i.e., based on
determining whether - given the capacity-related requirements of the service - the network infrastructure is overprovisioned or underprovisioned, as described above. In step 1 of the method, hardware capabilities of the nodes may be obtained from the cloud sites. In step 2, a hardware platform reference (HPR) value may be calculated as a reference value indicative of actual hardware capabilities of cloud sites. In step 3, a summation of the capacity-related service may be computed (in the shown example, a summation of VDU requirements (SVDU)) and, based on the HPR and SVDU, an overprovisioning index (OI) may be calculated. If the calculated 01 then indicates hardware underprovisioning (i.e., indicating that not enough hardware resources are available for the service), it may be determined that the service requires node aggregation in step 5a, to thereby obtain aggregated nodes which comply with the capacity-related requirements of the service. If, on the other hand, the calculated OI indicates overprovisioning (i.e., indicating that hardware resources are available in abundance), it may be determined that the service does not require node aggregation in step 5b. It will be understood that the same procedure may generally be carried out to classify a service as a service which requires link aggregation or not, the only difference being that, instead of node resources, link resources may be used to determine the OI.
Figure 13 illustrates an exemplary implementation of the technique presented herein using ONAP and OpenStack. In the example, so called OpenStack flavors are used as features of node aggregation. In OpenStack, flavors define the compute, memory and storage capacity of Nova computing instances. A flavor may thus correspond to an available hardware configuration for a server and defines the size of a virtual server that can be launched. In order to group vertices of cloud sites according to pools of VDU requirements, OpenStack flavors may be used as follows: (1) for each VNFD, map the set of requirements (e.g., storage, memory) to an OpenStack flavor, compute a summation of VDU requirements, i.e., an SVDU, and map the SVDU to the flavor that minimally supports the deployment of the VNF described in the VNFD, (2) for each flavor identified in (1), obtain compute nodes of the respective flavor and aggregate them to create a single aggregated node, wherein compute nodes of different cloud regions may not be aggregated, and (3) expose the aggregated nodes created in (2) per OpenStack cloud region. An example of such a scenario is illustrated in Figure 13 which shows that compute nodes CN1, CN2 and CN3 have been merged into the single aggregated node "flavor small" providing sufficient resources to comply with the capacity-related requirements of VNFD_1 and compute
nodes CN8, CN9 and CN10 have been merged into the single aggregated node "flavor big" providing sufficient resources to comply with the capacity-related requirements of VNFD_2. As has become apparent from the above, the present disclosure provides a technique for simplifying management of a service on a network infrastructure in a cloud computing environment. Due to the reduced number of nodes and/or links in the aggregated representation of the resources, the computational complexity of the placement problem, i.e., where to best place a service on the available infrastructure, may be alleviated and both network management and service deployment operations may be executed more efficiently, so that the time to deploy a service and to perform life-cycle operations in which service resources are rearranged, such as scaling VNFs or workloads, may be reduced. By considering service requirements in generating the aggregated representation, an aggregated network inventory may be built up which is specifically optimized for the services contained in the service catalog of the cloud computing environment.
It is believed that the advantages of the technique presented herein will be fully understood from the foregoing description, and it will be apparent that various changes may be made in the form, constructions and arrangement of the exemplary aspects thereof without departing from the scope of the invention or without sacrificing all of its advantageous effects. Because the technique presented herein can be varied in many ways, it will be recognized that the invention should be limited only by the scope of the claims that follow.
Claims
1. A method for simplifying management of a service on a network infrastructure in a cloud computing environment, the method being performed by an aggregation component (702) and comprising:
generating (S502), for a service to be managed on the network infrastructure and based on a representation of resources available in the network infrastructure, an aggregated representation of the resources available in the network
infrastructure, wherein aggregated resources in the aggregated representation are computed to comply with one or more capacity-related requirements of the service to be managed; and
providing (S504) the aggregated representation to an orchestration
component (704) for management of the service.
2. The method of claim 1, wherein the resources in the representation comprise nodes and links of the network infrastructure each providing a particular capacity.
3. The method of claim 2, wherein generating (S502) the aggregated
representation of the resources includes:
determining whether at least one of node aggregation and link aggregation is required for the aggregated resources to comply with the one or more capacity- related requirements of the service.
4. The method of claim 3, wherein, when it is determined that node aggregation is required, generating (S502) the aggregated representation of the resources includes:
aggregating at least two nodes of the network infrastructure to obtain an aggregated node that complies with the one or more capacity-related requirements of the service.
5. The method of claim 4, wherein node aggregation is performed under a constraint that nodes at different sites of the cloud computing environment are not to be aggregated.
6. The method of any one of claims 3 to 5, wherein, when it is determined that link aggregation is required, generating (S502) the aggregated representation of the resources includes:
aggregating at least two links of the network infrastructure to obtain an aggregated link that complies with the one or more capacity-related requirements of the service.
7. The method of any one of claims 3 to 6, wherein determining whether node aggregation is required includes:
determining a reference value of available node capacities in the network infrastructure;
calculating a total of required node capacities from the one or more capacity- related requirements of the service; and
determining whether node aggregation is required based on a comparison of the total of required node capacities with the reference value of available node capacities.
8. The method of claim 7, wherein the reference value of available node capacities is determined as one of a sum of available node capacities and an average of available node capacities per site in the cloud computing environment.
9. The method of claim 8, wherein the reference value of available node capacities is determined differently per site in the cloud computing environment.
10. The method of any one of claims 3 to 9, wherein determining whether link aggregation is required includes:
determining a reference value of available link capacities in the network infrastructure;
calculating a total of required link capacities from the one or more capacity- related requirements of the service; and
determining whether link aggregation is required based on a comparison of the total of required link capacities with the reference value of available link capacities.
11. The method of any one of claims 1 to 10, wherein the one or more capacity- related requirements of the service are derived from a deployment descriptor of the service.
12. The method of claim 11, wherein the deployment descriptor of the service is obtained from a service catalog (706) available in the cloud computing environment.
13. The method of any one of claims 1 to 12, wherein, when the service
corresponds to a network service to be managed on the network infrastructure, the one or more capacity-related requirements of the service are derived from a network service descriptor of the network service.
14. The method of any one of claims 1 to 13, wherein, when the service
corresponds to a virtualized network function to be managed on the network infrastructure, the one or more capacity-related requirements of the service are derived from a virtualized network function descriptor of the virtualized network function.
15. The method of any one of claims 1 to 14, wherein node-related requirements among the one or more capacity-related requirements of the service are derived from at least one definition of a virtual deployment unit in the deployment descriptor.
16. The method of any one of claims 1 to 15, wherein link-related requirements among the one or more capacity-related requirements of the service are derived from at least one definition of a virtual link in the deployment descriptor.
17. The method of any one of claims 1 to 16, wherein the aggregation component (702) is executed as a component of the orchestration component (704), wherein the orchestration component (704) is a central orchestration component being centrally responsible for management of services on the network infrastructure in the cloud computing environment.
18. The method of any one of claims 1 to 16, wherein the aggregation component (702) is executed in a distributed manner on at least one of a central orchestration component (704) being centrally responsible for management of services on the network infrastructure in the cloud computing environment and one or more local orchestration components (710) each being locally responsible for management of services on a local network infrastructure of a site of the cloud computing
environment.
19. A method for simplifying management of a service on a network infrastructure in a cloud computing environment, the method being performed by an orchestration component (704) and comprising:
obtaining (S802), from an aggregation component (702), an aggregated representation of resources available in the network infrastructure, the aggregated representation being generated for a service to be managed on the network infrastructure and based on a representation of resources available in the network infrastructure, wherein aggregated resources in the aggregated representation comply with one or more capacity-related requirements of the service to be managed; and
triggering (S804) management of the service based on the aggregated representation.
20. The method of claim 19, wherein triggering (S804) management of the service based on the aggregated representation includes:
calculating a placement of the service on the network infrastructure based on the aggregated representation of the resources; and
triggering management of the service based on the calculated placement.
21. A computer program product comprising program code portions for performing the method of any one of claims 1 to 20 when the computer program product is executed on one or more computing devices.
22. The computer program product of claim 21, stored on a computer readable recording medium.
23. A computing unit (400) configured to execute an aggregation component (702) for simplifying management of a service on a network infrastructure in a cloud computing environment, the computing unit (400) comprising at least one processor (402) and at least one memory (404), the at least one memory (404) containing instructions executable by the at least one processor (402) such that the aggregation component (702) is operable to perform the method of any one of claims 1 to 18.
24. A computing unit (410) configured to execute an orchestration component (704) for simplifying management of a service on a network infrastructure in a cloud computing environment, the computing unit (410) comprising at least one processor (412) and at least one memory (414), the at least one memory (414) containing
instructions executable by the at least one processor (412) such that the orchestration component (704) is operable to perform the method of claim 19 or 20.
25. A system comprising a computing unit (400) according to claim 23 and a computing unit (410) according to claim 24.
Priority Applications (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
PCT/EP2019/058274 WO2020200427A1 (en) | 2019-04-02 | 2019-04-02 | Technique for simplifying management of a service in a cloud computing environment |
EP19715467.7A EP3948536A1 (en) | 2019-04-02 | 2019-04-02 | Technique for simplifying management of a service in a cloud computing environment |
US17/439,551 US20220156125A1 (en) | 2019-04-02 | 2019-04-02 | Technique for Simplifying Management of a Service in a Cloud Computing Environment |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
PCT/EP2019/058274 WO2020200427A1 (en) | 2019-04-02 | 2019-04-02 | Technique for simplifying management of a service in a cloud computing environment |
Publications (1)
Publication Number | Publication Date |
---|---|
WO2020200427A1 true WO2020200427A1 (en) | 2020-10-08 |
Family
ID=66041488
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/EP2019/058274 WO2020200427A1 (en) | 2019-04-02 | 2019-04-02 | Technique for simplifying management of a service in a cloud computing environment |
Country Status (3)
Country | Link |
---|---|
US (1) | US20220156125A1 (en) |
EP (1) | EP3948536A1 (en) |
WO (1) | WO2020200427A1 (en) |
Citations (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20120226789A1 (en) * | 2011-03-03 | 2012-09-06 | Cisco Technology, Inc. | Hiearchical Advertisement of Data Center Capabilities and Resources |
Family Cites Families (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN105939290B (en) * | 2012-08-14 | 2019-07-09 | 华为技术有限公司 | A kind of method and device for distributing resource |
EP2816468A1 (en) * | 2013-06-19 | 2014-12-24 | British Telecommunications public limited company | Evaluating software compliance |
US9813335B2 (en) * | 2014-08-05 | 2017-11-07 | Amdocs Software Systems Limited | System, method, and computer program for augmenting a physical system utilizing a network function virtualization orchestrator (NFV-O) |
US9495211B1 (en) * | 2014-03-04 | 2016-11-15 | Google Inc. | Allocating computing resources based on user intent |
US9424065B2 (en) * | 2014-06-26 | 2016-08-23 | Vmware, Inc. | Methods and apparatus to scale application deployments in cloud computing environments using virtual machine pools |
US9569203B2 (en) * | 2015-03-27 | 2017-02-14 | International Business Machines Corporation | Service-based integration of application patterns |
US9804895B2 (en) * | 2015-08-28 | 2017-10-31 | Vmware, Inc. | Constrained placement in hierarchical randomized schedulers |
-
2019
- 2019-04-02 EP EP19715467.7A patent/EP3948536A1/en active Pending
- 2019-04-02 US US17/439,551 patent/US20220156125A1/en active Pending
- 2019-04-02 WO PCT/EP2019/058274 patent/WO2020200427A1/en unknown
Patent Citations (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20120226789A1 (en) * | 2011-03-03 | 2012-09-06 | Cisco Technology, Inc. | Hiearchical Advertisement of Data Center Capabilities and Resources |
Also Published As
Publication number | Publication date |
---|---|
US20220156125A1 (en) | 2022-05-19 |
EP3948536A1 (en) | 2022-02-09 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10558543B2 (en) | Methods and systems that efficiently store and analyze multidimensional metric data | |
US9851933B2 (en) | Capability-based abstraction of software-defined infrastructure | |
US9503387B2 (en) | Instantiating incompatible virtual compute requests in a heterogeneous cloud environment | |
CN107533483B (en) | Service orchestration | |
Aske et al. | Supporting multi-provider serverless computing on the edge | |
US20170288971A1 (en) | Constraint-Based Virtual Network Function Placement | |
Dräxler et al. | Jasper: Joint optimization of scaling, placement, and routing of virtual network services | |
US11477089B2 (en) | Rack-aware and network performance-aware service deployment | |
Blenk et al. | NeuroViNE: A neural preprocessor for your virtual network embedding algorithm | |
US20180309638A1 (en) | Discovering and publishing device changes in a cloud environment | |
US10862765B2 (en) | Allocation of shared computing resources using a classifier chain | |
US10860375B1 (en) | Singleton coordination in an actor-based system | |
CN113535385A (en) | Virtual network function deployment method, device, equipment and storage medium | |
Garg et al. | Heuristic and reinforcement learning algorithms for dynamic service placement on mobile edge cloud | |
US11748134B2 (en) | Inference engine for configuration parameters in a network functions virtualization orchestrator | |
Bolodurina et al. | Development and research of models of organization storages based on the software-defined infrastructure | |
Shefu et al. | Fruit fly optimization algorithm for network-aware web service composition in the cloud | |
US20220156125A1 (en) | Technique for Simplifying Management of a Service in a Cloud Computing Environment | |
Benomar et al. | Deviceless: A serverless approach for the Internet of Things | |
Wang et al. | Virtual network embedding with pre‐transformation and incentive convergence mechanism | |
US9348672B1 (en) | Singleton coordination in an actor-based system | |
US10372691B1 (en) | Processing platform with metric mapping for interoperability of multiple distinct models | |
Caixinha et al. | ViTeNA: an SDN-based virtual network embedding algorithm for multi-tenant data centers | |
US20210185119A1 (en) | A Decentralized Load-Balancing Method for Resource/Traffic Distribution | |
Auliya et al. | Analysis and prediction of virtual machine boot time on virtualized computing environments |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
121 | Ep: the epo has been informed by wipo that ep was designated in this application |
Ref document number: 19715467 Country of ref document: EP Kind code of ref document: A1 |
|
NENP | Non-entry into the national phase |
Ref country code: DE |
|
ENP | Entry into the national phase |
Ref document number: 2019715467 Country of ref document: EP Effective date: 20211102 |