Network Working Group                                     F. Le Faucheur
Request for Comments: 3564                           Cisco Systems, Inc.
Category: Informational                                           W. Lai
                                                                    AT&T
                                                               July 2003
       Requirements for Support of Differentiated Services-aware
                     MPLS Traffic Engineering
Status of this Memo
   This memo provides information for the Internet community.  It does
   not specify an Internet standard of any kind.  Distribution of this
   memo is unlimited.
Copyright Notice
   Copyright (C) The Internet Society (2003).  All Rights Reserved.
Abstract
   This document presents Service Provider requirements for support of
   Differentiated Services (Diff-Serv)-aware MPLS Traffic Engineering
   (DS-TE).
   Its objective is to provide guidance for the definition, selection
   and specification of a technical solution addressing these
   requirements.  Specification for this solution itself is outside the
   scope of this document.
   A problem statement is first provided.  Then, the document describes
   example applications scenarios identified by Service Providers where
   existing MPLS Traffic Engineering mechanisms fall short and
   Diff-Serv-aware Traffic Engineering can address the needs.  The
   detailed requirements that need to be addressed by the technical
   solution are also reviewed.  Finally, the document identifies the
   evaluation criteria that should be considered for selection and
   definition of the technical solution.
Le Faucheur & Lai            Informational                      [Page 1]RFC 3564          Requirements for Diff-Serv-aware TE          July 2003
Table of Contents
   Specification Requirements .......................................  2
   1.  Introduction .................................................  3
       1.1.  Problem Statement ......................................  3
       1.2.  Definitions ............................................  3
       1.3.  Mapping of traffic to LSPs .............................  5
   2.  Application Scenarios ........................................  6
       2.1.  Scenario 1: Limiting Proportion of Classes on a Link ...  6
       2.2.  Scenario 2: Maintain relative proportion of traffic ....  6
       2.3.  Scenario 3: Guaranteed Bandwidth Services ..............  8
   3.  Detailed Requirements for DS-TE ..............................  9
       3.1.  DS-TE Compatibility ....................................  9
       3.2.  Class-Types ............................................  9
       3.3.  Bandwidth Constraints .................................. 11
       3.4.  Preemption and TE-Classes .............................. 12
       3.5.  Mapping of Traffic to LSPs ............................. 15
       3.6.  Dynamic Adjustment of Diff-Serv PHBs ................... 15
       3.7.  Overbooking ............................................ 16
       3.8.  Restoration ............................................ 16
   4.  Solution Evaluation Criteria ................................. 16
       4.1.  Satisfying detailed requirements ....................... 17
       4.2.  Flexibility ............................................ 17
       4.3.  Extendibility .......................................... 17
       4.4.  Scalability ............................................ 17
       4.5.  Backward compatibility/Migration ....................... 17
       4.6.  Bandwidth Constraints Model ............................ 18
   5.  Security Considerations ...................................... 18
   6.  Acknowledgment ............................................... 18
   7.  Normative References ......................................... 18
   8.  Informative References ....................................... 19
   9.  Contributing Authors ......................................... 20
   10. Editors' Addresses ........................................... 21
   11. Full Copyright Statement ..................................... 22
Specification Requirements
   The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT",
   "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this
   document are to be interpreted as described in [RFC2119].
Le Faucheur & Lai            Informational                      [Page 2]RFC 3564          Requirements for Diff-Serv-aware TE          July 2003
1.  Introduction
1.1.  Problem Statement
   Diff-Serv is used by some Service Providers to achieve scalable
   network designs supporting multiple classes of services.
   In some such Diff-Serv networks, where optimization of transmission
   resources on a network-wide basis is not sought, MPLS Traffic
   Engineering (TE) mechanisms may not be used.
   In other networks, where optimization of transmission resources is
   sought, Diff-Serv mechanisms [DIFF-MPLS] may be complemented by
   MPLS Traffic Engineering mechanisms [TE-REQ] [ISIS-TE] [OSPF-TE]
   [RSVP-TE] which operate on an aggregate basis across all
   Diff-Serv classes of service.  In this case, Diff-Serv and MPLS TE
   both provide their respective benefits.
   To achieve fine-grained optimization of transmission resources and
   further enhanced network performance and efficiency, as discussed in
   [TEWG-FW], it may be desirable to perform traffic engineering at a
   per-class level instead of at an aggregate level.  By mapping the
   traffic from a given Diff-Serv class of service on a separate LSP, it
   allows this traffic to utilize resources available to the given class
   on both shortest paths and non-shortest paths, and follow paths that
   meet engineering constraints which are specific to the given class.
   This is what we refer to as "Diff-Serv-aware Traffic Engineering
   (DS-TE)".
   This document focuses exclusively on the specific environments which
   would benefit from DS-TE.  Some examples include:
     -    networks where bandwidth is scarce (e.g., transcontinental
          networks)
     -    networks with significant amounts of delay-sensitive traffic
     -    networks where the relative proportion of traffic across
          classes of service is not uniform
   This document focuses on intra-domain operation.  Inter-domain
   operation is not considered.
1.2.  Definitions
   For the convenience of the reader, relevant Diff-Serv ([DIFF-ARCH],
   [DIFF-NEW] and [DIFF-PDB]) definitions are repeated herein.
      Behavior Aggregate (BA): a collection of packets with the same
      (Diff-Serv) codepoint crossing a link in a particular direction.
