<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE rfc [
  <!ENTITY nbsp    "&#160;">
  <!ENTITY zwsp   "&#8203;">
  <!ENTITY nbhy   "&#8209;">
  <!ENTITY wj     "&#8288;">
]>
<?xml-stylesheet type="text/xsl" href="rfc2629.xslt" ?>
<!-- generated by https://github.com/cabo/kramdown-rfc version 1.7.29 (Ruby 3.4.4) -->
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" ipr="trust200902" docName="draft-watal-spring-srv6-sfc-sr-aware-functions-03" category="info" tocInclude="true" sortRefs="true" symRefs="true" version="3">
  <!-- xml2rfc v2v3 conversion 3.30.0 -->
  <front>
    <title abbrev="SRv6 SFC with SR-aware Functions">SRv6 SFC Architecture with SR-aware Functions</title>
    <seriesInfo name="Internet-Draft" value="draft-watal-spring-srv6-sfc-sr-aware-functions-03"/>
    <author initials="W." surname="Mishima" fullname="Wataru Mishima">
      <organization>NTT Communications</organization>
      <address>
        <postal>
          <country>Japan</country>
        </postal>
        <email>w.mishima@ntt.com</email>
      </address>
    </author>
    <author initials="Y." surname="Fukagawa" fullname="Yuta Fukagawa">
      <organization>NTT Communications</organization>
      <address>
        <postal>
          <country>Japan</country>
        </postal>
        <email>y.fukagawa@ntt.com</email>
      </address>
    </author>
    <date year="2025" month="August" day="04"/>
    <area>Routing</area>
    <workgroup>SPRING</workgroup>
    <keyword>SRv6</keyword>
    <keyword>SFC</keyword>
    <abstract>
      <?line 35?>

<t>This document describes the architecture of Segment Routing over IPv6 (SRv6) Service Function Chaining (SFC) with SR-aware functions.
This architecture provides the following benefits:</t>
      <ul spacing="normal">
        <li>
          <t>Comprehensive Management: a centralized controller for SFC, handling SR Policy, link-state, and network metrics.</t>
        </li>
        <li>
          <t>Simplicity: no SFC proxies, which reduces the number of nodes and address resource consumption.</t>
        </li>
      </ul>
    </abstract>
    <note removeInRFC="true">
      <name>Discussion Venues</name>
      <t>Discussion of this document takes place on the
    Source Packet Routing in Networking Working Group mailing list (spring@ietf.org),
    which is archived at <eref target="https://mailarchive.ietf.org/arch/browse/spring/"/>.</t>
      <t>Source for this draft and an issue tracker can be found at
    <eref target="https://https/github.com/watal"/>.</t>
    </note>
  </front>
  <middle>
    <?line 43?>

<section anchor="introduction">
      <name>Introduction</name>
      <t>Segment Routing over IPv6 (SRv6) <xref target="RFC8986"/> enables packet steering through a set of instructions called a segment list.
Each SR segment endpoint node provides SRv6 Endpoint Behaviors, including Prefix/Adjacency Segments, VPNs, and Binding Segments.</t>
      <t>Service Function Chaining (SFC) <xref target="RFC7665"/> can be used in various scenarios (e.g. FW, IPS, IDS, NAT, and DPI).
SFC based on Segment Routing (SR) is defined in <xref target="I-D.draft-ietf-spring-sr-service-programming"/>, which describes some SRv6 Endpoint Behaviors, such as End.AS/AD/AM, are necessary for using SR-unaware functions.</t>
      <t>This document describes an architecture for SRv6 SFC with SR-aware functions, which provides comprehensive management of SRv6 network resources and services.</t>
    </section>
    <section anchor="terminology">
      <name>Terminology</name>
      <section anchor="terminology-defined-in-related-rfcs-and-internet-drafts">
        <name>Terminology Defined in Related RFCs and Internet-Drafts</name>
        <t>The following terms are used in this document as defined in the related RFCs and Internet-Drafts:</t>
        <ul spacing="normal">
          <li>
            <t>SR, SR Domain, Segment ID (SID), SRv6, SR Policy, Prefix Segment, Adjacency Segment, Anycast Segment, Active Segment, and Distributed/Centralized/Hybrid Control Plane defined in <xref target="RFC8402"/>.</t>
          </li>
          <li>
            <t>SR Source Node, Transit Node, and SR Segment Endpoint Node defined in <xref target="RFC8754"/>.</t>
          </li>
          <li>
            <t>SRv6 Endpoint Behavior defined in <xref target="RFC8986"/>.</t>
          </li>
          <li>
            <t>SFC, SFC Proxy, and Service Classification Function defined in <xref target="RFC7665"/>.</t>
          </li>
          <li>
            <t>Service Segment, SR-Aware Service, SR-Unaware Service, End.AS, End.AD and End.AM defined in <xref target="I-D.draft-ietf-spring-sr-service-programming"/>.</t>
          </li>
          <li>
            <t>Headend, Color, and Endpoint defined in <xref target="RFC9256"/>.</t>
          </li>
          <li>
            <t>Quality of Service (QoS), Service Level Agreement (SLA), and Service Level Objective (SLO) defined in <xref target="RFC9522"/>.</t>
          </li>
          <li>
            <t>Forwarding Plane, Control Plane, Management Plane, Application Plane defined in <xref target="RFC7426"/>.</t>
          </li>
          <li>
            <t>Path Computation Client (PCC), Path Computation Element (PCE), and Traffic Engineering Database (TED) defined in <xref target="RFC5440"/>.</t>
          </li>
          <li>
            <t>BGP Flow Specification defined in <xref target="RFC8955"/></t>
          </li>
        </ul>
      </section>
      <section anchor="newly-defined-terminology">
        <name>Newly Defined Terminology</name>
        <t>The following terms are used in this document as defined below:</t>
        <ul spacing="normal">
          <li>
            <t>Service Function Node: an SR segment endpoint node that provides SR-aware functions as service segments.</t>
          </li>
          <li>
            <t>SRv6 Controller: controls SRv6 Forwarding Plane, consisting of a PCE and a Classification Rule Controller.</t>
          </li>
          <li>
            <t>Classification Rule Controller: applies sets of SR Policy and flows to SR source nodes.</t>
          </li>
          <li>
            <t>Service Function Manager: configures network function instances, enables SR-aware functions as service segments, and collects network metrics.</t>
          </li>
        </ul>
      </section>
      <section anchor="requirements-language">
        <name>Requirements Language</name>
        <t>The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in BCP 14 <xref target="RFC2119"/> <xref target="RFC8174"/> when, and only when, they appear in all capitals, as shown here.</t>
      </section>
    </section>
    <section anchor="design-objectives-and-assumptions">
      <name>Design Objectives and Assumptions</name>
      <t>## Goals/Objectives
