Network Working Group                                F. Le Faucheur, Ed.
Request for Comments: 4127                           Cisco Systems, Inc.
Category: Experimental                                         June 2005
            Russian Dolls Bandwidth Constraints Model for
                Diffserv-aware MPLS Traffic Engineering
Status of This Memo
   This memo defines an Experimental Protocol for the Internet
   community.  It does not specify an Internet standard of any kind.
   Discussion and suggestions for improvement are requested.
   Distribution of this memo is unlimited.
Copyright Notice
   Copyright (C) The Internet Society (2005).
Abstract
   This document provides specifications for one Bandwidth Constraints
   Model for Diffserv-aware MPLS Traffic Engineering, which is referred
   to as the Russian Dolls Model.
Table of Contents
   1. Introduction ....................................................2
      1.1. Specification of Requirements ..............................2
   2. Contributing Authors ............................................3
   3. Definitions .....................................................4
   4. Russian Dolls Model Definition ..................................5
   5. Example Formulas for Computing "Unreserved TE-Class [i]" with
      Russian Dolls Model .............................................7
   6. Receiving Both Maximum Reservable Bandwidth and Bandwidth
      Constraints sub-TLVs ............................................8
   7. Security Considerations .........................................8
   8. IANA Considerations .............................................8
   9. Acknowledgements ................................................9
   Appendix A: Addressing [DSTE-REQ] Scenarios .......................10
   Normative References ..............................................11
   Informative References ............................................12
Le Faucheur                   Experimental                      [Page 1]
RFC 4127             Russian Dolls Model for DS-TE             June 2005
1.  Introduction
   [DSTE-REQ] presents the Service Providers requirements for support of
   Diffserv-aware MPLS Traffic Engineering (DS-TE).  This includes the
   fundamental requirement to be able to enforce different Bandwidth
   Constraints for different classes of traffic.
   [DSTE-REQ] also defines the concept of Bandwidth Constraints Model
   for DS-TE and states that "The DS-TE technical solution MUST specify
   at least one Bandwidth Constraints Model and MAY specify multiple
   Bandwidth Constraints Models".
   This document provides a detailed description of one particular
   Bandwidth Constraints Model for DS-TE which is introduced in
   [DSTE-REQ] and called the Russian Dolls Model (RDM).
   [DSTE-PROTO] specifies the Interior Gateway Protocol (IGP) and RSVP-
   TE signaling extensions for support of DS-TE.  These extensions
   support RDM.