Le Faucheur & Lai            Informational                      [Page 3]RFC 3564          Requirements for Diff-Serv-aware TE          July 2003
      Per-Hop-Behavior (PHB): the externally observable forwarding
      behavior applied at a DS-compliant node to a Diff-Serv behavior
      aggregate.
      PHB Scheduling Class (PSC): A PHB group for which a common
      constraint is that ordering of at least those packets belonging to
      the same microflow must be preserved.
      Ordered Aggregate (OA): a set of BAs that share an ordering
      constraint.  The set of PHBs that are applied to this set of
      Behavior Aggregates constitutes a PHB scheduling class.
      Traffic Aggregate (TA): a collection of packets with a codepoint
      that maps to the same PHB, usually in a DS domain or some subset
      of a DS domain.  A traffic aggregate marked for the foo PHB is
      referred to as the "foo traffic aggregate" or "foo aggregate"
      interchangeably.  This generalizes the concept of Behavior
      Aggregate from a link to a network.
      Per-Domain Behavior (PDB): the expected treatment that an
      identifiable or target group of packets will receive from
      "edge-to-edge" of a DS domain.  A particular PHB (or, if
      applicable, list of PHBs) and traffic conditioning requirements
      are associated with each PDB.
   We also repeat the following definition from [TE-REQ]:
      Traffic Trunk: an aggregation of traffic flows of the same class
      which are placed inside a Label Switched Path.
   In the context of the present document, "flows of the same class" is
   to be interpreted as "flows from the same Forwarding Equivalence
   Class which are to be treated equivalently from the DS-TE
   perspective".
      We refer to the set of TAs corresponding to the set of PHBs of a
      given PSC, as a {TA}PSC.  A given {TA}PSC will receive the
      treatment of the PDB associated with the corresponding PSC.  In
      this document, we also loosely refer to a {TA}PSC as a "Diff-Serv
      class of service", or a "class of service".  As an example, the
      set of packets within a DS domain with a codepoint that maps to
      the EF PHB may form one {TA}PSC in that domain.  As another
      example, the set of packets within a DS domain with a codepoint
      that maps to the AF11 or AF12 or AF13 PHB may form another {TA}PSC
      in that domain.
Le Faucheur & Lai            Informational                      [Page 4]RFC 3564          Requirements for Diff-Serv-aware TE          July 2003
   We refer to the collection of packets which belong to a given Traffic
   Aggregate and are associated with a given MPLS Forwarding Equivalence
   Class (FEC) ([MPLS-ARCH]) as a <FEC/TA>.
   We refer to the set of <FEC/TA> whose TAs belong to a given {TA}PSC
   as a <FEC/{TA}PSC>.
1.3.  Mapping of traffic to LSPs
   A network may have multiple Traffic Aggregates (TAs) it wishes to
   service.  Recalling from [DIFF-MPLS], there are several options on
   how the set of <FEC/{TA}PSC> of a given FEC can be split into Traffic
   Trunks for mapping onto LSPs when running MPLS Traffic Engineering.
   One option is to not split this set of <FEC/{TA}PSC> so that each
   Traffic Trunk comprises traffic from all the {TA}/PSC.  This option
   is typically used when aggregate traffic engineering is deployed
   using current MPLS TE mechanisms.  In that case, all the
   <FEC/{TA}PSC> of a given FEC are routed collectively according to a
   single shared set of constraints and will follow the same path.  Note
   that the LSP transporting such a Traffic Trunk is, by definition, an
   E-LSP as defined in [DIFF-MPLS].
   Another option is to split the different <FEC/{TA}PSC> of a given FEC
   into multiple Traffic Trunks on the basis of the {TA}PSC.  In other
   words, traffic, from one given node to another, is split, based on
   the "classes of service", into multiple Traffic Trunks which are
   transported over separate LSP and can potentially follow different
   paths through the network.  DS-TE takes advantage of this and
   computes a separate path for each LSP.  In so doing, DS-TE can take
   into account the specific requirements of the Traffic Trunk
   transported on each LSP (e.g., bandwidth requirement, preemption
   priority).  Moreover DS-TE can take into account the specific
   engineering constraints to be enforced for these sets of Traffic
   Trunks (e.g., limit all Traffic Trunks transporting a particular
   {TA}PSC to x% of link capacity).  DS-TE achieves per LSP constraint
   based routing with paths that match specific objectives of the
   traffic while forming the corresponding Traffic Trunk.
   For simplicity, and because this is the specific topic of this
   document, the above paragraphs in this section only considered
   splitting traffic of a given FEC into multiple Traffic Aggregates on
   the basis of {TA}PSC.  However, it should be noted that, in addition
   to this, traffic from every {TA}PSC may also be split into multiple
   Traffic Trunks for load balancing purposes.
Le Faucheur & Lai            Informational                      [Page 5]RFC 3564          Requirements for Diff-Serv-aware TE          July 2003
2.  Application Scenarios
2.1.  Scenario 1: Limiting Proportion of Classes on a Link
   An IP/MPLS network may need to carry a significant amount of VoIP
   traffic compared to its link capacity.  For example, 10,000
   uncompressed calls at 20ms packetization result in about 1Gbps of IP
   traffic, which is significant on an OC-48c based network.  In case of
   topology changes such as link/node failure, VoIP traffic levels can
   even approach the full bandwidth on certain links.
   For delay/jitter reasons, some network administrators see it as
   undesirable to carry more than a certain percentage of VoIP traffic
   on any link.  The rest of the available link bandwidth can be used to
   route other "classes of service" corresponding to delay/jitter
   insensitive traffic (e.g.,  Best Effort Internet traffic).  The exact
   determination of this "certain" percentage is outside the scope of
   this requirements document.
   During normal operations, the VoIP traffic should be able to preempt
   other "classes of service" (if these other classes are designated as
   preemptable and they have lower preemption priority), so that it will
   be able to use the shortest available path, only constrained by the
   maximum defined link utilization ratio/percentage of the VoIP class.
   Existing TE mechanisms only allow constraint based routing of traffic
   based on a single bandwidth constraint common to all "classes of
   service", which does not satisfy the needs described here.  This
   leads to the requirement for DS-TE to be able to enforce a different
   bandwidth constraint for different "classes of service".  In the
   above example, the bandwidth constraint to be enforced for VoIP
   traffic may be the "certain" percentage of each link capacity, while
   the bandwidth constraint to be enforced for the rest of the "classes
   of service" might have their own constraints or have access to the
   rest of the link capacity.