SRv6 SFC Architecture is designed with two main objectives:</t>
      <ul spacing="normal">
        <li>
          <t>Comprehensive Management: a centralized controller for SFC, handling SR Policy, link-state, and network metrics.
When providing SRv6 services, meeting SLAs for each customer is required.
These SLAs consist of one or more SLOs such as availability, latency, and bandwidth.
In an SRv6 SFC network, service segment provisioning, link-state collection, and SR Policy calculation are required to meet SLOs, respectively.  </t>
          <t><xref target="RFC8402"/> outlines a hybrid control plane that merges a distributed control plane and a centralized control plane.
In this hybrid control plane, forwarding information like Node/Adjacency SIDs are advertised mutually by distributed SR nodes via IGPs such as ISIS and OSPF, while other information like SR Policies, classification rules, and service segments are provided by a centralized controller and manager.  </t>
          <t>
Software-Defined Networking (SDN) <xref target="RFC7426"/> provides centralized management of a network by a controller and a manager.
Centralized management reduces operational costs through abstraction and automation.
The SDN framework allows users to manage an SR domain without considering the details of a forwarding plane like a topology and node state.
Operators can use an SRv6 controller to build SR Policies for SFC and QoS, manage the state of network functions, issue service segments automatically, and specify disaster recovery with protection.</t>
        </li>
        <li>
          <t>Simplicity: no SFC proxies, so that reduces nodes and address resource consumption.
Network complexity increases operating costs.
Generally, using a variety of protocols in a network raises operational costs, including designing, building, monitoring, and troubleshooting.  </t>
          <t>
Using an SFC proxy may increase forwarding overhead due to additional header manipulations.</t>
        </li>
      </ul>
      <section anchor="assumptions">
        <name>Assumptions</name>
        <t>To achieve these objectives, this architecture is based on two main assumptions:</t>
        <ul spacing="normal">
          <li>
            <t>Straightforward extension of the SRv6 network programming model  </t>
            <t>
The protocol used in this architecture is compatible with SRv6.
This streamlines the operation of services like traffic steering, including SFC, redundancy, and local protection.
Standardized protocols such as BGP, PCEP, IS-IS, OSPF, TI-LFA, and Anycast SID are used in this architecture.  </t>
            <t>
This architecture is SRv6 compliant, enabling support for SR-unaware functions, although SR-aware functions are expected to meet the objective.</t>
          </li>
          <li>
            <t>SDN framework compliance and comprehensive management of SRv6 SFC by controllers  </t>
            <t>
A controller is used to provide comprehensive management.
To simplify building and operating, the controller uses standardized protocols and abstracted service interfaces.
This also provides programmability by controlling policies that meet a user's intent including SFC and quality of service (QoS).</t>
          </li>
        </ul>
      </section>
    </section>
    <section anchor="overview-of-architecture">
      <name>Overview of Architecture</name>
      <t>Figure 1 illustrates an overview of this architecture.</t>
      <figure anchor="overview">
        <name>Overview of SRv6 SFC Architecture with SR-aware Functions</name>
        <sourcecode type="drawing"><![CDATA[
 +----------------------- Application Plane ----------------------+
 |                        User Application                        |
 +-----------------------------------|----------------------------+
                                     |
 +- Control Plane (SRv6 Controller) -v-----+ +- Management Plane -+
 | +--------------+ +--------------------+ | | +----------------+ |
 | |Classification| |        Path        | | | |    Service     | |
 | |     Rule     | |     Computation    | | | |    Function    | |
 | |  Controller  | |    Element (PCE)   | | | |    Manager     | |
 | +------|-------+ +-^-------|--------^-+ | | +----------------+ |
 +--------|-----------|-------|--------|---+ +---------|----------+
          |           |       |        |               |
 +--------|-----------|-------|--------|---------------|---+
 | +------v-----------|-------v-+    +-|---------------v-+ |
 | |                            |    |      Service      | |
 | |       SR Source Node       |----|      Function     | |
 | |                            |    |        Node       | |
 | +----------------------------+    +-------------------+ |
 +------------------- Forwarding Plane --------------------+
]]></sourcecode>
      </figure>
      <t>This architecture is based on <xref target="RFC7426"/> and consists of forwarding plane, control plane, management plane, and application plane.</t>
      <ul spacing="normal">
        <li>
          <t>Forwarding Plane: classifies packets and encapsulates SRH, forwards them, and applies SRv6 Endpoint Behavior.
          </t>
          <ul spacing="normal">
            <li>
              <t>Provides SR-aware function using End.AN.</t>
            </li>
            <li>
              <t>Classifies flows and applies them to a TE application with PBR.</t>
            </li>
            <li>
              <t>Ensures redundancy with anycast.</t>
            </li>
            <li>
              <t>Provides local protection with Fast Reroute (FRR).</t>
            </li>
          </ul>
        </li>
        <li>
          <t>Control Plane: makes decisions about packet forwarding and provides rules for a forwarding plane.
          </t>
          <ul spacing="normal">
            <li>
              <t>Collects link-state including SRv6 locators, prefixes, behaviors, and delays.</t>
            </li>
            <li>
              <t>Calculates and provisions SR Policies.</t>
            </li>
            <li>
              <t>Applies SR Policies to each flow by provisioning flow classification rules.</t>
            </li>
          </ul>
        </li>
        <li>
          <t>Management Plane: deploys and monitors network functions and devices.
          </t>
          <ul spacing="normal">
            <li>
              <t>Sets up network functions.</t>
            </li>
            <li>
              <t>Collects metrics of devices, network functions, and SFC services.</t>
            </li>
          </ul>
        </li>
        <li>
          <t>Application Plane: provides user API for the control/management planes.
          </t>
          <ul spacing="normal">
            <li>
              <t>Offers an interface for operators or customers.</t>
            </li>
            <li>
              <t>Applies intents defined in <xref target="RFC9315"/>.</t>
            </li>
          </ul>
        </li>
      </ul>
      <t>Each component communicates using standardized protocols.
