<?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.30 (Ruby 3.4.8) -->
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" ipr="trust200902" docName="draft-watal-spring-srv6-sfc-sr-aware-functions-04" category="info" tocInclude="true" sortRefs="true" symRefs="true" version="3">
  <!-- xml2rfc v2v3 conversion 3.31.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-04"/>
    <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="2026" month="February" day="06"/>
    <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://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>
      <section anchor="goalsobjectives">
        <name>Goals/Objectives</name>
        <t>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>
      <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="Ahmed Abdelsalam" initials="A." surname="Abdelsalam">
            <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="3" month="November" 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-12"/>
      </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="1" month="February" year="2026"/>
          <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-08"/>
      </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 327?>

<section numbered="false" anchor="appendix-a-implementation-experience">
      <name>Appendix A. Implementation Experience</name>
      <t>Note to the RFC Editor: Please remove this appendix before publication as an RFC.</t>
      <t>This appendix is informative and non-normative.</t>
      <t>Several components of the architecture have been implemented and validated in IETF Hackathons.</t>
      <t>A.1. Flow-based Service Classification</t>
      <t>The following functionality has been implemented in GoBGP:</t>
      <ul spacing="normal">
        <li>
          <t>Advertisement of classification rules using BGP Flowspec extensions for SRv6 Policy.</t>
        </li>
      </ul>
      <t>A.2. SR Policy Computation and Provisioning</t>
      <t>The following functionality has been implemented in Pola PCE:</t>
      <ul spacing="normal">
        <li>
          <t>Centralized SR Policy computation for SFC using a stateful PCE.</t>
        </li>
        <li>
          <t>Support for explicit and dynamic SRv6 Policies with loose source routing.</t>
        </li>
      </ul>
      <t>A.3. Service Segment Advertisement</t>
      <t>The following functionality has been implemented in GoBGP and ExaBGP:</t>
      <ul spacing="normal">
        <li>
          <t>Advertisement of VNF and End.AN information using BGP-LS Service Segment extensions.</t>
        </li>
      </ul>
      <t>A.4. Service and Infrastructure Management</t>
      <t>The following functionality has been implemented using OpenStack and Ansible:</t>
      <ul spacing="normal">
        <li>
          <t>Deployment of VNFs.</t>
        </li>
        <li>
          <t>Provisioning of SRv6 End.AN behaviors.</t>
        </li>
      </ul>
    </section>
    <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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
TwAA

-->

</rfc>