2.2.  Scenario 2: Maintain relative proportion of traffic
   Suppose an IP/MPLS network supports 3 "classes of service".  The
   network administrator wants to perform Traffic Engineering to
   distribute the traffic load.  Also assume that proportion across
   "classes of service" varies significantly depending on the
   source/destination POPs.
Le Faucheur & Lai            Informational                      [Page 6]
RFC 3564          Requirements for Diff-Serv-aware TE          July 2003
   With existing TE mechanisms, the proportion of traffic from each
   "class of service" on a given link will vary depending on multiple
   factors including:
   - in which order the different TE-LSPs are established
   - the preemption priority associated with the different TE-LSPs
   - link/node failure situations
   This may make it difficult or impossible for the network
   administrator to configure the Diff-Serv PHBs (e.g., queue bandwidth)
   to ensure that each "class of service" gets the appropriate
   treatment.  This leads again to the requirement for DS-TE to be able
   to enforce a different bandwidth constraint for different "classes of
   service".  This could be used to ensure that, regardless of the order
   in which tunnels are routed, regardless of their preemption priority
   and regardless of the failure situation, the amount of traffic of
   each "class of service" routed over a link matches the Diff-Serv
   scheduler configuration on that link to the corresponding class
   (e.g., queue bandwidth).
   As an illustration of how DS-TE would address this scenario, the
   network administrator may configure the service rate of Diff-Serv
   queues to (45%,35%,20%) for "classes of service" (1,2,3)
   respectively.  The administrator would then split the traffic into
   separate Traffic Trunks for each "class of service" and associate a
   bandwidth to each LSP transporting those Traffic Trunks.  The network
   administrator may also want to configure preemption priorities of
   each LSP in order to give highest restoration priority to the highest
   priority "class of service" and medium priority to the medium "class
   of service".  Then DS-TE could ensure that after a failure, "class of
   service" 1 traffic would be rerouted with first access at link
   capacity without exceeding its service rate of 45% of the link
   bandwidth.  "Class of service" 2 traffic would be rerouted with
   second access at the link capacity without exceeding its allotment.
   Note that where "class of service" 3 is the Best-Effort service, the
   requirement on DS-TE may be to ensure that the total amount of
   traffic routed across all "classes of service" does not exceed the
   total link capacity of 100% (as opposed to separately limiting the
   amount of Best Effort traffic to 20 even if there was little "class
   of service" 1 and "class of service" 2 traffic).
   In this scenario, DS-TE would allow for the maintenance of a more
   steady distribution of "classes of service", even during rerouting.
   This would rely on the required capability of DS-TE to adjust the
   amount of traffic of each "class of service"  routed on a link based
   on the configuration of the scheduler and the amount of bandwidth
   available for each "class of service".
Le Faucheur & Lai            Informational                      [Page 7]
RFC 3564          Requirements for Diff-Serv-aware TE          July 2003
   Alternatively, some network administrators may want to solve the
   problem by having the scheduler dynamically adjusted based on the
   amount of bandwidth of the LSPs admitted for each "class of service".
   This is an optional additional requirement on the DS-TE solution.
2.3.  Scenario 3: Guaranteed Bandwidth Services
   In addition to the Best effort service, an IP/MPLS network operator
   may desire to offer a point-to-point "guaranteed bandwidth" service
   whereby the provider pledges to provide a given level of performance
   (bandwidth/delay/loss...) end-to-end through its network from an
   ingress port to an egress port.  The goal is to ensure that all the
   "guaranteed" traffic under the scope of a subscribed service level
   specification, will be delivered within the tolerances of this
   service level specification.
   One approach for deploying such "guaranteed" service involves:
   - dedicating a Diff-Serv PHB (or a Diff-Serv PSC as defined in
     [DIFF-NEW]) to the "guaranteed" traffic
   - policing guaranteed traffic on ingress against the traffic contract
     and marking the "guaranteed" packets with the corresponding
     DSCP/EXP value
   Where a very high level of performance is targeted for the
   "guaranteed" service, it may be necessary to ensure that the amount
   of "guaranteed" traffic remains below a given percentage of link
   capacity on every link.  Where the proportion of "guaranteed" traffic
   is high, constraint based routing can be used to enforce such a
   constraint.
   However, the network operator may also want to simultaneously perform
   Traffic Engineering for the rest of the traffic (i.e.,
   non-guaranteed traffic) which would require that constraint based
   routing is also capable of enforcing a different bandwidth
   constraint, which would be less stringent than the one for guaranteed
   traffic.
   Again, this combination of requirements can not be addressed with
   existing TE mechanisms.  DS-TE mechanisms allowing enforcement of a
   different bandwidth constraint for guaranteed traffic and for
   non-guaranteed traffic are required.
Le Faucheur & Lai            Informational                      [Page 8]RFC 3564          Requirements for Diff-Serv-aware TE          July 2003
3.  Detailed Requirements for DS-TE
   This section specifies the functionality that the above scenarios
   require out of the DS-TE solution.  Actual technical protocol
   mechanisms and procedures to achieve such functionality are outside
   the scope of this document.
3.1.  DS-TE Compatibility
   Since DS-TE may impact scalability (as discussed later in this
   document) and operational practices, DS-TE is expected to be used
   when existing TE mechanisms combined with Diff-Serv cannot address
   the network design requirements (i.e., where constraint based routing
   is required and where it needs to enforce different bandwidth
   constraints for different "classes of service", such as in the
   scenarios described above in section 2).  Where the benefits of DSTE
   are only required in a topological subset of their network, some
   network operators may wish to only deploy DS-TE in this topological
   subset.
   Thus, the DS-TE solution MUST be developed in such a way that:
   (i)    it raises no interoperability issues with existing deployed TE
          mechanisms.
   (ii)   it allows DS-TE deployment to the required level of
          granularity and scope (e.g., only in a subset of the topology,
          or only for the number of classes required in the considered
          network)
3.2.  Class-Types
   The fundamental requirement for DS-TE is to be able to enforce
   different bandwidth constraints for different sets of Traffic Trunks.
   [TEWG-FW] introduces the concept of Class-Types when discussing
   operations of MPLS Traffic Engineering in a Diff-Serv environment.
   We refine this definition into the following:
            Class-Type (CT): the set of Traffic Trunks crossing a link,
            that is governed by a specific set of Bandwidth constraints.
            CT is used for the purposes of link bandwidth allocation,
            constraint based routing and admission control.  A given
            Traffic Trunk belongs to the same CT on all links.
   Note that different LSPs transporting Traffic Trunks from the same CT
   may be using the same or different preemption priorities as explained
   in more details in section 3.4 below.
Le Faucheur & Lai            Informational                      [Page 9]RFC 3564          Requirements for Diff-Serv-aware TE          July 2003
   Mapping of {TA}PSC to Class-Types is flexible.  Different {TA}PSC can
   be mapped to different CTs, multiple {TA}PSC can be mapped to the
   same CT and one {TA}PSC can be mapped to multiple CTs.
   For illustration purposes, let's consider the case of a network
   running 4 Diff-Serv PDBs which are respectively based on the EF PHB
   [EF], the AF1x PSC [AF], the AF2x PSC and the Default (i.e.,
   Best-Effort) PHB [DIFF-FIELD].  The network administrator may decide
   to deploy DS-TE in the following way:
         o  from every DS-TE Head-end to every DS-TE Tail-end, split the
            traffic into 4 Traffic Trunks: one for traffic of each
            {TA}PSC
         o  because the QoS objectives for the AF1x PDB and for the AF2x
            PDB may be of similar nature (e.g., both targeting low loss
            albeit at different levels perhaps), the same (set of)
            Bandwidth Constraint(s) may be applied collectively over the
            AF1x Traffic Trunks and the AF2x Traffic Trunks.  Thus, the
            network administrator may only define three CTs: one for the
            EF Traffic Trunks, one for the AF1x and AF2x Traffic Trunks
            and one for the Best Effort Traffic Trunks.
   As another example of mapping of {TA}PSC to CTs, a network operator
   may split the traffic from the {TA}PSC associated with EF into two
   different sets of traffic trunks, so that each set of traffic trunks
   is subject to different constraints on the bandwidth it can access.
   In this case, two distinct CTs are defined for the EF {TA}PSC
   traffic:  one for the traffic subset subject to the first (set of)
   bandwidth constraint(s), the other for the traffic subset subject to
   the second (set of) bandwidth constraint(s).
   The DS-TE solution MUST support up to 8 CTs.  Those are referred to
   as CTc, 0 <= c <= MaxCT-1 = 7.
   The DS-TE solution MUST be able to enforce a different set of
   Bandwidth Constraints for each CT.
   A DS-TE implementation MUST support at least 2 CTs, and MAY support
   up to 8 CTs.
   In a given network, the DS-TE solution MUST NOT require the network
   administrator to always deploy the maximum number of CTs.  The DS-TE
   solution MUST allow the network administrator to deploy only the
   number of CTs actually utilized.
Le Faucheur & Lai            Informational                     [Page 10]RFC 3564          Requirements for Diff-Serv-aware TE          July 2003
3.3.  Bandwidth Constraints
   We refer to a Bandwidth Constraint Model as the set of rules
   defining:
   - the maximum number of Bandwidth Constraints; and
   - which CTs each Bandwidth Constraint applies to and how.
   By definition of CT, each CT is assigned either a Bandwidth
   Constraint, or a set of Bandwidth Constraints.
   We refer to the Bandwidth Constraints as BCb, 0 <= b <= MaxBC-1
   For a given Class-Type CTc, 0 <= c <= MaxCT-1, let us define
   "Reserved(CTc)" as the sum of the bandwidth reserved by all
   established LSPs which belong to CTc.
   Different models of Bandwidth Constraints are conceivable for control
   of the CTs.
   For example, a model with one separate Bandwidth Constraint per CT
   could be defined.  This model is referred to as the "Maximum
   Allocation Model" and is defined by:
        - MaxBC= MaxCT
        - for each value of b in the range 0 <= b <= (MaxCT - 1):
               Reserved (CTb) <= BCb
   For illustration purposes, on a link of 100 unit of bandwidth where
   three CTs are used, the network administrator might then configure
   BC0=20, BC1= 50, BC2=30 such that:
   - All LSPs supporting Traffic Trunks from CT2 use no more than 30
     (e.g., Voice <= 30)
   - All LSPs supporting Traffic Trunks from CT1 use no more than 50
     (e.g., Premium Data <= 50)
   - All LSPs supporting Traffic Trunks from CT0 use no more than 20
     (e.g.,  Best Effort <= 20)
   As another example, a "Russian Doll" model of Bandwidth Constraints
   may be defined whereby:
        - MaxBC= MaxCT
        - for each value of b in the range 0 <= b <= (MaxCT - 1):
               SUM (Reserved (CTc)) <= BCb,
               for all "c" in the range  b <= c <= (MaxCT - 1)
Le Faucheur & Lai            Informational                     [Page 11]RFC 3564          Requirements for Diff-Serv-aware TE          July 2003
   For illustration purposes, on a link of 100 units of bandwidth where
   three CTs are used, the network administrator might then configure
   BC0=100, BC1= 80, BC2=60 such that:
   - All LSPs supporting Traffic Trunks from CT2 use no more than 60
     (e.g., Voice <= 60)
   - All LSPs supporting Traffic Trunks from CT1 or CT2 use no more than
     80 (e.g., Voice + Premium Data <= 80)
   - All LSPs supporting Traffic Trunks from CT0 or CT1 or CT2 use no
     more than 100 (e.g., Voice + Premium Data + Best Effort <= 100).
   Other Bandwidth Constraints model can also be conceived.  Those could
   involve arbitrary relationships between BCb and CTc.  Those could
   also involve additional concepts such as associating minimum
   reservable bandwidth to a CT.
   The DS-TE technical solution MUST have the capability to support
   multiple Bandwidth Constraints models.  The DS-TE technical solution
   MUST specify at least one bandwidth constraint model and MAY specify
   multiple Bandwidth Constraints models.  Additional Bandwidth
   Constraints models MAY also be specified at a later stage if deemed
   useful based on operational experience from DS-TE deployments.  The
   choice of which (or which set of) Bandwidth Constraints model(s) is
   to be supported by a given DS-TE implementation, is an implementation
   choice.  For simplicity, a network operator may elect to use the same
   Bandwidth Constraints Model on all the links of his/her network.
   However, if he/she wishes/needs to do so, the network operator may
   elect to use different Bandwidth Constraints models on different
   links in a given network.
   Regardless of the Bandwidth Constraint Model, the DS-TE solution MUST
   allow support for up to 8 BCs.
3.4.  Preemption and TE-Classes
   [TEWG-FW] defines the notion of preemption and preemption priority.
   The DS-TE solution MUST retain full support of such preemption.
   However, a network administrator preferring not to use preemption for
   user traffic MUST be able to disable the preemption mechanisms
   described below.
   The preemption attributes defined in [TE-REQ] MUST be retained and
   applicable across all Class Types.  The preemption attributes of
   setup priority and holding priority MUST retain existing semantics,
   and in particular these semantics MUST not be affected by the Ordered
   Aggregate transported by the LSP or by the LSP's Class Type.  This
   means that if LSP1 contends with LSP2 for resources, LSP1 may preempt
   LSP2 if LSP1 has a higher set-up preemption priority (i.e., lower
Le Faucheur & Lai            Informational                     [Page 12]RFC 3564          Requirements for Diff-Serv-aware TE          July 2003
   numerical priority value) than LSP2's holding preemption priority
   regardless of LSP1's OA/CT and LSP2's OA/CT.
   We introduce the following definition:
       TE-Class: A pair of:
               (i)    a Class-Type
               (ii)   a preemption priority allowed for that
                      Class-Type.  This means that an LSP transporting a
                      Traffic Trunk from that Class-Type can use that
                      preemption priority as the set-up priority, as the
                      holding priority or both.
   Note that by definition:
   - for a given Class-Type, there may be one or multiple
     TE-classes using that Class-Type, each using a different preemption
     priority
   - for a given preemption priority, there may be one or multiple
     TE-Class(es) using that preemption priority, each using a different
     Class-Type.
   The DS-TE solution MUST allow all LSPs transporting Traffic Trunks of
   a given Class-Type to use the same preemption priority.  In other
   words, the DS-TE solution MUST allow a Class-Type to be used by
   single TE-Class.  This effectively allows the network administrator
   to ensure that no preemption happens within that Class-Type, when so
   desired.
   As an example, the DS-TE solution MUST allow the network
   administrator to define a Class-Type comprising a single TE-class
   using preemption 0.
   The DS-TE solution MUST allow two LSPs transporting Traffic Trunks of
   the same Class-Type to use different preemption priorities, and allow
   the LSP with higher (numerically lower) set-up priority to preempt
   the LSP with lower (numerically higher) holding priority when they
   contend for resources.  In other words, the DS-TE solution MUST allow
   multiple TE-Classes to be defined for a given Class-Type. This
   effectively allows the network administrator to enable preemption
   within a Class-Type, when so desired.
   As an example, the DS-TE solution MUST allow the network
   administrator to define a Class-Type comprising three TE-Classes; one
   using preemption 0, one using preemption 1 and one using preemption
   4.
Le Faucheur & Lai            Informational                     [Page 13]RFC 3564          Requirements for Diff-Serv-aware TE          July 2003
   The DS-TE solution MUST allow two LSPs transporting Traffic Trunks
   from different Class-Types to use different preemption priorities,
   and allow the LSP with higher setup priority to preempt the one with
   lower holding priority when they contend for resources.
   As an example, the DS-TE solution MUST allow the network
   administrator to define two Class-Types (CT0 and CT1) each comprising
   two TE-Classes where say:
      -one TE-Class groups CT0 and preemption 0
      -one TE-Class groups CT0 and preemption 2
      -one TE-Class groups CT1 and preemption 1
      -one TE-Class groups CT1 and preemption 3
   The network administrator would then, in particular, be able to:
   - transport a CT0 Traffic Trunk over an LSP with setup priority=0 and
     holding priority=0
   - transport a CT0 Traffic Trunk over an LSP with setup priority=2 and
     holding priority=0
   - transport a CT1 Traffic Trunk over an LSP with setup priority=1 and
     holding priority=1
   - transport a CT1 Traffic Trunk over an LSP with setup priority=3 and
     holding priority=1.
   The network administrator would then, in particular, NOT be able to:
   - transport a CT0 Traffic Trunk over an LSP with setup priority=1 and
     holding priority=1
   - transport a CT1 Traffic Trunk over an LSP with setup priority=0 and
     holding priority=0
   The DS-TE solution MUST allow two LSPs transporting Traffic Trunks
   from different Class-Types to use the same preemption priority.  In
   other words, the DS-TE solution MUST allow TE-classes using different
   CTs to use the same preemption priority.  This effectively allows the
   network administrator to ensure that no preemption happens across
   Class-Types, if so desired.
   As an example, the DS-TE solution MUST allow the network
   administrator to define three Class-Types (CT0, CT1 and CT2) each
   comprising one TE-Class which uses preemption 0.  In that case, no
   preemption will ever occur.
   Since there are 8 preemption priorities and up to 8 Class-Types,
   there could theoretically be up to 64 TE-Classes in a network.  This
   is felt to be beyond current practical requirements.  The current
   practical requirement is that the DS-TE solution MUST allow support
Le Faucheur & Lai            Informational                     [Page 14]RFC 3564          Requirements for Diff-Serv-aware TE          July 2003
   for up to 8 TE-classes.  The DS-TE solution MUST allow these
   TE-classes to comprise any arbitrary subset of 8 (or less) from the
   (64) possible combinations of (8) Class-Types and (8) preemption
   priorities.
   As with existing TE, an LSP which gets preempted is torn down at
   preemption time.  The Head-end of the preempted LSP may then attempt
   to reestablish that LSP, which involves re-computing a path by
   Constraint Based Routing based on updated available bandwidth
   information and then signaling for LSP establishment along the new
   path.  It is to be noted that there may be cases where the preempted
   LSP cannot be reestablished (e.g., no possible path satisfying LSP
   bandwidth constraints as well as other constraints).  In such cases,
   the Head-end behavior is left to implementation.  It may involve
   periodic attempts at reestablishing the LSP, relaxing of the LSP
   constraints, or other behaviors.
3.5.  Mapping of Traffic to LSPs
   The DS-TE solution MUST allow operation over E-LSPs onto which a
   single <FEC/{TA}PSC> is transported.
   The DS-TE solution MUST allow operation over L-LSPs.
   The DS-TE solution MAY allow operation over E-LSPs onto which
   multiple <FEC/{TA}PSC> of a given FEC are transported, under the
   condition that those multiple <FEC/{TA}PSC> can effectively be
   treated by DS-TE as a single atomic traffic trunk (in particular this
   means that those multiple <FEC/{TA}PSC> are routed as a whole based
   on a single collective bandwidth requirement, a single affinity
   attribute, a single preemption level, a single Class-Type, etc.).  In
   that case, it is also assumed that the multiple {TA}PSCs are grouped
   together in a consistent manner throughout the DS-TE domain (e.g., if
   <FECx/{TA}PSC1> and <FECx/{TA}PSC2> are transported together on an
   E-LSP, then there will not be any L-LSP transporting <FECy/{TA}PSC1>
   or <FECy/{TA}PSC2> on its own, and there will not be any E-LSP
   transporting <FECz/{TA}PSC1> and/or <FECz/{TA}PSC2> with
   <FECz/{TA}PSC3>).
3.6.  Dynamic Adjustment of Diff-Serv PHBs
   As discussed in section 2.2, the DS-TE solution MAY support
   adjustment of Diff-Serv PHBs parameters (e.g., queue bandwidth) based
   on the amount of TE-LSPs established for each OA/Class-Type.  Such
   dynamic adjustment is optional for DS-TE implementations.
Le Faucheur & Lai            Informational                     [Page 15]RFC 3564          Requirements for Diff-Serv-aware TE          July 2003
   Where this dynamic adjustment is supported, it MUST allow for
   disabling via configuration (thus reverting to PHB treatment with
   static scheduler configuration independent of DS-TE operations).  It
   MAY involve a number of configurable parameters which are outside the
   scope of this specification.  Those MAY include configurable
   parameters controlling how scheduling resources (e.g., service rates)
   need to be apportioned across multiple OAs when those belong to the
   same Class-Type and are transported together on the same E-LSP.
   Where supported, the dynamic adjustment MUST take account of the
   performance requirements of each PDB when computing required
   adjustments.
3.7.  Overbooking
   Existing TE mechanisms allow overbooking to be applied on LSPs for
   Constraint Based Routing and admission control.  Historically, this
   has been achieved in TE deployment through factoring overbooking
   ratios at the time of sizing the LSP bandwidth and/or at the time of
   configuring the Maximum Reservable Bandwidth on links.
   The DS-TE solution MUST also allow overbooking and MUST effectively
   allow different overbooking ratios to be enforced for different CTs.
   The DS-TE solution SHOULD optionally allow the effective overbooking
   ratio of a given CT to be tweaked differently in different parts of
   the network.
3.8.  Restoration
   With existing TE, restoration policies use standard priority
   mechanisms such as, for example, the preemption priority to
   effectively control the order/importance of LSPs for restoration
   purposes.
   The DS-TE solution MUST ensure that similar application of the use of
   standard priority mechanisms for implementation of restoration policy
   are not prevented since those are expected to be required for
   achieving the survivability requirements of DS-TE networks.
   Further discussion of restoration requirements are presented in the
   output document of the TEWG Requirements Design Team [SURVIV-REQ].
4.  Solution Evaluation Criteria
   A range of solutions is possible for the support of the DS-TE
   requirements discussed above.  For example, some solutions may
   require that all current TE protocols syntax (IGP, RSVP-TE,) be
Le Faucheur & Lai            Informational                     [Page 16]
RFC 3564          Requirements for Diff-Serv-aware TE          July 2003
   extended in various ways.  For instance, current TE protocols could
   be modified to support multiple bandwidth constraints rather than the
   existing single aggregate bandwidth constraint.  Alternatively, other
   solutions may keep the existing TE protocols syntax unchanged but
   modify their semantics to allow for the multiple bandwidth
   constraints.
   This section identifies the evaluation criteria that MUST be used to
   assess potential DS-TE solutions for selection.
4.1.  Satisfying detailed requirements
   The solution MUST address all the scenarios described in section 2
   and satisfy all the requirements listed in section 3.
4.2.  Flexibility
   -  number of Class-Types that can be supported, compared to number
      identified in Requirements section
   -  number of PDBs within a Class-Type
4.3.  Extendibility
   -  how far can the solution be extended in the future if requirements
      for more Class-Types are identified in the future.
4.4.  Scalability
   -  impact on network scalability in what is propagated, processed,
      stored and computed (IGP signaling, IGP processing, IGP database,
      TE-Tunnel signaling ,...).
   -  how does scalability impact evolve with number of
      Class-Types/PDBs actually deployed in a network.  In particular,
      is it possible to keep overhead small for a large networks which
      only use a small number of
      Class-Types/PDBs, while allowing higher number of
      Class-Types/PDBs in smaller networks which can bear higher
      overhead)