These are designed to be loosely coupled and cooperate by using an abstraction layer.</t>
      <t>This document suggests handling a control plane by application plane, but a detailed design of an application plane is out of the scope of this document.
This is because application plane components and abstraction layers should be designed based on individual network utilization and operator intent.
In the following sections, details of a forwarding plane, control plane, and management plane are explained.</t>
    </section>
    <section anchor="forwarding-plane">
      <name>Forwarding Plane</name>
      <t>A forwarding plane provides SFC through packet classification, SRv6 encapsulation, and forwarding.
In this architecture, all forwarding plane components are located within the SR domain.</t>
      <figure anchor="fp">
        <name>Forwarding Plane</name>
        <sourcecode type="drawing"><![CDATA[
 +-----------------------------------------------------------------+
 | +-----------+             +----------+             +----------+ |
 | |           | SRv6 Packet | Service  | SRv6 Packet | Service  | |
 | | SR Source |(S2,S1; SL:1)| Function |(S2,S1; SL:1)| Function | |
-->|    Node   |------------>|   Node   |------------>|   Node   |-->
 | |           |             |   (S1)   |             |   (S2)   | |
 | +-----------+             +----------+             +----------+ |
 +--------------------------- SR domain ---------------------------+
]]></sourcecode>
      </figure>
      <t>Figure 2 shows an example of SFC with two network functions.
Firstly, the SR source node classifies the flow and encapsulates it with an SRH containing the segment list &lt;S1, S2&gt;.
Next, the service function node (S1) receives the packet and applies a network function associated with an End.AN S1.
Finally, the service function node (S2) receives the packet and also applies a network function associated End.AN S2, thus achieving SFC.</t>
      <section anchor="endan-based-service-segment-provisioning">
        <name>End.AN-based Service Segment Provisioning</name>
        <t>End.AN provides an SR-aware function.</t>
        <t>Functions with the same role MAY be assigned as the same service segment within the SR domain.
By using Anycast SIDs, multiple nodes can be grouped as part of the same service segment.</t>
        <t>End.AN MAY have optional arguments.
This can provide additional programmability by embedding network function instructions in the segment list.</t>
        <t>By using virtualized spaces within routers or on generic servers, network functions can be provided at any node in an SR domain.
This allows for scaling and flexible redundancy of network functions.</t>
        <section anchor="when-a-network-function-becomes-unavailable">
          <name>When a Network Function Becomes Unavailable</name>
          <t>When a network function becomes unavailable, the node removes the SID from its routing table.
If an anycast SID is used, packets are redirected to another node.
If no other nodes are available, the node drops the packets and sends an ICMP message (Type 3: Destination Unreachable, Code 0: Net Unreachable).</t>
        </section>
        <section anchor="anycast-segment">
          <name>Anycast Segment</name>
          <t>The concept of the Anycast Segment is introduced in <xref target="RFC8402"/>.
In the SRv6 SFC, it realizes to provide the same network function segment as the same Anycast Segment.
In such cases, the state between network functions MUST be shared mutually.</t>
        </section>
        <section anchor="fast-reroute">
          <name>Fast Reroute</name>
          <t>The ordering of network functions in an SRv6 SFC is guaranteed by the segment list, even if an FRR occurs,
When an FRR occurs, if the Active segment is an Anycast SID, it MAY be forwarded to another service function node.
In such a case, since state synchronization may not have been completed, the network function MUST have a mechanism to handle rerouted packets, such as buffering to wait for synchronization.</t>
        </section>
      </section>
      <section anchor="service-function-chains">
        <name>Service Function Chains</name>
        <t>In this architecture, each SFC is represented as an SR Policy.
The purpose or intent of each SR Policy can be identified using attributes such as color or name.</t>
        <t>In general, SFC is achieved by using loose source routing.
If both SFC and QoS are desired, they can be achieved by using strict source routing or loose source routing with Flex-Algo SIDs.</t>
      </section>
      <section anchor="per-flow-encapsulation">
        <name>Per-Flow Encapsulation</name>
        <t>In an SR source node, which serves as the Service Classification Function, packets are classified on a per-flow basis using PBR and encapsulated with SR Policy.
