OPS Area Working Group | Q. Wu |
Internet-Draft | W. Liu |
Intended status: Informational | Huawei Technologies |
Expires: January 6, 2017 | A. Farrel |
Juniper Networks | |
July 5, 2016 |
Service Models Explained
draft-wu-opsawg-service-model-explained-00
The IETF has produced a considerable number of data models in the YANG modelling language. The majority of these are used to model devices and they allow access for configuration and to read operational status.
A small number of YANG models are used to model services (for example, the Layer Three Virtual Private Network Service Model produced by the L3SM working group).
This document briefly sets out the scope of and purpose of an IETF service model, and it shows where a service model might fit into a Software Defined Networking architecture or deployment.
This Internet-Draft is submitted in full conformance with the provisions of BCP 78 and BCP 79.
Internet-Drafts are working documents of the Internet Engineering Task Force (IETF). Note that other groups may also distribute working documents as Internet-Drafts. The list of current Internet-Drafts is at http://datatracker.ietf.org/drafts/current/.
Internet-Drafts are draft documents valid for a maximum of six months and may be updated, replaced, or obsoleted by other documents at any time. It is inappropriate to use Internet-Drafts as reference material or to cite them other than as "work in progress."
This Internet-Draft will expire on January 6, 2017.
Copyright (c) 2016 IETF Trust and the persons identified as the document authors. All rights reserved.
This document is subject to BCP 78 and the IETF Trust's Legal Provisions Relating to IETF Documents (http://trustee.ietf.org/license-info) in effect on the date of publication of this document. Please review these documents carefully, as they describe your rights and restrictions with respect to this document. Code Components extracted from this document must include Simplified BSD License text as described in Section 4.e of the Trust Legal Provisions and are provided without warranty as described in the Simplified BSD License.
In recent years the number of data models written in the YANG modelling langauge [RFC6020] for configuration and monitoring has blossomed. Many of these are used for device-level configuration (for example, [RFC7223]) or for control of protocols (for example, [RFC7407]).
Within the context of Software Defined Networking (SDN) [RFC7426] YANG data models may be used on Southbound Interfaces (SBIs) between a controller and network devices, and between network orchestrators and controllers.
Recently there has been interest in using YANG to define and document data models that describe services in a portable way that is independent of which network operator uses the model. These models may be used in manual and even paper-driven service request processes moving to IT-based mechanisms. Ultimately they could be used in online, software-driven dynamic systems.
This document explains the scope and purpose of service models within the IETF and describes how a service model can be used by a network operator. Equally, this document clarifies what a service model is not, and dispells some common misconceptions.
The following terms are used in this document:
It needs to be repeatedly clarified that a service model is not a data model used to directly configure network devices, protocols, or functions: it is not something that is sent to network devices (i.e., routers or switches) for processing. Equally, a service model is not a data model that describes how a network operator realizes and delivers the service described by the model. This issue is discussed further in later sections.
As already indicated, service models are used on the interface between customers and network operators. This is simply shown in Figure 1
The language in which a service model is described is a choice for whoever specifies the model. The IETF uses the YANG data modeling language defined in [RFC6020]
The encoding and communication protocol used to exchange a service model between customer and network operator are deployment- and implementation-specific. The IETF recommends the use of the NETCONF Configuration Protocol [RFC4741] with data encoded in XML or JSON for interactions "on the wire" between software components. However, co-located software components might use an API, while systems with more direct huan interactions might use web pages or even paper forms.
-------------- ---------------------- | | Service Model | | | Customer | <-----------------> | Network Operator | | | | | -------------- ----------------------
Figure 1: Service Models used on the Interface between Customers and Network Operators
How a network operator processes a service request described be a service model will depend on the commercial and operational tools, processes, and policies used by the operator. These may vary considerably from one network operator to another.
However, the intent is that the network operator maps the service request into configuration and operational parameters that control one or more network to deliver the requested services. That means that the network operator (or software run by the network operator) takes the information in the service model and determines how to deliver the service by enabling and configuring network protocols and devices.
In an SDN system, the control and configuration of network resources and protocols is performed by software systems that determine how best to utilize the network. Figure 2 shows common architectural view of an SDN system where network elements are programmed by a component called a Controller, and where Controllers are instructed by an Orchestrator that has a wider view of the whole of, or part of, a network.
------------------ | | | Orchestrator | | | .------------------. . : . . : . ------------ ------------ ------------ | | | | | | | Controller | | Controller | | Controller | | | | | | | ------------ ------------ ------------ : . . : : . . : : . . : --------- --------- --------- --------- | Network | | Network | | Network | | Network | | Element | | Element | | Element | | Element | --------- --------- --------- ---------
Figure 2: A Common SDN Architecture
But a service request is (or should be) network-agnostic. That is, there should be an independence between the behavior and unctions that a customer requests and the technology that the network operator has available to deliver the service. This means that the service request must be mapped to the Orchestrator's view, and this mapping may include a choice of which networks to use depending on what technologies are available and which service features have been requested.
This mapping can be achieved by splitting the orchestration function between a "Service Orchestrator" and a "Network Orchestrator" as shown in Figure 3. In a system that is fully implemented in software, this could lead to agile service delivery or service automation.
------------------ ---------- | | Service Model | | | Service |<--------------->| Customer | | Orchestrator | | | | | ---------- .------------------. . . . . ------------------ ------------------ | | | | | Network | | Network | | Orchestrator | | Orchestrator | | | | | .------------------ ------------------. . : : . . : : . ------------ ------------ ------------ ------------ | | | | | | | | | Controller | | Controller | | Controller | | Controller | | | | | | | | | ------------ ------------ ------------ ------------ : . . : : : . . : : : . . : : --------- --------- --------- --------- --------- | Network | | Network | | Network | | Network | | Network | | Element | | Element | | Element | | Element | | Element | --------- --------- --------- --------- ---------
Figure 3: An SDN Architecture with a Service Orchestrator
The split between control components that exposes a "service interface" is present in many figures showing extended SDN architectures:
In discussing service models, there are several possible causes of confusion:
This section introduces a few further, more advanced concepts
Service models should generally be technology agnostic. That is to say, the customer should not care how the service is provided so long as the service is delivered.
However, some technologies reach the customer site and make a definition to the type of service delivered. Such features do need to be described in the service model.
Two examples are:
Policy appears as a crucial function in many places during network orchestration. A service orchestrator will, for example, apply the network operator's policies to determine how to provide a service for a particular customer (possibly considering commercial terms). However, the policies within a service model are limited to those over which a customer has direct influence, but which are acted on by the network operator.
The policies that express desired behavior of services on occurrence of specific events are close to SLA definitions: they should only be included in the base service model where they are common to all network operators' offerings. Policies that describe who at a customer may request or modify services (that is, authorization) are close to commercial terms: they, too, should only be included in the base service model where they are common to all network operators' offerings.
Nevertheless, policy is so important that all service models should be designed to be easily extensible to allow policy components to be added and associated with services as needed.
When work in Layer Three Virtual Private Network Service Model (L3SM) ws started, there was some doubt as to whether network operators would be able to agree on a common description of the services that they offer to their customers because, in a competitive environment, each markets the services in a different way with different additional features. Thus, when a basic description of the core service is agreed and documented in a service model, it is important that that model should be easily extended or augmented by each network operator so that the standardized model can be used in a common way and only the operator- specific features vary from one environment to another.
Network operators will, in general, offer many different services to their customers. Each would normally be the subject of a separate service model.
It is an implementation and deployment choice whether all service models are processed by a single Service Orchestrator that can coordinate between the different services, or whether each service model is handled by a specialized Service Orchestrator able to provide tuned behavior for a specific service.
TBD
TBD
This document makes no requests for IANA action
Thanks to Daniel King for review comments.
[RFC3444] | Pras, A. and J. Schoenwaelder, "On the Difference between Information Models and Data Models", RFC 3444, DOI 10.17487/RFC3444, January 2003. |
[RFC7426] | Haleplidis, E., Pentikousis, K., Denazis, S., Hadi Salim, J., Meyer, D. and O. Koufopavlou, "Software-Defined Networking (SDN): Layers and Architecture Terminology", RFC 7426, DOI 10.17487/RFC7426, January 2015. |
[RFC4741] | Enns, R., "NETCONF Configuration Protocol", RFC 4741, DOI 10.17487/RFC4741, December 2006. |
[RFC6020] | Bjorklund, M., "YANG - A Data Modeling Language for the Network Configuration Protocol (NETCONF)", RFC 6020, DOI 10.17487/RFC6020, October 2010. |
[RFC7223] | Bjorklund, M., "A YANG Data Model for Interface Management", RFC 7223, DOI 10.17487/RFC7223, May 2014. |
[RFC7407] | Bjorklund, M. and J. Schoenwaelder, "A YANG Data Model for SNMP Configuration", RFC 7407, DOI 10.17487/RFC7407, December 2014. |
[RFC7491] | King, D. and A. Farrel, "A PCE-Based Architecture for Application-Based Network Operations", RFC 7491, DOI 10.17487/RFC7491, March 2015. |