4.5.  Backward compatibility/Migration
   -  backward compatibility/migration with/from existing TE mechanisms
   -  backward compatibility/migration when increasing/decreasing the
      number of Class-Types actually deployed in a given network.
Le Faucheur & Lai            Informational                     [Page 17]RFC 3564          Requirements for Diff-Serv-aware TE          July 2003
4.6.  Bandwidth Constraints Model
   Work is currently in progress to investigate the performance and
   trade-offs of different operational aspects of Bandwidth Constraints
   models (for example see [BC-MODEL], [BC-CONS] and [MAR]).  In this
   investigation, at least the following criteria are expected to be
   considered:
       (1) addresses the scenarios in Section 2
       (2) works well under both normal and overload conditions
       (3) applies equally when preemption is either enabled or disabled
       (4) minimizes signaling load processing requirements
       (5) maximizes efficient use of the network
       (6) Minimizes implementation and deployment complexity.
   In selection criteria (2), "normal condition" means that the network
   is attempting to establish a volume of DS-TE LSPs for which it is
   designed; "overload condition" means that the network is attempting
   to establish a volume of DS-TE LSPs beyond the one it is designed
   for; "works well" means that under these conditions, the network
   should be able to sustain the expected performance, e.g., under
   overload it is x times worse than its normal performance.