Therefore, the SR source node MUST be capable of identifying packets using at least a 5-tuple or even more detailed information.</t>
        <t>In this architecture, aiming for comprehensive management, the Service Classification Function has an API to communicate with the controller.</t>
      </section>
    </section>
    <section anchor="control-plane">
      <name>Control Plane</name>
      <t>A control plane sets up a forwarding plane by creating SR policies, including SFCs, and applying them to each flow.</t>
      <figure anchor="cp">
        <name>Control Plane</name>
        <sourcecode type="drawing"><![CDATA[
 +- Control Plane (SRv6 Controller) -------+
 | +--------------+ +--------------------+ |
 | |Classification| |        Path        | |
 | |     Rule     | |     Computation    | |
 | |  Controller  | |    Element (PCE)   | |
 | +------|-------+ +-^-------|--------^-+ |
 +--------|-----------|-------|--------|---+
  Classification link-state SR Policy link-state(Service Segment)
        Rule      (BGP-LS) (PCEP/BGP) (BGP-LS)
  (BGP Flowspec)      |       |        |
 +--------|-----------|-------|--------|-------------------+
 | +------v-----------|-------v-+    +-|-----------------+ |
 | |                            |    |      Service      | |
 | |       SR Source Node       |----|      Function     | |
 | |                            |    |        Node       | |
 | +----------------------------+    +-------------------+ |
 +------------------- Forwarding Plane --------------------+
]]></sourcecode>
      </figure>
      <t>The SRv6 Controller consists of the following two components:</t>
      <ul spacing="normal">
        <li>
          <t>PCE: provides SR Policies that fulfill SFC/QoS requirements from the headend to the tailend and sends them to the SR source node.</t>
        </li>
        <li>
          <t>Classification Rule Controller: provides an Encapsulation Policy that corresponds to a specific flow and SR Policy, and sends them to the SR source node.</t>
        </li>
      </ul>
      <section anchor="path-computation-element-pce">
        <name>Path Computation Element (PCE)</name>
        <t>PCE is a controller that provides SR Policy.
As an Active Stateful PCE, it establishes sessions with all PEs in an SR domain and manages SFCs.
SR Policies MUST support both explicit and dynamic paths.</t>
        <t>For dynamic path computation, the Constrained Shortest Path First (CSPF) algorithm considers not only the SFC but also QoS constraints.</t>
        <t>The PCE builds a Traffic Engineering Database (TED) of the SR domain using BGP-LS and installs SR policies via PCEP <xref target="RFC5440"/> or BGP SR Policy <xref target="I-D.draft-ietf-idr-segment-routing-te-policy"/>.</t>
        <t>To enable dynamic path calculation based on the state of service segments and Network Functions, the BGP-LS Service Segment extension <xref target="I-D.draft-ietf-idr-bgp-ls-sr-service-segments"/> is required.</t>
      </section>
      <section anchor="classification-rule-controller">
        <name>Classification Rule Controller</name>
        <t>A Classification Rule Controller determines flows to apply specific SFC.</t>
        <t>The classification results are advertised to each SR source node as a set of flow, endpoints, and color with an extended protocol based on BGP Flowspec defined in <xref target="I-D.draft-ietf-idr-ts-flowspec-srv6-policy"/>.</t>
      </section>
    </section>
    <section anchor="management-plane">
      <name>Management Plane</name>
      <t>A management plane configures network function instances, enables SR-aware functions as service segments, monitors resources, and collects network metrics.