1.1.  Specification of 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                   Experimental                      [Page 2]
RFC 4127             Russian Dolls Model for DS-TE             June 2005
2.  Contributing Authors
   This document was the collective work of several authors.  The text
   and content were contributed by the editor and the co-authors listed
   below. (The contact information for the editor appears in the
   Editor's Address section.)
   Jim Boyle                               Kireeti Kompella
   Protocol Driven Networks, Inc.          Juniper Networks, Inc.
   1381 Kildaire Farm Road #288            1194 N. Mathilda Ave.
   Cary, NC 27511, USA                     Sunnyvale, CA 94099
   Phone: (919) 852-5160                   EMail: kireeti@juniper.net
   EMail: jboyle@pdnets.com
   William Townsend                        Thomas D. Nadeau
   Tenor Networks                          Cisco Systems, Inc.
   100 Nagog Park                          250 Apollo Drive
   Acton, MA 01720                         Chelmsford, MA 01824
   Phone: +1-978-264-4900                  Phone: +1-978-244-3051
   EMail: btownsend@tenornetworks.com      EMail: tnadeau@cisco.com
   Darek Skalecki
   Nortel Networks
   3500 Carling Ave,
   Nepean K2H 8E9
   Phone: +1-613-765-2252
   EMail: dareks@nortelnetworks.com
Le Faucheur                   Experimental                      [Page 3]
RFC 4127             Russian Dolls Model for DS-TE             June 2005
3.  Definitions
   For readability a number of definitions from [DSTE-REQ] are repeated
   here:
   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.
   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 setup priority, the holding
                    priority, or both.
   A number of recovery mechanisms under investigation or specification
   in the IETF take advantage of the concept of bandwidth sharing across
   particular sets of LSPs.  "Shared Mesh Restoration" in [GMPLS-RECOV]
   and "Facility-based Computation Model" in [MPLS-BACKUP] are example
   mechanisms that increase bandwidth efficiency by sharing bandwidth
   across backup LSPs protecting against independent failures.  To
   ensure that the notion of "Reserved (CTc)" introduced in [DSTE-REQ]
   is compatible with such a concept of bandwidth sharing across
   multiple LSPs, the wording of the "Reserved (CTc)" definition
   provided in [DSTE-REQ] is generalized into the following:
   Reserved (CTc):  For a given Class-Type CTc ( 0 <= c <= MaxCT ), let
                    us define "Reserved(CTc)" as the total amount of the
                    bandwidth reserved by all the established LSPs which
                    belong to CTc.
   With this generalization, the Russian Dolls Model definition provided
   in this document is compatible with Shared Mesh Restoration defined
   in [GMPLS-RECOV], so that DS-TE and Shared Mesh Protection can
   operate simultaneously.  This assumes that Shared Mesh Restoration
   operates independently within each DS-TE Class-Type and does not
   operate across Class-Types (for example, backup LSPs protecting
   Primary LSPs of CTx also need to belong to CTx; Excess Traffic LSPs
   sharing bandwidth with Backup LSPs of CTx also need to belong to
   CTx).
Le Faucheur                   Experimental                      [Page 4]
RFC 4127             Russian Dolls Model for DS-TE             June 2005
   We also introduce the following definition:
   Reserved(CTb,q): Let us define "Reserved(CTb,q)" as the total amount
                    of the bandwidth reserved by all the established
                    LSPs that belong to CTb and have a holding priority
                    of q.  Note that if q and CTb do not form one of the
                    8 possible configured TE-Classes, then there cannot
                    be any established LSPs that belongs to CTb and has
                    a holding priority of q; therefore, in this case,
                    Reserved(CTb,q) = 0.
4.  Russian Dolls Model Definition
   RDM is defined in the following manner:
        o Maximum Number of Bandwidth Constraints (MaxBC)=
             Maximum Number of Class-Types (MaxCT) = 8
        o for each value of b in the range 0 <= b <= (MaxCT - 1):
             SUM (Reserved (CTc)) <= BCb,
             where the SUM is across all values of c in the
             range b <= c <= (MaxCT - 1)
        o BC0= Maximum Reservable Bandwidth, so that
             SUM (Reserved(CTc)) <= Max-Reservable-Bw,
             where the SUM is across all values of c in the
             range  0 <= c <= (MaxCT - 1)
   A DS-TE LSR implementing RDM MUST support enforcement of Bandwidth
   Constraints in compliance with this definition.
   Both preemption within a CT and across CTs is allowed.
   Where 8 CTs are active, the RDM Bandwidth Constraints can also be
   expressed in the following way:
      - All LSPs from CT7 use no more than BC7
      - All LSPs from CT6 and CT7 use no more than BC6
      - All LSPs from CT5, CT6 and CT7 use no more than BC5
      - etc.
      - All LSPs from CT0, CT1, ..., CT7 use no more than BC0 = "Maximum
        Reservable Bandwidth"
Le Faucheur                   Experimental                      [Page 5]
RFC 4127             Russian Dolls Model for DS-TE             June 2005
   Purely for illustration purposes, the diagram below represents the
   Russian Dolls Bandwidth Constraints Model in a pictorial manner when
   3 Class-Types are active:
   I------------------------------------------------------I
   I-------------------------------I                      I
   I--------------I                I                      I
   I    CT2       I    CT2+CT1     I      CT2+CT1+CT0     I
   I--------------I                I                      I
   I-------------------------------I                      I
   I------------------------------------------------------I
   I-----BC2------>
   I----------------------BC1------>
   I------------------------------BC0=Max Reservable Bw--->
   While simpler Bandwidth Constraints models or, conversely, more
   flexible/sophisticated Bandwidth Constraints models can be defined,
   the Russian Dolls Model is attractive in some DS-TE environments for
   the following reasons:
      - Although it is a little less intuitive than the Maximum
        Allocation Model (see [DSTE-MAM]), RDM is still a simple model
        to conceptualize.
      - RDM can be used simultaneously to ensure bandwidth efficiency
        and to protect against QoS degradation of all CTs, whether
        preemption is used or not.
      - RDM can be used in conjunction with preemption to simultaneously
        achieve (i) isolation across CTs (so that each CT is guaranteed
        its share of bandwidth no matter the level of contention by
        other classes), (ii) bandwidth efficiency, and (iii) protection
        against QoS degradation of all CTs.
      - RDM only requires limited protocol extensions such as the ones
        defined in [DSTE-PROTO].
   RDM may not be attractive in some DS-TE environments for the
   following reasons:
      - if the usage of preemption is precluded for some administrative
        reason, while RDM can still ensure bandwidth efficiency and
        protection against QoS degradation of all CTs, RDM cannot
        guarantee isolation across Class-Types.
   Additional considerations on the properties of RDM can be found in
   [BC-CONS] and [BC-MODEL].
Le Faucheur                   Experimental                      [Page 6]
RFC 4127             Russian Dolls Model for DS-TE             June 2005
   As a simple example usage of the "Russian Dolls" Bandwidth
   Constraints Model, a network administrator, using one CT for Voice
   (CT1) and one CT for data (CT0), might configure on a given link:
      - BC0 = Max-Reservable - Bw = 2.5 Gb/s (i.e., Voice + Data is
        limited to 2.5 Gb/s)
      - BC1 = 1.5 Gb/s (i.e., Voice is limited to 1.5 Gb/s).
5.  Example Formulas for Computing "Unreserved TE-Class [i]" with
    Russian Dolls Model
   As specified in [DSTE-PROTO], formulas for computing "Unreserved TE-
   Class [i]" MUST reflect all of the Bandwidth Constraints relevant to
   the CT associated with TE-Class[i], and thus, depend on the Bandwidth
   Constraints Model.  Thus, a DS-TE LSR implementing RDM MUST reflect
   the RDM Bandwidth Constraints defined in section 4 above when
   computing "Unreserved TE-Class [i]".
   As explained in [DSTE-PROTO], the details of admission control
   algorithms, as well as formulas for computing "Unreserved TE-Class
   [i]", are outside the scope of the IETF work.  Keeping that in mind,
   we provide in this section an example for illustration purposes, of
   how values for the unreserved bandwidth for TE-Class[i] might be
   computed with RDM.  In the example, we assume the basic admission
   control algorithm, which simply deducts the exact bandwidth of any
   established LSP from all of the Bandwidth Constraints relevant to the
   CT associated with that LSP.
   We assume that:
        TE-Class [i] <--> < CTc , preemption p>
   in the configured TE-Class mapping.
   For readability, formulas are first shown assuming only 3 CTs are
   active.  The formulas are then extended to cover the cases where more
   CTs are used.
   If CTc = CT0, then "Unreserved TE-Class [i]" =
      [ BC0 - SUM ( Reserved(CTb,q) ) ] for q <= p and 0 <= b <= 2
   If CTc = CT1, then "Unreserved TE-Class [i]" =
      MIN  [
      [ BC1 - SUM ( Reserved(CTb,q) ) ] for q <= p and 1 <= b <= 2,
      [ BC0 - SUM ( Reserved(CTb,q) ) ] for q <= p and 0 <= b <= 2
             ]
Le Faucheur                   Experimental                      [Page 7]
RFC 4127             Russian Dolls Model for DS-TE             June 2005
   If CTc = CT2, then "Unreserved TE-Class [i]" =
      MIN  [
      [ BC2 - SUM ( Reserved(CTb,q) ) ] for q <= p and 2 <= b <= 2,
      [ BC1 - SUM ( Reserved(CTb,q) ) ] for q <= p and 1 <= b <= 2,
      [ BC0 - SUM ( Reserved(CTb,q) ) ] for q <= p and 0 <= b <= 2
             ]
   The formula can be generalized to 8 active CTs and expressed in a
   more compact way in the following:
     "Unreserved TE-Class [i]" =
      MIN  [
    [ BCc - SUM ( Reserved(CTb,q) ) ] for q <= p and c <= b <= 7,
    [ BC(c-1) - SUM ( Reserved(CTb,q) ) ] for q <= p and (c-1)<= b <= 7,
        . . .
    [ BC0 - SUM ( Reserved(CTb,q) ) ] for q <= p and 0 <= b <= 7,
           ]
      where:
        TE-Class [i] <--> < CTc , preemption p>
        in the configured TE-Class mapping.
6.  Receiving Both Maximum Reservable Bandwidth and Bandwidth
    Constraints sub-TLVs
   [DSTE-PROTO] states that "A DS-TE LSR, which does advertise BCs, MUST
   use the new "Bandwidth Constraints" sub-TLV (in addition to the
   existing Maximum Reservable Bandwidth sub-TLV) to do so."
   With RDM, BC0 is equal to the Maximum Reservable Bandwidth because
   they both represent the aggregate constraint across all CTs.  Thus, a
   DS-TE LSR, receiving both the "Maximum Reservable Bw" sub-TLV and the
   new "Bandwidth Constraints" sub-TLV (which contains BC0) for a given
   link where the RDM model is used, MAY ignore the "Maximum Reservable
   Bw" sub-TLV.
7.  Security Considerations
   Security considerations related to the use of DS-TE are discussed in
   [DSTE-PROTO].  Those apply independently of the Bandwidth Constraints
   Model, including RDM specified in this document.
8.  IANA Considerations
   [DSTE-PROTO] defines a new name space for "Bandwidth Constraints
   Model Id".  The guidelines for allocation of values in that name
   space are detailed in section 13.1 of [DSTE-PROTO].  In accordance
Le Faucheur                   Experimental                      [Page 8]
RFC 4127             Russian Dolls Model for DS-TE             June 2005
   with these guidelines, the IANA has assigned a Bandwidth Constraints
   Model Id for RDM from the range 0-239 (which is to be managed as per
   the "Specification Required" policy defined in [IANA-CONS]).
   Bandwidth Constraints Model Id 0 was allocated by IANA to RDM.
9.  Acknowledgements
   We thank Martin Tatham for his key contribution in this work.
   Tatiana Renko is also warmly thanked for her instantiation of the
   Russian Doll.
Le Faucheur                   Experimental                      [Page 9]
RFC 4127             Russian Dolls Model for DS-TE             June 2005
Appendix A: Addressing [DSTE-REQ] Scenarios
   This appendix provides examples of how the Russian Dolls Bandwidth
   Constraints Model can be used to support each of the scenarios
   described in [DSTE-REQ].
A.1.  Scenario 1: Limiting Amount of Voice
   By configuring on every link:
      - Bandwidth Constraint 1 (for CT1 = Voice) = "certain percentage"
        of link capacity
      - BC0 (for CT1=Voice + CT0=Data) = link capacity
   By configuring:
      - every CT1/Voice TE-LSP with preemption = 0
      - every CT0/Data TE-LSP with preemption = 1
   DS-TE with the Russian Dolls Model will address all the requirements:
      - amount of Voice traffic limited to desired percentage on every
        link
      - data traffic capable of using all remaining link capacity
      - voice traffic capable of preempting other traffic
A.2.  Scenario 2: Maintain Relative Proportion of Traffic Classes
   By configuring on every link:
      - BC2 (for CT2) = e.g., 45%
      - BC1 (for CT1+CT2) = e.g., 80%
      - BC0 (for CT0+CT1+CT2) = e.g., 100%
   DS-TE with the RDM will ensure that the amount of traffic of each CT
   established on a link is within acceptable levels as compared to the
   resources allocated to the corresponding Diffserv Per Hop Behaviors
   (PHBs) regardless of which order the LSPs are routed in, regardless
   of which preemption priorities are used by which LSPs and regardless
   of failure situations.
Le Faucheur                   Experimental                     [Page 10]
RFC 4127             Russian Dolls Model for DS-TE             June 2005
   By also configuring:
      - every CT2/Voice TE-LSP with preemption = 0
      - every CT1/Premium Data TE-LSP with preemption = 1
      - every CT0/Best-Effort TE-LSP with preemption = 2
   DS-TE with the Russian Dolls Model will also ensure that:
      - CT2 Voice LSPs always have first preemption priority in order to
        use the CT2 capacity
      - CT1 Premium Data LSPs always have second preemption priority in
        order to use the CT1 capacity
      - Best-Effort can use up to link capacity of what is left by CT2
        and CT1.
   Optional automatic adjustment of Diffserv scheduling configuration
   could be used for maintaining very strict relationships between the
   amounts of established traffic of each Class Type and corresponding
   Diffserv resources.
A.3.  Scenario 3: Guaranteed Bandwidth Services
   By configuring on every link:
      - BC1 (for CT1) = "given" percentage of link bandwidth
        (appropriate to achieve the Guaranteed Bandwidth service's QoS
        objectives)
      - BC0 (for CT0+CT1) = 100% of link bandwidth
   DS-TE with the Russian Dolls Model will ensure that the amount of
   Guaranteed Bandwidth Traffic established on every link remains below
   the given percentage so that it will always meet its QoS objectives.
   At the same time, it will allow traffic engineering of the rest of
   the traffic such that links can be filled up.
Normative References
   [DSTE-REQ]    Le Faucheur, F. and W. Lai, "Requirements for Support
                 of Differentiated Services-aware MPLS Traffic
                 Engineering", RFC 3564, July 2003.
Le Faucheur                   Experimental                     [Page 11]
RFC 4127             Russian Dolls Model for DS-TE             June 2005
   [DSTE-PROTO]  Le Faucheur, F., Ed., "Protocol Extensions for Support
                 of Diffserv-aware MPLS Traffic Engineering", RFC 4124,
                 June 2005.
   [RFC2119]     Bradner, S., "Key words for use in RFCs to Indicate
                 Requirement Levels", BCP 14, RFC 2119, March 1997.
   [IANA-CONS]   Narten, T. and H. Alvestrand, "Guidelines for Writing
                 an IANA Considerations Section in RFCs", BCP 26, RFC
                 2434, October 1998.
Informative References
   [BC-CONS]     Le Faucheur, F., "Considerations on Bandwidth
                 Constraints Model for DS-TE", Work in Progress, June
                 2002.
   [BC-MODEL]    Lai, W., "Bandwidth Constraints Models for
                 Differentiated Services (Diffserv)-aware MPLS Traffic
                 Engineering:  Performance Evaluation", RFC 4128, June
                 2005.
   [DSTE-MAM]    Le Faucheur, F. and W. Lai, "Maximum Allocation
                 Bandwidth Constraints Model for Diffserv-aware MPLS
                 Traffic Engineering", RFC 4125, June 2005.
   [GMPLS-RECOV] Lang, et al., "Generalized MPLS Recovery Functional
                 Specification", Work in Progress.
   [MPLS-BACKUP] Vasseur, et al., "MPLS Traffic Engineering Fast
                 Reroute:  Bypass Tunnel Path Computation for Bandwidth
                 Protection", Work in Progress.
Editor's Address
   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
Le Faucheur                   Experimental                     [Page 12]
RFC 4127             Russian Dolls Model for DS-TE             June 2005
Full Copyright Statement
   Copyright (C) The Internet Society (2005).
   This document is subject to the rights, licenses and restrictions
   contained in BCP 78, and except as set forth therein, the authors
   retain all their rights.
   This document and the information contained herein are provided on an
   "AS IS" basis and THE CONTRIBUTOR, THE ORGANIZATION HE/SHE REPRESENTS
   OR IS SPONSORED BY (IF ANY), THE INTERNET SOCIETY AND THE INTERNET
   ENGINEERING TASK FORCE DISCLAIM 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.
Intellectual Property
   The IETF takes no position regarding the validity or scope of any
   Intellectual Property Rights or other rights that might be claimed to
   pertain to the implementation or use of the technology described in
   this document or the extent to which any license under such rights
   might or might not be available; nor does it represent that it has
   made any independent effort to identify any such rights.  Information
   on the procedures with respect to rights in RFC documents can be
   found in BCP 78 and BCP 79.
   Copies of IPR disclosures made to the IETF Secretariat and any
   assurances of licenses to be made available, or the result of an
   attempt made to obtain a general license or permission for the use of
   such proprietary rights by implementers or users of this
   specification can be obtained from the IETF on-line IPR repository at
   http://www.ietf.org/ipr.
   The IETF invites any interested party to bring to its attention any
   copyrights, patents or patent applications, or other proprietary
   rights that may cover technology that may be required to implement
   this standard.  Please address the information to the IETF at ietf-
   ipr@ietf.org.
Acknowledgement
   Funding for the RFC Editor function is currently provided by the
   Internet Society.
Le Faucheur                   Experimental                     [Page 13]