5.  Security Considerations
   The solution developed to address the DS-TE requirements defined in
   this document MUST address security aspects.  DS-TE does not raise
   any specific additional security requirements beyond the existing
   security requirements of MPLS TE and Diff-Serv.  The solution MUST
   ensure that the existing security mechanisms (including those
   protecting against DOS attacks) of MPLS TE and Diff-Serv are not
   compromised by the protocol/procedure extensions of the DS-TE
   solution or otherwise MUST provide security mechanisms to address
   this.
6.  Acknowledgment
   We thank David Allen for his help in aligning with up-to-date
   Diff-Serv terminology.
7.  Normative References
   [AF]         Heinanen, J., Baker, F., Weiss, W. and J. Wroclawski,
                "Assured Forwarding PHB Group", RFC 2597, June 1999.
   [DIFF-ARCH]  Blake, S., Black, D., Carlson, M., Davies, E., Wang, Z.
                and W. Weiss,  "An Architecture for Differentiated
                Services", RFC 2475, December 1998.
Le Faucheur & Lai            Informational                     [Page 18]RFC 3564          Requirements for Diff-Serv-aware TE          July 2003
   [DIFF-FIELD] Nichols, K., Blake, S., Baker, F. and D. Black,
                "Definition of the Differentiated Services Field (DS
                Field) in the IPv4 and IPv6 Headers", RFC 2474, December
                1998.
   [MPLS-ARCH]  Rosen, E., Viswanathan, A. and R. Callon, "Multiprotocol
                Label Switching Architecture", RFC 3031, January 2001.
   [DIFF-MPLS]  Le Faucheur, F., Wu, L., Davie, B., Davari, S.,
                Vaananen, P., Krishnan, R., Cheval, P. and J. Heinanen,
                "Multi-Protocol Label Switching (MPLS) Support of
                Differentiated Services", RFC 3270, May 2002.
   [DIFF-NEW]   Grossman, D., "New Terminology and Clarifications for
                Diffserv", RFC 3260, April 2002.
   [EF]         Davie, B., Charny, A., Bennet, J.C.R., Benson, K., Le
                Boudec, J.Y., Davari, S., Courtney, W., Firioiu, V. and
                D. Stiliadis, "An Expedited Forwarding PHB (Per-Hop
                Behavior)", RFC 3246, March 2002.
   [TEWG-FW]    Awduche, D., Chiu, A., Elwalid, A., Widjaja, I. and X.
                Xiao, "Overview and Principles of Internet Traffic
                Engineering", RFC 3272, May 2002.
   [TE-REQ]     Awduche, D., Malcolm, J., Agogbua, J., O'Dell, M. and J.
                McManus, "Requirements for Traffic Engineering over
                MPLS", RFC 2702, September 1999.
   [RFC2119]    Bradner, S., "Key words for use in RFCs to Indicate
                Requirement Levels", BCP 14, RFC 2119, March 1997.