The details of each manager are outside the scope of this document, as the southbound interface of the management plane may be different for each service and hardware architecture.</t>
      <figure anchor="mp">
        <name>Management Plane</name>
        <sourcecode type="drawing"><![CDATA[
 +-------------------- Function Managers ---------------------+
 | +-----------+ +--------------+ +-----------+ +-----------+ |
 | |  Service  | | Virtualized  | |    VNF    | |  Network  | |
 | |  Function | |Infrastructure| |  Manager  | |  Metric   | |
 | |  Manager  | |   Manager    | |           | |  Manager  | |
 | +-----|-----+ +------^-------+ +-----|-----+ +-----^-----+ |
 +-------|--------------|---------------|-------------|-------+
         |              |               |             |
             Management Plane Southbound Interfaces
         |              |               |             |
 +-------|--------------|---------------|-------------|--------+
 | +-----v--------------v---------------v-------------|------+ |
 | |                  Service Function Node                  | |
 | +---------------------------------------------------------+ |
 +------------------------- SR domain -------------------------+
]]></sourcecode>
      </figure>
      <t>Figure 4 shows examples of managers that MAY be added to a management plane:</t>
      <ul spacing="normal">
        <li>
          <t>Service Function Manager: provides an SID for a network service and manages this state.</t>
        </li>
        <li>
          <t>VNF Manager: handles deployment and scaling of network functions.
          </t>
          <ul spacing="normal">
            <li>
              <t>VNF Manager keeps links redundant and optimize link utilization.</t>
            </li>
          </ul>
        </li>
        <li>
          <t>VIM: monitors hypervisor resources on service function nodes.
          </t>
          <ul spacing="normal">
            <li>
              <t>In SRv6 SFC, a hypervisor managed by a VIM MAY be located in virtualized spaces within routers or on generic servers.</t>
            </li>
          </ul>
        </li>
        <li>
          <t>Network Metrics Manager: collects metrics for SR Policy calculation and evaluation.
          </t>
          <ul spacing="normal">
            <li>
              <t>Metrics are collected from multiple data sources, including IPFIX, TCP statistics, and SRv6 path tracing <xref target="I-D.draft-filsfils-spring-path-tracing"/>.</t>
            </li>
            <li>
              <t>Metrics can be used for PCE calculation parameters.</t>
            </li>
          </ul>
        </li>
      </ul>
      <section anchor="service-function-manager">
        <name>Service Function Manager</name>
        <t>Service Function Manager enables and disables service segments of service function nodes.</t>
        <t>The Manager advertises the following parameters to each service function node:</t>
        <ul spacing="normal">
          <li>
            <t>Behavior: End.AN</t>
          </li>
          <li>
            <t>SID: the SID of End.AN (in IPv6 Address format). If service segments support slicing, they are represented as Flex-Algo SIDs.</t>
          </li>
          <li>
            <t>Function Name: type of network function</t>
          </li>
          <li>
            <t>Action: enable</t>
          </li>
          <li>
            <t>TLV:
            </t>
            <ul spacing="normal">
              <li>
                <t>Specification of the Anycast Group: when deploying multiple Network Functions within the same context, it MUST use the Anycast Group TLV to indicate a shared anycast group SID.</t>
              </li>
              <li>
                <t>Allows for the specification of unique parameters and context associated with a particular network function.</t>
              </li>
            </ul>
          </li>
        </ul>
      </section>
    </section>
  </middle>
  <back>
    <references anchor="sec-normative-references">
      <name>Normative References</name>
      <reference anchor="RFC8986">
        <front>
          <title>Segment Routing over IPv6 (SRv6) Network Programming</title>
          <author fullname="C. Filsfils" initials="C." role="editor" surname="Filsfils"/>
          <author fullname="P. Camarillo" initials="P." role="editor" surname="Camarillo"/>
          <author fullname="J. Leddy" initials="J." surname="Leddy"/>
          <author fullname="D. Voyer" initials="D." surname="Voyer"/>
          <author fullname="S. Matsushima" initials="S." surname="Matsushima"/>
          <author fullname="Z. Li" initials="Z." surname="Li"/>
          <date month="February" year="2021"/>
          <abstract>
            <t>The Segment Routing over IPv6 (SRv6) Network Programming framework enables a network operator or an application to specify a packet processing program by encoding a sequence of instructions in the IPv6 packet header.</t>
            <t>Each instruction is implemented on one or several nodes in the network and identified by an SRv6 Segment Identifier in the packet.</t>
            <t>This document defines the SRv6 Network Programming concept and specifies the base set of SRv6 behaviors that enables the creation of interoperable overlays with underlay optimization.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="8986"/>
        <seriesInfo name="DOI" value="10.17487/RFC8986"/>
      </reference>
      <reference anchor="RFC7665">
        <front>
          <title>Service Function Chaining (SFC) Architecture</title>
          <author fullname="J. Halpern" initials="J." role="editor" surname="Halpern"/>
          <author fullname="C. Pignataro" initials="C." role="editor" surname="Pignataro"/>
          <date month="October" year="2015"/>
          <abstract>
            <t>This document describes an architecture for the specification, creation, and ongoing maintenance of Service Function Chains (SFCs) in a network. It includes architectural concepts, principles, and components used in the construction of composite services through deployment of SFCs, with a focus on those to be standardized in the IETF. This document does not propose solutions, protocols, or extensions to existing protocols.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="7665"/>
        <seriesInfo name="DOI" value="10.17487/RFC7665"/>
      </reference>
      <reference anchor="I-D.draft-ietf-spring-sr-service-programming">
        <front>
          <title>Service Programming with Segment Routing</title>
          <author fullname="Francois Clad" initials="F." surname="Clad">
            <organization>Cisco Systems, Inc.</organization>
          </author>
          <author fullname="Xiaohu Xu" initials="X." surname="Xu">
            <organization>China Mobile</organization>
          </author>
          <author fullname="Clarence Filsfils" initials="C." surname="Filsfils">
            <organization>Cisco Systems, Inc.</organization>
          </author>
          <author fullname="Daniel Bernier" initials="D." surname="Bernier">
            <organization>Bell Canada</organization>
          </author>
          <author fullname="Cheng Li" initials="C." surname="Li">
            <organization>Huawei</organization>
          </author>
          <author fullname="Bruno Decraene" initials="B." surname="Decraene">
            <organization>Orange</organization>
          </author>
          <author fullname="Shaowen Ma" initials="S." surname="Ma">
            <organization>Mellanox</organization>
          </author>
          <author fullname="Chaitanya Yadlapalli" initials="C." surname="Yadlapalli">
            <organization>AT&amp;T</organization>
          </author>
          <author fullname="Wim Henderickx" initials="W." surname="Henderickx">
            <organization>Nokia</organization>
          </author>
          <author fullname="Stefano Salsano" initials="S." surname="Salsano">
            <organization>Universita di Roma "Tor Vergata"</organization>
          </author>
          <date day="23" month="February" year="2025"/>
          <abstract>
            <t>   This document defines data plane functionality required to implement
   service segments and achieve service programming in SR-enabled MPLS
   and IPv6 networks, as described in the Segment Routing architecture.

            </t>
          </abstract>
        </front>
        <seriesInfo name="Internet-Draft" value="draft-ietf-spring-sr-service-programming-11"/>
      </reference>
      <reference anchor="RFC8402">
        <front>
          <title>Segment Routing Architecture</title>
          <author fullname="C. Filsfils" initials="C." role="editor" surname="Filsfils"/>
          <author fullname="S. Previdi" initials="S." role="editor" surname="Previdi"/>
          <author fullname="L. Ginsberg" initials="L." surname="Ginsberg"/>
          <author fullname="B. Decraene" initials="B." surname="Decraene"/>
          <author fullname="S. Litkowski" initials="S." surname="Litkowski"/>
          <author fullname="R. Shakir" initials="R." surname="Shakir"/>
          <date month="July" year="2018"/>
          <abstract>
            <t>Segment Routing (SR) leverages the source routing paradigm. A node steers a packet through an ordered list of instructions, called "segments". A segment can represent any instruction, topological or service based. A segment can have a semantic local to an SR node or global within an SR domain. SR provides a mechanism that allows a flow to be restricted to a specific topological path, while maintaining per-flow state only at the ingress node(s) to the SR domain.</t>
            <t>SR can be directly applied to the MPLS architecture with no change to the forwarding plane. A segment is encoded as an MPLS label. An ordered list of segments is encoded as a stack of labels. The segment to process is on the top of the stack. Upon completion of a segment, the related label is popped from the stack.</t>
            <t>SR can be applied to the IPv6 architecture, with a new type of routing header. A segment is encoded as an IPv6 address. An ordered list of segments is encoded as an ordered list of IPv6 addresses in the routing header. The active segment is indicated by the Destination Address (DA) of the packet. The next active segment is indicated by a pointer in the new routing header.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="8402"/>
        <seriesInfo name="DOI" value="10.17487/RFC8402"/>
      </reference>
      <reference anchor="RFC8754">
        <front>
          <title>IPv6 Segment Routing Header (SRH)</title>
          <author fullname="C. Filsfils" initials="C." role="editor" surname="Filsfils"/>
          <author fullname="D. Dukes" initials="D." role="editor" surname="Dukes"/>
          <author fullname="S. Previdi" initials="S." surname="Previdi"/>
          <author fullname="J. Leddy" initials="J." surname="Leddy"/>
          <author fullname="S. Matsushima" initials="S." surname="Matsushima"/>
          <author fullname="D. Voyer" initials="D." surname="Voyer"/>
          <date month="March" year="2020"/>
          <abstract>
            <t>Segment Routing can be applied to the IPv6 data plane using a new type of Routing Extension Header called the Segment Routing Header (SRH). This document describes the SRH and how it is used by nodes that are Segment Routing (SR) capable.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="8754"/>
        <seriesInfo name="DOI" value="10.17487/RFC8754"/>
      </reference>
      <reference anchor="RFC9256">
        <front>
          <title>Segment Routing Policy Architecture</title>
          <author fullname="C. Filsfils" initials="C." surname="Filsfils"/>
          <author fullname="K. Talaulikar" initials="K." role="editor" surname="Talaulikar"/>
          <author fullname="D. Voyer" initials="D." surname="Voyer"/>
          <author fullname="A. Bogdanov" initials="A." surname="Bogdanov"/>
          <author fullname="P. Mattes" initials="P." surname="Mattes"/>
          <date month="July" year="2022"/>
          <abstract>
            <t>Segment Routing (SR) allows a node to steer a packet flow along any path. Intermediate per-path states are eliminated thanks to source routing. SR Policy is an ordered list of segments (i.e., instructions) that represent a source-routed policy. Packet flows are steered into an SR Policy on a node where it is instantiated called a headend node. The packets steered into an SR Policy carry an ordered list of segments associated with that SR Policy.</t>
            <t>This document updates RFC 8402 as it details the concepts of SR Policy and steering into an SR Policy.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="9256"/>
        <seriesInfo name="DOI" value="10.17487/RFC9256"/>
      </reference>
      <reference anchor="RFC9522">
        <front>
          <title>Overview and Principles of Internet Traffic Engineering</title>
          <author fullname="A. Farrel" initials="A." role="editor" surname="Farrel"/>
          <date month="January" year="2024"/>
          <abstract>
            <t>This document describes the principles of traffic engineering (TE) in the Internet. The document is intended to promote better understanding of the issues surrounding traffic engineering in IP networks and the networks that support IP networking and to provide a common basis for the development of traffic-engineering capabilities for the Internet. The principles, architectures, and methodologies for performance evaluation and performance optimization of operational networks are also discussed.</t>
            <t>This work was first published as RFC 3272 in May 2002. This document obsoletes RFC 3272 by making a complete update to bring the text in line with best current practices for Internet traffic engineering and to include references to the latest relevant work in the IETF.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="9522"/>
        <seriesInfo name="DOI" value="10.17487/RFC9522"/>
      </reference>
      <reference anchor="RFC7426">
        <front>
          <title>Software-Defined Networking (SDN): Layers and Architecture Terminology</title>
          <author fullname="E. Haleplidis" initials="E." role="editor" surname="Haleplidis"/>
          <author fullname="K. Pentikousis" initials="K." role="editor" surname="Pentikousis"/>
          <author fullname="S. Denazis" initials="S." surname="Denazis"/>
          <author fullname="J. Hadi Salim" initials="J." surname="Hadi Salim"/>
          <author fullname="D. Meyer" initials="D." surname="Meyer"/>
          <author fullname="O. Koufopavlou" initials="O." surname="Koufopavlou"/>
          <date month="January" year="2015"/>
          <abstract>
            <t>Software-Defined Networking (SDN) refers to a new approach for network programmability, that is, the capacity to initialize, control, change, and manage network behavior dynamically via open interfaces. SDN emphasizes the role of software in running networks through the introduction of an abstraction for the data forwarding plane and, by doing so, separates it from the control plane. This separation allows faster innovation cycles at both planes as experience has already shown. However, there is increasing confusion as to what exactly SDN is, what the layer structure is in an SDN architecture, and how layers interface with each other. This document, a product of the IRTF Software-Defined Networking Research Group (SDNRG), addresses these questions and provides a concise reference for the SDN research community based on relevant peer-reviewed literature, the RFC series, and relevant documents by other standards organizations.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="7426"/>
        <seriesInfo name="DOI" value="10.17487/RFC7426"/>
      </reference>
      <reference anchor="RFC5440">
        <front>
          <title>Path Computation Element (PCE) Communication Protocol (PCEP)</title>
          <author fullname="JP. Vasseur" initials="JP." role="editor" surname="Vasseur"/>
          <author fullname="JL. Le Roux" initials="JL." role="editor" surname="Le Roux"/>
          <date month="March" year="2009"/>
          <abstract>
            <t>This document specifies the Path Computation Element (PCE) Communication Protocol (PCEP) for communications between a Path Computation Client (PCC) and a PCE, or between two PCEs. Such interactions include path computation requests and path computation replies as well as notifications of specific states related to the use of a PCE in the context of Multiprotocol Label Switching (MPLS) and Generalized MPLS (GMPLS) Traffic Engineering. PCEP is designed to be flexible and extensible so as to easily allow for the addition of further messages and objects, should further requirements be expressed in the future. [STANDARDS-TRACK]</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="5440"/>
        <seriesInfo name="DOI" value="10.17487/RFC5440"/>
      </reference>
      <reference anchor="RFC8955">
        <front>
          <title>Dissemination of Flow Specification Rules</title>
          <author fullname="C. Loibl" initials="C." surname="Loibl"/>
          <author fullname="S. Hares" initials="S." surname="Hares"/>
          <author fullname="R. Raszuk" initials="R." surname="Raszuk"/>
          <author fullname="D. McPherson" initials="D." surname="McPherson"/>
          <author fullname="M. Bacher" initials="M." surname="Bacher"/>
          <date month="December" year="2020"/>
          <abstract>
            <t>This document defines a Border Gateway Protocol Network Layer Reachability Information (BGP NLRI) encoding format that can be used to distribute (intra-domain and inter-domain) traffic Flow Specifications for IPv4 unicast and IPv4 BGP/MPLS VPN services. This allows the routing system to propagate information regarding more specific components of the traffic aggregate defined by an IP destination prefix.</t>
            <t>It also specifies BGP Extended Community encoding formats, which can be used to propagate Traffic Filtering Actions along with the Flow Specification NLRI. Those Traffic Filtering Actions encode actions a routing system can take if the packet matches the Flow Specification.</t>
            <t>This document obsoletes both RFC 5575 and RFC 7674.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="8955"/>
        <seriesInfo name="DOI" value="10.17487/RFC8955"/>
      </reference>
      <reference anchor="RFC2119">
        <front>
          <title>Key words for use in RFCs to Indicate Requirement Levels</title>
          <author fullname="S. Bradner" initials="S." surname="Bradner"/>
          <date month="March" year="1997"/>
          <abstract>
            <t>In many standards track documents several words are used to signify the requirements in the specification. These words are often capitalized. This document defines these words as they should be interpreted in IETF documents. This document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t>
          </abstract>
        </front>
        <seriesInfo name="BCP" value="14"/>
        <seriesInfo name="RFC" value="2119"/>
        <seriesInfo name="DOI" value="10.17487/RFC2119"/>
      </reference>
      <reference anchor="RFC8174">
        <front>
          <title>Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words</title>
          <author fullname="B. Leiba" initials="B." surname="Leiba"/>
          <date month="May" year="2017"/>
          <abstract>
            <t>RFC 2119 specifies common key words that may be used in protocol specifications. This document aims to reduce the ambiguity by clarifying that only UPPERCASE usage of the key words have the defined special meanings.</t>
          </abstract>
        </front>
        <seriesInfo name="BCP" value="14"/>
        <seriesInfo name="RFC" value="8174"/>
        <seriesInfo name="DOI" value="10.17487/RFC8174"/>
      </reference>
      <reference anchor="RFC9315">
        <front>
          <title>Intent-Based Networking - Concepts and Definitions</title>
          <author fullname="A. Clemm" initials="A." surname="Clemm"/>
          <author fullname="L. Ciavaglia" initials="L." surname="Ciavaglia"/>
          <author fullname="L. Z. Granville" initials="L. Z." surname="Granville"/>
          <author fullname="J. Tantsura" initials="J." surname="Tantsura"/>
          <date month="October" year="2022"/>
          <abstract>
            <t>Intent and Intent-Based Networking are taking the industry by storm. At the same time, terms related to Intent-Based Networking are often used loosely and inconsistently, in many cases overlapping and confused with other concepts such as "policy." This document clarifies the concept of "intent" and provides an overview of the functionality that is associated with it. The goal is to contribute towards a common and shared understanding of terms, concepts, and functionality that can be used as the foundation to guide further definition of associated research and engineering problems and their solutions.</t>
            <t>This document is a product of the IRTF Network Management Research Group (NMRG). It reflects the consensus of the research group, having received many detailed and positive reviews by research group participants. It is published for informational purposes.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="9315"/>
        <seriesInfo name="DOI" value="10.17487/RFC9315"/>
      </reference>
      <reference anchor="I-D.draft-ietf-idr-segment-routing-te-policy">
        <front>
          <title>Advertising Segment Routing Policies in BGP</title>
          <author fullname="Stefano Previdi" initials="S." surname="Previdi">
            <organization>Huawei Technologies</organization>
          </author>
          <author fullname="Clarence Filsfils" initials="C." surname="Filsfils">
            <organization>Cisco Systems</organization>
          </author>
          <author fullname="Ketan Talaulikar" initials="K." surname="Talaulikar">
            <organization>Cisco Systems</organization>
          </author>
          <author fullname="Paul Mattes" initials="P." surname="Mattes">
            <organization>Microsoft</organization>
          </author>
          <author fullname="Dhanendra Jain" initials="D." surname="Jain">
            <organization>Google</organization>
          </author>
          <date day="23" month="October" year="2023"/>
          <abstract>
            <t>   This document introduces a BGP SAFI with two NLRIs to advertise a
   candidate path of a Segment Routing (SR) Policy.  An SR Policy is an
   ordered list of segments (i.e., instructions) that represent a
   source-routed policy.  An SR Policy consists of one or more candidate
   paths, each consisting of one or more segment lists.  A headend may
   be provisioned with candidate paths for an SR Policy via several
   different mechanisms, e.g., CLI, NETCONF, PCEP, or BGP.  This
   document specifies how BGP may be used to distribute SR Policy
   candidate paths.  It defines sub-TLVs for the Tunnel Encapsulation
   Attribute for signaling information about these candidate paths.

   This documents updates RFC9012 with extensions to the Color Extended
   Community to support additional steering modes over SR Policy.

            </t>
          </abstract>
        </front>
        <seriesInfo name="Internet-Draft" value="draft-ietf-idr-segment-routing-te-policy-26"/>
      </reference>
      <reference anchor="I-D.draft-ietf-idr-bgp-ls-sr-service-segments">
        <front>
          <title>BGP-LS Advertisement of Segment Routing Service Segments</title>
          <author fullname="Gaurav Dawra" initials="G." surname="Dawra">
            <organization>LinkedIn</organization>
          </author>
          <author fullname="Clarence Filsfils" initials="C." surname="Filsfils">
            <organization>Cisco Systems</organization>
          </author>
          <author fullname="Ketan Talaulikar" initials="K." surname="Talaulikar">
            <organization>Cisco Systems</organization>
          </author>
          <author fullname="Francois Clad" initials="F." surname="Clad">
            <organization>Cisco Systems</organization>
          </author>
          <author fullname="Daniel Bernier" initials="D." surname="Bernier">
            <organization>Bell Canada</organization>
          </author>
          <author fullname="Jim Uttaro" initials="J." surname="Uttaro">
            <organization>AT&amp;T</organization>
          </author>
          <author fullname="Bruno Decraene" initials="B." surname="Decraene">
            <organization>Orange</organization>
          </author>
          <author fullname="Hani Elmalky" initials="H." surname="Elmalky">
            <organization>Ericsson</organization>
          </author>
          <author fullname="Xiaohu Xu" initials="X." surname="Xu">
            <organization>Capitalonline</organization>
          </author>
          <author fullname="Jim Guichard" initials="J." surname="Guichard">
            <organization>Futurewei Technologies</organization>
          </author>
          <author fullname="Cheng Li" initials="C." surname="Li">
            <organization>Huawei Technologies</organization>
          </author>
          <date day="5" month="November" year="2022"/>
          <abstract>
            <t>   Service functions are deployed as, physical or virtualized elements
   along with network nodes or on servers in data centers.  Segment
   Routing (SR) brings in the concept of segments which can be
   topological or service instructions.  Service segments are SR
   segments that are associated with service functions.  SR Policies are
   used for the setup of paths for steering of traffic through service
   functions using their service segments.

   BGP Link-State (BGP-LS) enables distribution of topology information
   from the network to a controller or an application in general so it
   can learn the network topology.  This document specifies the
   extensions to BGP-LS for the advertisement of service functions along
   their associated service segments.  The BGP-LS advertisement of
   service function information along with the network nodes that they
   are attached to, or associated with, enables controllers compute and
   setup service paths in the network.

            </t>
          </abstract>
        </front>
        <seriesInfo name="Internet-Draft" value="draft-ietf-idr-bgp-ls-sr-service-segments-02"/>
      </reference>
      <reference anchor="I-D.draft-ietf-idr-ts-flowspec-srv6-policy">
        <front>
          <title>Traffic Steering using BGP FlowSpec with SR Policy</title>
          <author fullname="Jiang Wenying" initials="J." surname="Wenying">
            <organization>China Mobile</organization>
          </author>
          <author fullname="Yisong Liu" initials="Y." surname="Liu">
            <organization>China Mobile</organization>
          </author>
          <author fullname="Shunwan Zhuang" initials="S." surname="Zhuang">
            <organization>Huawei Technologies</organization>
          </author>
          <author fullname="Gyan Mishra" initials="G. S." surname="Mishra">
            <organization>Verizon Communications Inc.</organization>
          </author>
          <author fullname="Shuanglong Chen" initials="S." surname="Chen">
            <organization>Huawei Technologies</organization>
          </author>
          <date day="4" month="August" year="2025"/>
          <abstract>
            <t>   BGP Flow Specification (FlowSpec) [RFC8955] and [RFC8956] has been
   proposed to distribute BGP [RFC4271] FlowSpec NLRI to FlowSpec
   clients to mitigate (distributed) denial-of-service attacks, and to
   provide traffic filtering in the context of a BGP/MPLS VPN service.
   Recently, traffic steering applications in the context of SR-MPLS and
   SRv6 using FlowSpec are being used in networks.  This document
   introduces the usage of BGP FlowSpec to steer packets into an SR
   Policy.


            </t>
          </abstract>
        </front>
        <seriesInfo name="Internet-Draft" value="draft-ietf-idr-ts-flowspec-srv6-policy-07"/>
      </reference>
      <reference anchor="I-D.draft-filsfils-spring-path-tracing">
        <front>
          <title>Path Tracing in SRv6 networks</title>
          <author fullname="Clarence Filsfils" initials="C." surname="Filsfils">
            <organization>Cisco Systems, Inc.</organization>
          </author>
          <author fullname="Ahmed Abdelsalam" initials="A." surname="Abdelsalam">
            <organization>Cisco Systems, Inc.</organization>
          </author>
          <author fullname="Pablo Camarillo" initials="P." surname="Camarillo">
            <organization>Cisco Systems, Inc.</organization>
          </author>
          <author fullname="Mark Yufit" initials="M." surname="Yufit">
            <organization>Broadcom</organization>
          </author>
          <author fullname="Thomas Graf" initials="T." surname="Graf">
            <organization>Swisscom</organization>
          </author>
          <author fullname="Yuanchao Su" initials="Y." surname="Su">
            <organization>Alibaba, Inc</organization>
          </author>
          <author fullname="Satoru Matsushima" initials="S." surname="Matsushima">
            <organization>SoftBank</organization>
          </author>
          <author fullname="Mike Valentine" initials="M." surname="Valentine">
            <organization>Goldman Sachs</organization>
          </author>
          <author fullname="Amit Dhamija" initials="" surname="Dhamija">
            <organization>Arrcus</organization>
          </author>
          <date day="23" month="October" year="2023"/>
          <abstract>
            <t>   Path Tracing provides a record of the packet path as a sequence of
   interface ids.  In addition, it provides a record of end-to-end
   delay, per-hop delay, and load on each egress interface along the
   packet delivery path.

   Path Tracing allows to trace 14 hops with only a 40-bytes IPv6 Hop-
   by-Hop extension header.

   Path Tracing supports fine grained timestamp.  It has been designed
   for linerate hardware implementation in the base pipeline.

            </t>
          </abstract>
        </front>
        <seriesInfo name="Internet-Draft" value="draft-filsfils-spring-path-tracing-05"/>
      </reference>
    </references>
    <?line 325?>

<section numbered="false" anchor="acknowledgments">
      <name>Acknowledgments</name>
      <t>The authors would like to acknowledge the review and inputs from Mitsuru Maruyama, Katsuhiro Sebayashi, Yuma Ito, and Taisei Tanabe.
We partially obtained the research results from NICT's commissioned research No.JPJ012368C03101 and JST's CRONOS No.JPMJCS24N9.</t>
    </section>
  </back>
  <!-- ##markdown-source:
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

-->

</rfc>