8.  Informative References
   [DIFF-PDB]   Nichols, K. and B. Carpenter, "Definition of
                Differentiated Services Per Domain Behaviors and Rules
                for their Specification", RFC 3086, April 2001.
   [ISIS-TE]    Smit, Li, "IS-IS extensions for Traffic Engineering",
                Work in Progress, December 2002.
   [OSPF-TE]    Katz, et al., "Traffic Engineering Extensions to OSPF",
                Work in Progress, October 2002.
   [RSVP-TE]    Awduche, D., Berger, L., Gan, D., Li, T., Srinivasan, V.
                and G. Swallow, "RSVP-TE: Extensions to RSVP for LSP
                Tunnels", RFC 3209, December 2001.
Le Faucheur & Lai            Informational                     [Page 19]RFC 3564          Requirements for Diff-Serv-aware TE          July 2003
   [SURVIV-REQ] Lai, W. and D. McDysan, "Network Hierarchy and
                Multilayer Survivability", RFC 3386, November 2002.
   [BC-MODEL]   Lai, W., "Bandwidth Constraints Models for
                Diffserv-aware MPLS Traffic Engineering: Performance
                Evaluation", Work in Progress, June 2002.
   [BC-CONS]    F. Le Faucheur, "Considerations on Bandwidth Constraints
                Models for DS-TE", Work in Progress, June 2002.
   [MAR]        Ash, J., "Max Allocation with Reservation Bandwidth
                Constraint Model for MPLS/DiffServ TE & Performance
                Comparisons", Work in Progress, May 2003.
9.  Contributing Authors
   This document was the collective work of several people.  The text
   and content of this document was contributed by the editors and the
   co-authors listed below.  (The contact information for the editors
   appears below.)
   Martin Tatham                        Thomas Telkamp
   BT                                   Global Crossing
   Adastral Park, Martlesham Heath,     Oudkerkhof 51,  3512 GJ Utrecht
   Ipswich IP5 3RE, UK                  The Netherlands
   Phone: +44-1473-606349               Phone: +31 30 238 1250
   EMail: martin.tatham@bt.com          EMail: telkamp@gblx.net
   David Cooper                         Jim Boyle
   Global Crossing                      Protocol Driven Networks, Inc.
   960 Hamlin Court                     1381 Kildaire Farm Road #288
   Sunnyvale, CA 94089, USA             Cary, NC 27511, USA
   Phone: (916) 415-0437                Phone: (919) 852-5160
   EMail: dcooper@gblx.net              EMail: jboyle@pdnets.com
   Luyuan Fang                          Gerald R. Ash
   AT&T Labs                            AT&T Labs
   200 Laurel Avenue                    200 Laurel Avenue
   Middletown, New Jersey 07748, USA    Middletown, New Jersey 07748,USA
   Phone: (732) 420-1921                Phone: (732) 420-4578
   EMail: luyuanfang@att.com            EMail: gash@att.com
Le Faucheur & Lai            Informational                     [Page 20]RFC 3564          Requirements for Diff-Serv-aware TE          July 2003
   Pete Hicks                           Angela Chiu
   CoreExpress, Inc                     AT&T Labs-Research
   12655 Olive Blvd, Suite 500          200 Laurel Ave.  Rm A5-1F13
   St. Louis, MO 63141, USA             Middletown, NJ 07748, USA
   Phone: (314) 317-7504                Phone: (732) 420-9061
   EMail: pete.hicks@coreexpress.net    EMail: chiu@research.att.com
   William Townsend                     Thomas D. Nadeau
   Tenor Networks                       Cisco Systems, Inc.
   100 Nagog Park                       300 Beaver Brook Road
   Acton, MA 01720, USA                 Boxborough, MA  01719
   Phone: +1 978-264-4900               Phone: +1-978-936-1470
   EMail:btownsend@tenornetworks.com    EMail: tnadeau@cisco.com
   Darek Skalecki
   Nortel Networks
   3500 Carling Ave,
   Nepean K2H 8E9,
   Phone: (613) 765-2252
   EMail: dareks@nortelnetworks.com
10.  Editors' Addresses
   Francois Le Faucheur
   Cisco Systems, Inc.
   Village d'Entreprise Green Side - Batiment T3
   400, Avenue de Roumanille
   06410 Biot-Sophia Antipolis, France
   Phone: +33 4 97 23 26 19
   EMail: flefauch@cisco.com
   Wai Sum Lai
   AT&T Labs
   200 Laurel Avenue
   Middletown, New Jersey 07748, USA
   Phone: (732) 420-3712
   EMail: wlai@att.com
Le Faucheur & Lai            Informational                     [Page 21]
RFC 3564          Requirements for Diff-Serv-aware TE          July 2003
11.  Full Copyright Statement
   Copyright (C) The Internet Society (2003).  All Rights Reserved.
   This document and translations of it may be copied and furnished to
   others, and derivative works that comment on or otherwise explain it
   or assist in its implementation may be prepared, copied, published
   and distributed, in whole or in part, without restriction of any
   kind, provided that the above copyright notice and this paragraph are
   included on all such copies and derivative works.  However, this
   document itself may not be modified in any way, such as by removing
   the copyright notice or references to the Internet Society or other
   Internet organizations, except as needed for the purpose of
   developing Internet standards in which case the procedures for
   copyrights defined in the Internet Standards process must be
   followed, or as required to translate it into languages other than
   English.
   The limited permissions granted above are perpetual and will not be
   revoked by the Internet Society or its successors or assigns.
   This document and the information contained herein is provided on an
   "AS IS" basis and THE INTERNET SOCIETY AND THE INTERNET ENGINEERING
   TASK FORCE DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING
   BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE INFORMATION
   HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED WARRANTIES OF
   MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
Acknowledgement
   Funding for the RFC Editor function is currently provided by the
   Internet Society.
Le Faucheur & Lai            Informational                     [Page 22]