<?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.2.3) -->
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" ipr="trust200902" docName="draft-ietf-cats-framework-09" category="info" consensus="true" submissionType="IETF" tocInclude="true" sortRefs="true" symRefs="true" version="3">
  <!-- xml2rfc v2v3 conversion 3.29.0 -->
  <front>
    <title abbrev="CATS Framework">A Framework for Computing-Aware Traffic Steering (CATS)</title>
    <seriesInfo name="Internet-Draft" value="draft-ietf-cats-framework-09"/>
    <author initials="C." surname="Li" fullname="Cheng Li" role="editor">
      <organization>Huawei Technologies</organization>
      <address>
        <postal>
          <country>China</country>
        </postal>
        <email>c.l@huawei.com</email>
      </address>
    </author>
    <author initials="Z." surname="Du" fullname="Zongpeng Du">
      <organization>China Mobile</organization>
      <address>
        <postal>
          <country>China</country>
        </postal>
        <email>duzongpeng@chinamobile.com</email>
      </address>
    </author>
    <author fullname="Mohamed Boucadair" role="editor">
      <organization>Orange</organization>
      <address>
        <postal>
          <country>France</country>
        </postal>
        <email>mohamed.boucadair@orange.com</email>
      </address>
    </author>
    <author fullname="Luis M. Contreras">
      <organization>Telefonica</organization>
      <address>
        <postal>
          <country>Spain</country>
        </postal>
        <email>luismiguel.contrerasmurillo@telefonica.com</email>
      </address>
    </author>
    <author initials="J." surname="Drake" fullname="John E Drake">
      <organization>Independent</organization>
      <address>
        <postal>
          <country>United States of America</country>
        </postal>
        <email>je_drake@yahoo.com</email>
      </address>
    </author>
    <date year="2025" month="June" day="18"/>
    <area>Routing area</area>
    <workgroup>cats</workgroup>
    <keyword>Computing Computing-Aware Traffic Steering</keyword>
    <keyword>User Experience</keyword>
    <keyword>Collaborative Networking</keyword>
    <keyword>Service optimization</keyword>
    <abstract>
      <?line 110?>

<t>This document describes a framework for Computing-Aware Traffic Steering (CATS). Specifically, the document identifies a set of CATS components, describes their interactions, and provides illustrative workflows of the control and data planes.</t>
    </abstract>
  </front>
  <middle>
    <?line 114?>

<section anchor="introduction">
      <name>Introduction</name>
      <t>Computing service architectures have evolved from single service site to multiple, sometimes collaborative, service sites to address various issues such as long response times or suboptimal utilization of service and network resources (e.g., resource under-utilization or exhaustion).</t>
      <t>The underlying networking infrastructures that include computing resources usually provide relatively static service dispatching, e.g., the selection of the service instances for a request. In such infrastructures, service-specific traffic is often directed to the closest service site from a routing perspective without considering the actual network state (e.g., traffic congestion conditions) or the service site state.</t>
      <t>As described in <xref target="I-D.ietf-cats-usecases-requirements"/>, traffic steering that takes into account computing resource metrics would benefit several services, including latency-sensitive services such as immersive services that rely upon the use of augmented reality or virtual reality (AR/VR) techniques. This document provides an architectural framework that aims at facilitating the making of compute- and network-aware traffic steering decisions in networking environments where computing service resources are deployed.</t>
      <t>The Computing-Aware Traffic Steering (CATS) framework assumes that there might be multiple service instances that are providing one given service, which are running in one or more service sites. Each of these service instances can be accessed via a service contact instance, which is a client-facing service function instance. A single service site may host one or multiple service contact instances. A single service site may have limited computing resources available at a given time, whereas the various service sites may experience different resource availability issues over time. Therefore, steering traffic among different service sites can address the issues of lacking resources in a specific service site.</t>
      <t>Steering in CATS is about selecting the appropriate service contact instance that will service a request according to a set of network and computing metrics. This selection may not necessarily reveal the actual service instance that will be invoked, e.g., in hierarchical or recursive contexts. Therefore, the metrics of the service contact instance may be the aggregated metrics from multiple service instances.</t>
      <t>The CATS framework is an overlay framework for the selection of the suitable service contact instance(s) from a set of candidates. The exact characterization of 'suitable' is determined by a combination of networking and computing metrics.</t>
      <t>Furthermore, this document describes a workflow of the main CATS procedures in <xref target="sec-cats-workflow"/>, which are executed in both the control and data planes.</t>
    </section>
    <section anchor="terminology">
      <name>Terminology</name>
      <t>This document makes use of the following terms:</t>
      <dl>
        <dt>Client:</dt>
        <dd>
          <t>An endpoint that is connected to a service provider network.</t>
        </dd>
        <dt>Flow:</dt>
        <dd>
          <t>A flow is identified by the 5-tuple transport coordinates (source address and destination address, source and destination port numbers, and protocol).</t>
        </dd>
        <dt>Computing-Aware Traffic Steering (CATS):</dt>
        <dd>
          <t>A traffic engineering approach <xref target="RFC9522"/> that takes into account the dynamic nature of computing resources (e.g., compute and storage) and network state to optimize service-specific traffic forwarding towards a given service contact instance. Various relevant metrics may be used to enable such computing-aware traffic steering policies.</t>
        </dd>
        <dt>Metric:</dt>
        <dd>
          <t>A piece of information that provides suitable input to a selection mechanism to determine a CATS egress node.</t>
        </dd>
        <dt>Computing metrics:</dt>
        <dd>
          <t>Computing metrics are the metrics that come specifically from the computing side of the system as distinct from other metrics that may be used in a CATS system, such as the metrics from network side.</t>
        </dd>
        <dt>Service:</dt>
        <dd>
          <t>An offering that is made available by a service provider by orchestrating a set of resources (networking, compute, storage, etc.).</t>
        </dd>
        <dt/>
        <dd>
          <t>Which and how these resources are used is part of the service logic which is internal to the service provider. For example, these resources may be:
</t>
          <ul spacing="normal">
            <li>
              <t>Exposed by one or multiple processes.</t>
            </li>
            <li>
              <t>Provided by virtual instances, physical, or a combination thereof.</t>
            </li>
            <li>
              <t>Hosted within the same or distinct nodes.</t>
            </li>
            <li>
              <t>Hosted within the same or multiple service sites.</t>
            </li>
            <li>
              <t>Chained to provide a service using a variety of means.</t>
            </li>
          </ul>
        </dd>
        <dt/>
        <dd>
          <t>How a service is structured is out of the scope of CATS.</t>
        </dd>
        <dt/>
        <dd>
          <t>The same service can be provided in many locations; each of them constitutes a service instance.</t>
        </dd>
        <dt>Computing Service:</dt>
        <dd>
          <t>An offering is made available by a service provider by orchestrating a set of computing resources.</t>
        </dd>
        <dt>CATS Service ID (CS-ID):</dt>
        <dd>
          <t>An identifier representing a service, which the clients use to access it. See <xref target="cats-ids"/>.</t>
        </dd>
        <dt>Service instance:</dt>
        <dd>
          <t>An instance of running resources according to a given service logic.</t>
        </dd>
        <dt/>
        <dd>
          <t>Many such instances can be enabled by a service provider. Instances that adhere to the same service logic provide the same service.</t>
        </dd>
        <dt/>
        <dd>
          <t>An instance is running in a service site. Clients' requests are serviced by one or more of these instances.</t>
        </dd>
        <dt>Service site:</dt>
        <dd>
          <t>A location that hosts the resources that are required to offer a service.</t>
        </dd>
        <dt/>
        <dd>
          <t>A service site may be a node or a set of nodes.</t>
        </dd>
        <dt/>
        <dd>
          <t>A CATS-serviced site is a service site that is connected to a CATS-Forwarder.</t>
        </dd>
        <dt>Service contact instance:</dt>
        <dd>
          <t>A client-facing service function instance that is responsible for receiving requests in the context of a given service.</t>
        </dd>
        <dt/>
        <dd>
          <t>A service contact instance can handle one or more service instances.</t>
        </dd>
        <dt/>
        <dd>
          <t>Steering beyond a service contact instance is hidden to both clients and CATS components.</t>
        </dd>
        <dt/>
        <dd>
          <t>A service request is processed according to the service logic (e.g., handle locally or solicit backend resources).</t>
        </dd>
        <dt/>
        <dd>
          <t>A service contact instance is reachable via at least one Egress CATS-Forwarder.</t>
        </dd>
        <dt/>
        <dd>
          <t>A service can be accessed via multiple service contact instances running at the same or different locations (service sites).</t>
        </dd>
        <dt/>
        <dd>
          <t>A service contact instance may dispatch service requests to one or more service instances (e.g., a service contact instance that behaves as a service load-balancer).</t>
        </dd>
        <dt>CATS Service Contact Instance ID (CSCI-ID):</dt>
        <dd>
          <t>An identifier of a specific service contact instance. See <xref target="cats-ids"/>.</t>
        </dd>
        <dt>Service request:</dt>
        <dd>
          <t>A request to access or invoke a specific service. Such a request is steered to a service contact instance via CATS-Forwarders.</t>
        </dd>
        <dt/>
        <dd>
          <t>A service request is placed using service-specific protocols.</t>
        </dd>
        <dt/>
        <dd>
          <t>Service requests are not explicitly sent by clients to CATS-Forwarders.</t>
        </dd>
        <dt>CATS-Forwarder:</dt>
        <dd>
          <t>A network entity that steers traffic specific to a service request towards a corresponding yet selected service contact instance according to provisioned forwarding decisions. These decisions are supplied by a C-PS, which may or may not be on the CATS-Forwarder.</t>
        </dd>
        <dt/>
        <dd>
          <t>A CATS-Forwarder may behave as Ingress or Egress CATS-Forwarder.</t>
        </dd>
        <dt>Ingress CATS-Forwarder:</dt>
        <dd>
          <t>An entity that steers service-specific traffic along a CATS-computed path that leads to an Egress CATS-Forwarder that connects to the most suitable service site that host the service contact instance selected to satisfy the initial service request.</t>
        </dd>
        <dt>Egress CATS-Forwarder:</dt>
        <dd>
          <t>An entity that is located at the end of a CATS-computed path and which connects to a CATS-serviced site.</t>
        </dd>
        <dt>CATS Path Selector (C-PS):</dt>
        <dd>
          <t>A functional entity that selects paths towards service locations and instances and which accommodates the requirements of service requests. Such a path selection engine takes into account the service and network status information. See <xref target="sec-cps"/>.</t>
        </dd>
        <dt>CATS Service Metric Agent (C-SMA):</dt>
        <dd>
          <t>A functional entity that is responsible for collecting service capabilities and status, and for reporting them to a CATS Path Selector (C-PS). See <xref target="sec-csma"/>.</t>
        </dd>
        <dt>CATS Network Metric Agent (C-NMA):</dt>
        <dd>
          <t>A functional entity that is responsible for collecting network capabilities and status, and for reporting them to a C-PS. See <xref target="sec-cnma"/>.</t>
        </dd>
        <dt>CATS Traffic Classifier (C-TC):</dt>
        <dd>
          <t>A functional entity that is responsible for determining which packets belong to a traffic flow for a specific service request. It is also responsible for forwarding such packets along a C-PS computed path that leads to the relevant service contact instance. See <xref target="sec-ctc"/>.</t>
        </dd>
      </dl>
    </section>
    <section anchor="Framework-and-concepts">
      <name>CATS Framework and Components</name>
      <section anchor="assumptions">
        <name>Assumptions</name>
        <t>CATS assumes that there are multiple service instances running on different service sites, which provide a given service that is represented by the same service identifier (see <xref target="cats-ids"/>). However, CATS does not make any assumption about these instances other than they are reachable via one or multiple service contact instances.</t>
      </section>
      <section anchor="cats-ids">
        <name>CATS Identifiers</name>
        <t>CATS uses the following identifiers:</t>
        <dl>
          <dt>CATS Service ID (CS-ID):</dt>
          <dd>
            <t>An identifier representing a service, which the clients use to access it. Such an ID identifies all the instances of a given service, regardless of their location.</t>
          </dd>
          <dt/>
          <dd>
            <t>The CS-ID is independent of which service contact instance serves the service request.</t>
          </dd>
          <dt/>
          <dd>
            <t>Service requests are spread over the service contact instances that can accommodate them, considering the location of the initiator of the service request and the availability (in terms of resource/traffic load, for example) of the service instances resource-wise among other considerations like traffic congestion conditions.</t>
          </dd>
          <dt>CATS Service Contact Instance ID (CSCI-ID):</dt>
          <dd>
            <t>An identifier of a specific service contact instance.</t>
          </dd>
        </dl>
      </section>
      <section anchor="sec-cats-framework">
        <name>Framework Overview</name>
        <t>A high-level view of the CATS framework, without expanding the functional entities in the network, is illustrated in <xref target="fig-cats-fw"/>.</t>
        <figure anchor="fig-cats-fw">
          <name>Main CATS Interactions</name>
          <artset>
            <artwork type="svg"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="384" width="488" viewBox="0 0 488 384" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
                <path d="M 8,32 L 8,96" fill="none" stroke="black"/>
                <path d="M 8,160 L 8,192" fill="none" stroke="black"/>
                <path d="M 288,32 L 288,96" fill="none" stroke="black"/>
                <path d="M 288,160 L 288,192" fill="none" stroke="black"/>
                <path d="M 312,32 L 312,336" fill="none" stroke="black"/>
                <path d="M 392,32 L 392,96" fill="none" stroke="black"/>
                <path d="M 392,160 L 392,208" fill="none" stroke="black"/>
                <path d="M 392,272 L 392,320" fill="none" stroke="black"/>
                <path d="M 408,176 L 408,240" fill="none" stroke="black"/>
                <path d="M 408,288 L 408,336" fill="none" stroke="black"/>
                <path d="M 424,96 L 424,152" fill="none" stroke="black"/>
                <path d="M 464,32 L 464,96" fill="none" stroke="black"/>
                <path d="M 480,176 L 480,240" fill="none" stroke="black"/>
                <path d="M 480,288 L 480,336" fill="none" stroke="black"/>
                <path d="M 8,32 L 288,32" fill="none" stroke="black"/>
                <path d="M 392,32 L 464,32" fill="none" stroke="black"/>
                <path d="M 8,64 L 288,64" fill="none" stroke="black"/>
                <path d="M 320,62 L 384,62" fill="none" stroke="black"/>
                <path d="M 320,66 L 384,66" fill="none" stroke="black"/>
                <path d="M 8,96 L 288,96" fill="none" stroke="black"/>
                <path d="M 392,96 L 464,96" fill="none" stroke="black"/>
                <path d="M 8,160 L 288,160" fill="none" stroke="black"/>
                <path d="M 392,160 L 464,160" fill="none" stroke="black"/>
                <path d="M 408,176 L 480,176" fill="none" stroke="black"/>
                <path d="M 8,192 L 288,192" fill="none" stroke="black"/>
                <path d="M 320,190 L 384,190" fill="none" stroke="black"/>
                <path d="M 320,194 L 384,194" fill="none" stroke="black"/>
                <path d="M 408,240 L 480,240" fill="none" stroke="black"/>
                <path d="M 392,272 L 464,272" fill="none" stroke="black"/>
                <path d="M 408,288 L 480,288" fill="none" stroke="black"/>
                <path d="M 408,336 L 480,336" fill="none" stroke="black"/>
                <polygon class="arrowhead" points="392,192 380,186.4 380,197.6" fill="black" transform="rotate(0,384,192)"/>
                <polygon class="arrowhead" points="392,64 380,58.4 380,69.6" fill="black" transform="rotate(0,384,64)"/>
                <polygon class="arrowhead" points="328,192 316,186.4 316,197.6" fill="black" transform="rotate(180,320,192)"/>
                <polygon class="arrowhead" points="328,64 316,58.4 316,69.6" fill="black" transform="rotate(180,320,64)"/>
                <g class="text">
                  <text x="124" y="52">Management</text>
                  <text x="192" y="52">Plane</text>
                  <text x="424" y="68">C-SMA</text>
                  <text x="128" y="84">Control</text>
                  <text x="184" y="84">Plane</text>
                  <text x="140" y="116">/\</text>
                  <text x="140" y="132">||</text>
                  <text x="140" y="148">\/</text>
                  <text x="116" y="180">Data</text>
                  <text x="160" y="180">Plane</text>
                  <text x="440" y="196">Service</text>
                  <text x="400" y="212">-</text>
                  <text x="440" y="212">Contact</text>
                  <text x="444" y="228">Instance</text>
                  <text x="448" y="260">|</text>
                  <text x="440" y="308">Service</text>
                  <text x="400" y="324">-</text>
                  <text x="444" y="324">Instance</text>
                </g>
              </svg>
            </artwork>
            <artwork type="ascii-art"><![CDATA[
   +----------------------------------+  |         +--------+
   |         Management Plane         |  |         |        |
   +----------------------------------+  |<=======>| C-SMA  |
   |           Control Plane          |  |         |        |
   +----------------------------------+  |         +---+----+
                   /\                    |             |
                   ||                    |             |
                   \/                    |             |
   +----------------------------------+  |         +--------+
   |           Data Plane             |  |         | +--------+
   +----------------------------------+  |<=======>| |Service |
                                         |         +-|Contact |
                                         |           |Instance|
                                         |           +--------+
                                         |                |
                                         |         +--------+
                                         |         | +--------+
                                         |         | |Service |
                                         |         +-|Instance|
                                         |           +--------+

]]></artwork>
          </artset>
        </figure>
        <t>For the sake of illustration, "Service Instance" is shown as a single box in <xref target="fig-cats-fw"/>. However,
this does not imply that a service instance is hosted in a single node. Whether  a service instance
is realized by invoking resources within a same node or by chaining resources exposed by several nodes
is deployment specific.</t>
        <t>The following planes are defined:</t>
        <ul spacing="normal">
          <li>
            <t>CATS Management Plane: Responsible for monitoring, configuring, and maintaining CATS network devices.</t>
          </li>
          <li>
            <t>CATS Control Plane: Responsible for scheduling services based on computing and network information. It is also responsible for making decisions about how packets should be forwarded by involved forwarding nodes and communicating such decisions to the CATS Data Plane for execution.</t>
          </li>
          <li>
            <t>CATS Data Plane: Responsible for computing-aware routing, including handling packets in the data path, such as packet forwarding.</t>
          </li>
        </ul>
        <t>Depending on implementation and deployment, these planes may consist of several functional elements/components, and the details will be described in the following sections.</t>
      </section>
      <section anchor="sec-cats-arch">
        <name>CATS Functional Components</name>
        <t>CATS nodes make forwarding decisions for a given service request that has been received from a client according to the capabilities and status information of both service contact instances and network. The main CATS functional elements and their interactions are shown in <xref target="fig-cats-components"/>.</t>
        <figure anchor="fig-cats-components">
          <name>CATS Functional Components</name>
          <artset>
            <artwork type="svg"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="688" width="480" viewBox="0 0 480 688" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
                <path d="M 8,48 L 8,80" fill="none" stroke="black"/>
                <path d="M 24,320 L 24,368" fill="none" stroke="black"/>
                <path d="M 40,80 L 40,128" fill="none" stroke="black"/>
                <path d="M 56,112 L 56,208" fill="none" stroke="black"/>
                <path d="M 64,48 L 64,80" fill="none" stroke="black"/>
                <path d="M 72,32 L 72,64" fill="none" stroke="black"/>
                <path d="M 72,464 L 72,528" fill="none" stroke="black"/>
                <path d="M 104,152 L 104,176" fill="none" stroke="black"/>
                <path d="M 104,368 L 104,440" fill="none" stroke="black"/>
                <path d="M 104,592 L 104,640" fill="none" stroke="black"/>
                <path d="M 160,320 L 160,368" fill="none" stroke="black"/>
                <path d="M 176,48 L 176,80" fill="none" stroke="black"/>
                <path d="M 176,464 L 176,552" fill="none" stroke="black"/>
                <path d="M 184,336 L 184,448" fill="none" stroke="black"/>
                <path d="M 192,112 L 192,208" fill="none" stroke="black"/>
                <path d="M 192,464 L 192,512" fill="none" stroke="black"/>
                <path d="M 192,592 L 192,640" fill="none" stroke="black"/>
                <path d="M 208,80 L 208,128" fill="none" stroke="black"/>
                <path d="M 208,576 L 208,624" fill="none" stroke="black"/>
                <path d="M 224,560 L 224,608" fill="none" stroke="black"/>
                <path d="M 232,48 L 232,80" fill="none" stroke="black"/>
                <path d="M 232,160 L 232,208" fill="none" stroke="black"/>
                <path d="M 248,32 L 248,64" fill="none" stroke="black"/>
                <path d="M 248,336 L 248,368" fill="none" stroke="black"/>
                <path d="M 264,128 L 264,152" fill="none" stroke="black"/>
                <path d="M 288,160 L 288,208" fill="none" stroke="black"/>
                <path d="M 296,320 L 296,400" fill="none" stroke="black"/>
                <path d="M 304,464 L 304,528" fill="none" stroke="black"/>
                <path d="M 312,112 L 312,208" fill="none" stroke="black"/>
                <path d="M 328,48 L 328,80" fill="none" stroke="black"/>
                <path d="M 328,576 L 328,624" fill="none" stroke="black"/>
                <path d="M 360,80 L 360,112" fill="none" stroke="black"/>
                <path d="M 360,400 L 360,440" fill="none" stroke="black"/>
                <path d="M 368,240 L 368,272" fill="none" stroke="black"/>
                <path d="M 384,48 L 384,80" fill="none" stroke="black"/>
                <path d="M 400,32 L 400,64" fill="none" stroke="black"/>
                <path d="M 408,464 L 408,528" fill="none" stroke="black"/>
                <path d="M 416,576 L 416,624" fill="none" stroke="black"/>
                <path d="M 424,464 L 424,512" fill="none" stroke="black"/>
                <path d="M 432,240 L 432,272" fill="none" stroke="black"/>
                <path d="M 432,320 L 432,400" fill="none" stroke="black"/>
                <path d="M 432,560 L 432,608" fill="none" stroke="black"/>
                <path d="M 448,112 L 448,208" fill="none" stroke="black"/>
                <path d="M 24,32 L 72,32" fill="none" stroke="black"/>
                <path d="M 192,32 L 248,32" fill="none" stroke="black"/>
                <path d="M 344,32 L 400,32" fill="none" stroke="black"/>
                <path d="M 8,48 L 56,48" fill="none" stroke="black"/>
                <path d="M 176,48 L 232,48" fill="none" stroke="black"/>
                <path d="M 328,48 L 384,48" fill="none" stroke="black"/>
                <path d="M 8,80 L 56,80" fill="none" stroke="black"/>
                <path d="M 176,80 L 232,80" fill="none" stroke="black"/>
                <path d="M 328,80 L 384,80" fill="none" stroke="black"/>
                <path d="M 56,112 L 192,112" fill="none" stroke="black"/>
                <path d="M 312,112 L 448,112" fill="none" stroke="black"/>
                <path d="M 40,128 L 56,128" fill="none" stroke="black"/>
                <path d="M 192,128 L 208,128" fill="none" stroke="black"/>
                <path d="M 264,128 L 312,128" fill="none" stroke="black"/>
                <path d="M 64,144 L 184,144" fill="none" stroke="black"/>
                <path d="M 320,144 L 440,144" fill="none" stroke="black"/>
                <path d="M 232,160 L 288,160" fill="none" stroke="black"/>
                <path d="M 104,176 L 184,176" fill="none" stroke="black"/>
                <path d="M 56,208 L 192,208" fill="none" stroke="black"/>
                <path d="M 232,208 L 288,208" fill="none" stroke="black"/>
                <path d="M 312,208 L 448,208" fill="none" stroke="black"/>
                <path d="M 368,240 L 432,240" fill="none" stroke="black"/>
                <path d="M 368,272 L 432,272" fill="none" stroke="black"/>
                <path d="M 24,320 L 160,320" fill="none" stroke="black"/>
                <path d="M 296,320 L 432,320" fill="none" stroke="black"/>
                <path d="M 184,336 L 248,336" fill="none" stroke="black"/>
                <path d="M 24,368 L 160,368" fill="none" stroke="black"/>
                <path d="M 184,368 L 248,368" fill="none" stroke="black"/>
                <path d="M 296,368 L 432,368" fill="none" stroke="black"/>
                <path d="M 296,400 L 432,400" fill="none" stroke="black"/>
                <path d="M 88,448 L 176,448" fill="none" stroke="black"/>
                <path d="M 320,448 L 408,448" fill="none" stroke="black"/>
                <path d="M 72,464 L 168,464" fill="none" stroke="black"/>
                <path d="M 304,464 L 400,464" fill="none" stroke="black"/>
                <path d="M 72,528 L 176,528" fill="none" stroke="black"/>
                <path d="M 304,528 L 408,528" fill="none" stroke="black"/>
                <path d="M 136,560 L 224,560" fill="none" stroke="black"/>
                <path d="M 344,560 L 432,560" fill="none" stroke="black"/>
                <path d="M 120,576 L 208,576" fill="none" stroke="black"/>
                <path d="M 328,576 L 416,576" fill="none" stroke="black"/>
                <path d="M 104,592 L 192,592" fill="none" stroke="black"/>
                <path d="M 328,624 L 416,624" fill="none" stroke="black"/>
                <path d="M 104,640 L 192,640" fill="none" stroke="black"/>
                <path d="M 56,48 C 64.83064,48 72,55.16936 72,64" fill="none" stroke="black"/>
                <path d="M 56,48 C 64.83064,48 72,40.83064 72,32" fill="none" stroke="black"/>
                <path d="M 56,80 C 64.83064,80 72,72.83064 72,64" fill="none" stroke="black"/>
                <path d="M 88,448 C 79.16936,448 72,455.16936 72,464" fill="none" stroke="black"/>
                <path d="M 176,448 C 184.83064,448 192,455.16936 192,464" fill="none" stroke="black"/>
                <path d="M 320,448 C 311.16936,448 304,455.16936 304,464" fill="none" stroke="black"/>
                <path d="M 408,448 C 416.83064,448 424,455.16936 424,464" fill="none" stroke="black"/>
                <path d="M 168,464 C 176.83064,464 184,456.83064 184,448" fill="none" stroke="black"/>
                <path d="M 400,464 C 408.83064,464 416,456.83064 416,448" fill="none" stroke="black"/>
                <g class="text">
                  <text x="36" y="68">client</text>
                  <text x="204" y="68">client</text>
                  <text x="240" y="68">-</text>
                  <text x="356" y="68">client</text>
                  <text x="392" y="68">-</text>
                  <text x="116" y="132">C-TC#1</text>
                  <text x="372" y="132">C-TC#2</text>
                  <text x="132" y="164">C-PS#1</text>
                  <text x="372" y="164">CATS-Forwarder</text>
                  <text x="440" y="164">4</text>
                  <text x="28" y="180">......</text>
                  <text x="212" y="180">....</text>
                  <text x="260" y="180">C-PS#2</text>
                  <text x="300" y="180">..</text>
                  <text x="464" y="180">...</text>
                  <text x="8" y="196">:</text>
                  <text x="116" y="196">CATS-Forwarder</text>
                  <text x="184" y="196">2</text>
                  <text x="472" y="196">.</text>
                  <text x="8" y="212">:</text>
                  <text x="472" y="212">:</text>
                  <text x="8" y="228">:</text>
                  <text x="472" y="228">:</text>
                  <text x="8" y="244">:</text>
                  <text x="472" y="244">:</text>
                  <text x="8" y="260">:</text>
                  <text x="244" y="260">Underlay</text>
                  <text x="400" y="260">C-NMA</text>
                  <text x="472" y="260">:</text>
                  <text x="8" y="276">:</text>
                  <text x="244" y="276">Infrastructure</text>
                  <text x="472" y="276">:</text>
                  <text x="8" y="292">:</text>
                  <text x="472" y="292">:</text>
                  <text x="8" y="308">:</text>
                  <text x="472" y="308">:</text>
                  <text x="8" y="324">:</text>
                  <text x="472" y="324">:</text>
                  <text x="8" y="340">:</text>
                  <text x="84" y="340">CATS-Forwarder</text>
                  <text x="152" y="340">1</text>
                  <text x="356" y="340">CATS-Forwarder</text>
                  <text x="424" y="340">3</text>
                  <text x="472" y="340">:</text>
                  <text x="12" y="356">:.</text>
                  <text x="172" y="356">..</text>
                  <text x="216" y="356">C-SMA#1</text>
                  <text x="268" y="356">....</text>
                  <text x="456" y="356">....:</text>
                  <text x="352" y="388">C-SMA#2</text>
                  <text x="120" y="484">Service</text>
                  <text x="352" y="484">Service</text>
                  <text x="120" y="500">Contact</text>
                  <text x="352" y="500">Contact</text>
                  <text x="124" y="516">Instance</text>
                  <text x="184" y="516">-</text>
                  <text x="356" y="516">Instance</text>
                  <text x="416" y="516">-</text>
                  <text x="384" y="548">|</text>
                  <text x="368" y="596">Service</text>
                  <text x="144" y="612">Service</text>
                  <text x="216" y="612">-</text>
                  <text x="372" y="612">Instance</text>
                  <text x="424" y="612">-</text>
                  <text x="148" y="628">Instance</text>
                  <text x="200" y="628">-</text>
                  <text x="104" y="660">Service</text>
                  <text x="156" y="660">Site</text>
                  <text x="184" y="660">1</text>
                  <text x="328" y="660">Service</text>
                  <text x="380" y="660">Site</text>
                  <text x="408" y="660">2</text>
                </g>
              </svg>
            </artwork>
            <artwork type="ascii-art"><![CDATA[
    +-----+              +------+           +------+
  +------+|            +------+ |         +------+ |
  |client|+            |client|-+         |client|-+
  +---+--+             +---+--+           +---+--+
      |                    |                  |
      | +----------------+ |            +-----+----------+
      '-+    C-TC#1      +-'      .-----+    C-TC#2      |
        |----------------|        |     |----------------|
        |     |C-PS#1    |    +------+  |CATS-Forwarder 4|
  ......|     +----------|....|C-PS#2|..|                |...
  :     |CATS-Forwarder 2|    |      |  |                |  .
  :     +----------------+    +------+  +----------------+  :
  :                                                         :
  :                                            +-------+    :
  :                         Underlay           | C-NMA |    :
  :                      Infrastructure        +-------+    :
  :                                                         :
  :                                                         :
  : +----------------+                +----------------+    :
  : |CATS-Forwarder 1|  +-------+     |CATS-Forwarder 3|    :
  :.|                |..|C-SMA#1|.... |                |....:
    +---------+------+  +-------+     +----------------+
              |         |             |   C-SMA#2      |
              |         |             +-------+--------+
              |         |                     |
              |         |                     |
           +------------+               +------------+
          +------------+ |             +------------+ |
          |  Service   | |             |  Service   | |
          |  Contact   | |             |  Contact   | |
          |  Instance  |-+             |  Instance  |-+
          +------------+               +------------+
                       |                         |
                  +----------+              +----------+
                +----------+ |            +----------+ |
              +----------+ | |            | Service  | |
              | Service  | |-+            | Instance |-+
              | Instance |-+              +----------+
              +----------+
           Service Site 1              Service Site 2
]]></artwork>
          </artset>
        </figure>
        <section anchor="sec-service-sites">
          <name>Service Sites, Services Instances, and Service Contact Instances</name>
          <t>Service sites are locations that host resources (including computing resources) that are required to offer a service.</t>
          <t>A compute service (e.g., for face recognition purposes or a game server) is identified by a CATS Service Identifier (CS-ID). The CS-ID does not need to be globally unique, but must be sufficiently unique to unambiguously identify the service at all of the components of a CATS system.</t>
          <t>A single service can be represented and accessed via several contact instances that run in same or different regions of a network.</t>
          <t>As service instances are accessed via a service contact instance, a client will not see the service instances but only the service contact instance.</t>
          <t><xref target="fig-cats-components"/> shows two CATS nodes ("CATS-Forwarder 1" and "CATS-Forwarder 3") that provide access to service contact instances.  These nodes behave as Egress CATS-Forwarders (<xref target="sec-ocr"/>).</t>
          <ul empty="true">
            <li>
              <t>Note: "Egress" is used here in reference to the direction of the service request placement.  The directionality is called to explicitly identify the exit node of the CATS infrastructure.</t>
            </li>
          </ul>
        </section>
        <section anchor="sec-csma">
          <name>CATS Service Metric Agent (C-SMA)</name>
          <t>The CATS Service Metric Agent (C-SMA) is a functional component that gathers information about service sites and server resources, as well as the status of the different service instances. A C-SMA may be co-located or located adjacent to a service contact instance, hosted by or adjacent to an Egress CATS-Forwarder (<xref target="sec-ocr"/>), etc.</t>
          <t><xref target="fig-cats-components"/> shows one C-SMA embedded in "CATS-Forwarder 3", and another C-SMA that is adjacent to "CATS-Forwarder 1".</t>
        </section>
        <section anchor="sec-cnma">
          <name>CATS Network Metric Agent (C-NMA)</name>
          <t>The CATS Network Metric Agent (C-NMA) is a functional component that gathers information about the state of the underlay network. The C-NMAs may be implemented as standalone components or may be hosted by other components, such as CATS-Forwarders or CATS Path Selectors (C-PS) (<xref target="sec-cps"/>).</t>
          <t>C-NMA is likely to leverage existing techniques (e.g., <xref target="RFC7471"/>, <xref target="RFC8570"/>, and <xref target="RFC8571"/>).</t>
          <t><xref target="fig-cats-components"/> shows a single, standalone C-NMA within the underlay network. There may be one or more C-NMAs for an underlay network.</t>
        </section>
        <section anchor="sec-cps">
          <name>CATS Path Selector (C-PS)</name>
          <t>The C-SMAs and C-NMAs share the collected information with CATS Path Selectors (C-PSes) that use such information to select the Egress CATS-Forwarders (and potentially the service contact instances) where to forward traffic for a given service request. C-PSes also determine the best paths (possibly using tunnels) to forward traffic, according to various criteria that include network state and traffic congestion conditions. The collected information is encoded into one or more metrics that feed the C-PS path selection logic. Such information also includes CS-ID and possibly CSCI-IDs.</t>
          <t>There might be one or more C-PSes used to select CATS paths in a CATS infrastructure.</t>
          <t>A C-PS can be integrated into CATS-Forwarders (e.g., "C-PS#1" in <xref target="fig-cats-components"/>) or may be deployed as a standalone component (e.g., "C-PS#2" in <xref target="fig-cats-components"/>). Generally, a standalone C-PS can be a functional component of a centralized controller (e.g., a Path Computation Element (PCE) <xref target="RFC4655"/>).</t>
          <t>Refer to <xref target="sec-met-dist"/> for a discussion on metric distribution (including, interaction with routing protocols).</t>
        </section>
        <section anchor="sec-ctc">
          <name>CATS Traffic Classifier (C-TC)</name>
          <t>The CATS Traffic Classifier (C-TC) is a functional component that is responsible for associating incoming packets from clients with service requests. CATS classifiers also ensure that packets that are bound to a specific service contact instance are all forwarded towards that same service contact instance, as instructed by a C-PS.</t>
          <t>CATS classifiers are typically hosted in CATS-Forwarders.</t>
        </section>
        <section anchor="sec-ocr">
          <name>CATS-Forwarders</name>
          <t>Ingress CATS-Forwarder are resposnible for steering service-specific traffic along a CATS-computed path that leads to an Egress CATS-
Forwarder. Egress CATS-Forwarders are the endpoints that behave as an egress for service requests that are forwarded over a CATS infrastructure. A service site that hosts service instances may be connected to one or more Egress CATS-Forwarders (e.g., multi-homing design). If a C-PS has selected a specific service contact instance and the C-TC has marked the traffic with the CSCI-ID related information, the Egress CATS-Forwarder then forwards traffic to the relevant service contact instance accordingly. In some cases, the choice of the service contact instance may be left open to the Egress CATS-Forwarder (i.e., traffic is marked only with the CS-ID). In such cases, the Egress CATS-Forwarder selects a service contact instance using its knowledge of service and network capabilities as well as the current load as observed by the CATS-Forwarder, among other considerations. In the absence of an explicit policy, an Egress CATS-Forwarder must make sure to forward all packets that pertain to a given service request towards the same service contact instance.</t>
          <t>Note that, depending on the design considerations and service requirements, per-service  contact instance computing-related metrics or aggregated per-site computing related metrics (and a combination thereof) can be used by a C-PS. Using aggregated per-site computing related metrics appears as a preferred option scalability-wise, but relies on Egress CATS-Forwarders that connect to various service contact instances to select the proper service contact instance. An Egress CATS-Forwarder may choose to aggregate the metrics from different sites as well. In this case, the Egress CATS-Forwarder will choose the best site by itself when the packets arrive at it.</t>
        </section>
        <section anchor="underlay-infrastructure">
          <name>Underlay Infrastructure</name>
          <t>The "underlay infrastructure" in <xref target="fig-cats-components"/> indicates an IP and/or MPLS network that is not necessarily CATS-aware. The CATS paths that are computed by a C-PS will be distributed among the CATS-Forwarders (<xref target="sec-ocr"/>), and will not affect the underlay nodes. Underlay nodes are typically P routers (<xref section="5.3.1" sectionFormat="of" target="RFC4026"/>).</t>
        </section>
      </section>
    </section>
    <section anchor="sec-cats-workflow">
      <name>CATS Framework Workflow</name>
      <t>The following subsections provide an overview of how the CATS workflow operates.</t>
      <section anchor="service-announcement">
        <name>Service Announcement</name>
        <t>A service is associated with a unique identifier called a CS-ID. A CS-ID may be a network identifier, such as an IP address. The mapping of CS-IDs to network identifiers may be learned through a name resolution service (e.g., DNS <xref target="RFC1034"/>). Note that CATS framework does not assume nor preclude any specific name resolution service.</t>
      </section>
      <section anchor="sec-met-dist">
        <name>Metrics Distribution</name>
        <t>As described in <xref target="sec-cats-arch"/>, a C-SMA collects both computing-related capabilities and metrics, and associates them with a CS-ID that identifies the service. The C-SMA may aggregate the metrics for multiple service contact  instances, or maintain them separately or both.</t>
        <t>The C-SMA then advertises CS-IDs along with metrics to related C-PSes in the network. Depending on deployment choice, CS-IDs with metrics may be distributed in different ways.</t>
        <t>For example, in a distributed model, CS-IDs with metrics can be distributed from the C-SMA to an Egress CATS-Forwarder firstly and then be redistributed by the Egress CATS-Forwarder to related C-PSes that are integrated into Ingress CATS-Forwarders.</t>
        <t>In the centralized model, CS-IDs with metrics can be distributed from the C-SMA to a centralized control plane, for instance, a standalone C-PS.</t>
        <t>In the hybrid model, the metrics can be distributed to C-PSes in combination of distributed and centralized ways. The specific combination of metric distribution is an implementation choice, which is determined by the requirements of specific services.</t>
        <t>The Computing metrics include computing-related metrics and potentially other service-specific metrics like the number of end-users who access the service contact instance at any given time, etc.</t>
        <t>Computing metrics may change very frequently (see <xref target="I-D.ietf-cats-usecases-requirements"/> for a discussion). How frequently such information is distributed is to be determined as part of the specification of any communication protocol (including routing protocols) that may be used to distribute the information. Various options can be considered, such as (but not limited to) interval-based updates, threshold-triggered updates, or policy-based updates.</t>
        <t>Additionally, the C-NMA collects network-related capabilities and metrics. These may be collected and distributed by existing measurement protocols and/or routing protocols, although extensions to such protocols may be required to carry additional information (e.g., link latency). The C-NMA distributes the network metrics to the C-PSes so that they can use the combination of service and network metrics to determine the best Egress CATS-Forwarder to provide access to a service contact instance and invoke the compute function required by a service request. Similar to computing-related metrics, the network-related metrics can be distributed using distributed, centralized, or hybrid schemes. This document does not describe such details since this is deployment-specific.</t>
        <t>Network metrics may also change over time. Dynamic routing protocols may take advantage of some information or capabilities to prevent the network from being flooded with state change information (e.g., Partial Route Computation (PRC) of OSPFv3 <xref target="RFC5340"/>). C-NMAs should also be configured or instructed like C-SMAs to determine when and how often updates should be notified to the C-PSes.</t>
        <t><xref target="fig-cats-example-overlay"/> shows an example of how CATS metrics can be disseminated in the distributed model. There is a client attached to the network via "CATS-Forwarder 1". There are three service contact instances of the service with CS-ID "1": two service contact instances with CSCI-IDs "1" and "2", respectively, are located at "Service Site 2" attached via "CATS-Forwarder 2"; the third service contact instance is located at "Service Site 3" attached via "CATS-Forwarder 3" and with CSCI-ID "3". There is also a second service with CS-ID "2" with only one service contact instance located at "Service Site 3".</t>
        <t>In <xref target="fig-cats-example-overlay"/>, the C-SMA collocated with "CATS-Forwarder 2" distributes the computing metrics for both service contact instances (i.e., (CS-ID 1, CSCI-ID 1) and (CS-ID 1, CSCI-ID 2)). Note that this information may be aggregated into a single advertisement, but in this case, the metrics for each service contact instance are indicated separately. Similarly, the C-SMA agent located at "Service Site 3" advertises the computing metrics for the two services hosted by "Service Site 3".</t>
        <t>The computing metric advertisements are processed by the C-PS hosted by "CATS-Forwarder 1". The C-PS also processes network metric advertisements sent by the C-NMA. All metrics are used by the C-PS to select the most relevant path that leads to the Egress CATS-Forwarder according to the initial client's service request, the service that is requested ("CS-ID 1" or "CS-ID 2"), the state of the service contact instances as reported by the metrics, and the state of the network.</t>
        <figure anchor="fig-cats-example-overlay">
          <name>An Example of CATS Metric Dissemination in a Distributed Model</name>
          <artset>
            <artwork type="svg"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="576" width="584" viewBox="0 0 584 576" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
                <path d="M 8,224 L 8,256" fill="none" stroke="black"/>
                <path d="M 8,304 L 8,336" fill="none" stroke="black"/>
                <path d="M 48,264 L 48,296" fill="none" stroke="black"/>
                <path d="M 80,224 L 80,256" fill="none" stroke="black"/>
                <path d="M 184,304 L 184,336" fill="none" stroke="black"/>
                <path d="M 224,240 L 224,264" fill="none" stroke="black"/>
                <path d="M 224,280 L 224,384" fill="none" stroke="black"/>
                <path d="M 224,416 L 224,448" fill="none" stroke="black"/>
                <path d="M 240,256 L 240,288" fill="none" stroke="black"/>
                <path d="M 256,144 L 256,208" fill="none" stroke="black"/>
                <path d="M 304,256 L 304,288" fill="none" stroke="black"/>
                <path d="M 360,416 L 360,448" fill="none" stroke="black"/>
                <path d="M 384,416 L 384,448" fill="none" stroke="black"/>
                <path d="M 392,144 L 392,208" fill="none" stroke="black"/>
                <path d="M 408,240 L 408,384" fill="none" stroke="black"/>
                <path d="M 424,384 L 424,408" fill="none" stroke="black"/>
                <path d="M 424,456 L 424,480" fill="none" stroke="black"/>
                <path d="M 432,128 L 432,192" fill="none" stroke="black"/>
                <path d="M 448,416 L 448,448" fill="none" stroke="black"/>
                <path d="M 456,96 L 456,144" fill="none" stroke="black"/>
                <path d="M 456,176 L 456,224" fill="none" stroke="black"/>
                <path d="M 456,352 L 456,400" fill="none" stroke="black"/>
                <path d="M 456,464 L 456,496" fill="none" stroke="black"/>
                <path d="M 520,464 L 520,496" fill="none" stroke="black"/>
                <path d="M 536,96 L 536,144" fill="none" stroke="black"/>
                <path d="M 536,176 L 536,224" fill="none" stroke="black"/>
                <path d="M 536,352 L 536,400" fill="none" stroke="black"/>
                <path d="M 144,80 L 320,80" fill="none" stroke="black"/>
                <path d="M 456,96 L 536,96" fill="none" stroke="black"/>
                <path d="M 432,128 L 448,128" fill="none" stroke="black"/>
                <path d="M 256,144 L 392,144" fill="none" stroke="black"/>
                <path d="M 456,144 L 536,144" fill="none" stroke="black"/>
                <path d="M 400,160 L 424,160" fill="none" stroke="black"/>
                <path d="M 256,176 L 392,176" fill="none" stroke="black"/>
                <path d="M 456,176 L 536,176" fill="none" stroke="black"/>
                <path d="M 432,192 L 448,192" fill="none" stroke="black"/>
                <path d="M 256,208 L 392,208" fill="none" stroke="black"/>
                <path d="M 8,224 L 80,224" fill="none" stroke="black"/>
                <path d="M 456,224 L 536,224" fill="none" stroke="black"/>
                <path d="M 224,240 L 408,240" fill="none" stroke="black"/>
                <path d="M 8,256 L 80,256" fill="none" stroke="black"/>
                <path d="M 240,256 L 304,256" fill="none" stroke="black"/>
                <path d="M 160,272 L 232,272" fill="none" stroke="black"/>
                <path d="M 240,288 L 304,288" fill="none" stroke="black"/>
                <path d="M 8,304 L 184,304" fill="none" stroke="black"/>
                <path d="M 192,320 L 216,320" fill="none" stroke="black"/>
                <path d="M 8,336 L 184,336" fill="none" stroke="black"/>
                <path d="M 456,352 L 536,352" fill="none" stroke="black"/>
                <path d="M 224,384 L 408,384" fill="none" stroke="black"/>
                <path d="M 424,384 L 448,384" fill="none" stroke="black"/>
                <path d="M 464,400 L 536,400" fill="none" stroke="black"/>
                <path d="M 224,416 L 360,416" fill="none" stroke="black"/>
                <path d="M 384,416 L 440,416" fill="none" stroke="black"/>
                <path d="M 224,448 L 360,448" fill="none" stroke="black"/>
                <path d="M 384,448 L 440,448" fill="none" stroke="black"/>
                <path d="M 464,464 L 520,464" fill="none" stroke="black"/>
                <path d="M 424,480 L 448,480" fill="none" stroke="black"/>
                <path d="M 456,496 L 520,496" fill="none" stroke="black"/>
                <path d="M 144,512 L 392,512" fill="none" stroke="black"/>
                <path d="M 464,400 C 455.16936,400 448,407.16936 448,416" fill="none" stroke="black"/>
                <path d="M 440,416 C 448.83064,416 456,408.83064 456,400" fill="none" stroke="black"/>
                <path d="M 440,448 C 448.83064,448 456,455.16936 456,464" fill="none" stroke="black"/>
                <path d="M 464,464 C 455.16936,464 448,456.83064 448,448" fill="none" stroke="black"/>
                <polygon class="arrowhead" points="168,272 156,266.4 156,277.6" fill="black" transform="rotate(180,160,272)"/>
                <polygon class="arrowhead" points="152,512 140,506.4 140,517.6" fill="black" transform="rotate(180,144,512)"/>
                <polygon class="arrowhead" points="152,80 140,74.4 140,85.6" fill="black" transform="rotate(180,144,80)"/>
                <g class="text">
                  <text x="104" y="36">Service</text>
                  <text x="160" y="36">CS-ID</text>
                  <text x="196" y="36">1,</text>
                  <text x="240" y="36">contact</text>
                  <text x="308" y="36">instance</text>
                  <text x="376" y="36">CSCI-ID</text>
                  <text x="416" y="36">1</text>
                  <text x="468" y="36">&lt;computing</text>
                  <text x="548" y="36">metrics&gt;</text>
                  <text x="104" y="52">Service</text>
                  <text x="160" y="52">CS-ID</text>
                  <text x="196" y="52">1,</text>
                  <text x="240" y="52">contact</text>
                  <text x="308" y="52">instance</text>
                  <text x="376" y="52">CSCI-ID</text>
                  <text x="416" y="52">2</text>
                  <text x="468" y="52">&lt;computing</text>
                  <text x="548" y="52">metrics&gt;</text>
                  <text x="136" y="84">:</text>
                  <text x="328" y="84">:</text>
                  <text x="136" y="100">:</text>
                  <text x="328" y="100">:</text>
                  <text x="136" y="116">:</text>
                  <text x="328" y="116">:</text>
                  <text x="480" y="116">CS-ID</text>
                  <text x="512" y="116">1</text>
                  <text x="136" y="132">:</text>
                  <text x="328" y="132">:</text>
                  <text x="488" y="132">CSCI-ID</text>
                  <text x="528" y="132">1</text>
                  <text x="136" y="148">:</text>
                  <text x="136" y="164">:</text>
                  <text x="312" y="164">C-SMA</text>
                  <text x="488" y="164">Service</text>
                  <text x="540" y="164">Site</text>
                  <text x="568" y="164">2</text>
                  <text x="136" y="180">:</text>
                  <text x="136" y="196">:</text>
                  <text x="316" y="196">CATS-Forwarder</text>
                  <text x="384" y="196">2</text>
                  <text x="480" y="196">CS-ID</text>
                  <text x="512" y="196">1</text>
                  <text x="136" y="212">:</text>
                  <text x="488" y="212">CSCI-ID</text>
                  <text x="528" y="212">2</text>
                  <text x="136" y="228">:</text>
                  <text x="336" y="228">|</text>
                  <text x="44" y="244">Client</text>
                  <text x="136" y="244">:</text>
                  <text x="184" y="244">Network</text>
                  <text x="136" y="260">:</text>
                  <text x="184" y="260">metrics</text>
                  <text x="136" y="276">:</text>
                  <text x="152" y="276">:</text>
                  <text x="272" y="276">C-NMA</text>
                  <text x="136" y="292">:</text>
                  <text x="152" y="292">:</text>
                  <text x="68" y="324">CATS-Forwarder</text>
                  <text x="156" y="324">1|C-PS</text>
                  <text x="316" y="340">Underlay</text>
                  <text x="136" y="356">:</text>
                  <text x="324" y="356">Infrastructure</text>
                  <text x="136" y="372">:</text>
                  <text x="480" y="372">CS-ID</text>
                  <text x="512" y="372">1</text>
                  <text x="136" y="388">:</text>
                  <text x="488" y="388">CSCI-ID</text>
                  <text x="528" y="388">3</text>
                  <text x="136" y="404">:</text>
                  <text x="304" y="404">|</text>
                  <text x="136" y="420">:</text>
                  <text x="136" y="436">:</text>
                  <text x="284" y="436">CATS-Forwarder</text>
                  <text x="352" y="436">3</text>
                  <text x="372" y="436">--</text>
                  <text x="416" y="436">C-SMA</text>
                  <text x="488" y="436">Service</text>
                  <text x="540" y="436">Site</text>
                  <text x="568" y="436">3</text>
                  <text x="136" y="452">:</text>
                  <text x="136" y="468">:</text>
                  <text x="400" y="468">:</text>
                  <text x="136" y="484">:</text>
                  <text x="400" y="484">:</text>
                  <text x="480" y="484">CS-ID</text>
                  <text x="512" y="484">2</text>
                  <text x="136" y="500">:</text>
                  <text x="400" y="500">:</text>
                  <text x="136" y="516">:</text>
                  <text x="400" y="516">:</text>
                  <text x="104" y="532">Service</text>
                  <text x="160" y="532">CS-ID</text>
                  <text x="196" y="532">1,</text>
                  <text x="240" y="532">contact</text>
                  <text x="308" y="532">instance</text>
                  <text x="376" y="532">CSCI-ID</text>
                  <text x="416" y="532">3</text>
                  <text x="468" y="532">&lt;computing</text>
                  <text x="548" y="532">metrics&gt;</text>
                  <text x="104" y="548">Service</text>
                  <text x="160" y="548">CS-ID</text>
                  <text x="196" y="548">2,</text>
                  <text x="252" y="548">&lt;computing</text>
                  <text x="332" y="548">metrics&gt;</text>
                </g>
              </svg>
            </artwork>
            <artwork type="ascii-art"><![CDATA[
          Service CS-ID 1, contact instance CSCI-ID 1 <computing metrics>
          Service CS-ID 1, contact instance CSCI-ID 2 <computing metrics>

                 :<----------------------:
                 :                       :               +---------+
                 :                       :               |CS-ID 1  |
                 :                       :            .--|CSCI-ID 1|
                 :              +----------------+    |  +---------+
                 :              |    C-SMA       |----|   Service Site 2
                 :              +----------------+    |  +---------+
                 :              |CATS-Forwarder 2|    '--|CS-ID 1  |
                 :              +----------------+       |CSCI-ID 2|
 +--------+      :                        |              +---------+
 | Client |      :  Network +----------------------+
 +--------+      :  metrics | +-------+            |
      |          : :<---------| C-NMA |            |
      |          : :        | +-------+            |
 +---------------------+    |                      |
 |CATS-Forwarder 1|C-PS|----|                      |
 +---------------------+    |       Underlay       |
                 :          |     Infrastructure   |     +---------+
                 :          |                      |     |CS-ID 1  |
                 :          +----------------------+ .---|CSCI-ID 3|
                 :                    |              |   +---------+
                 :          +----------------+  +-------+
                 :          |CATS-Forwarder 3|--| C-SMA | Service Site 3
                 :          +----------------+  +-------+
                 :                                :  |   +-------+
                 :                                :  '---|CS-ID 2|
                 :                                :      +-------+
                 :<-------------------------------:
          Service CS-ID 1, contact instance CSCI-ID 3 <computing metrics>
          Service CS-ID 2, <computing metrics>
]]></artwork>
          </artset>
        </figure>
        <t>The example in <xref target="fig-cats-example-overlay"/> mainly describes a per-instance computing-related metric distribution. In the case of distributing aggregated per-site computing-related metrics, the per-instance CSCI-ID information will not be included in the advertisement. Instead, a per-site CSCI-ID may be used in case multiple sites are connected to the Egress CATS-Forwarder to explicitly indicate the site from where the aggregated metrics come.</t>
        <t>If the CATS framework is implemented using a centralized model, the metric can be, e.g., distributed as illustrated in <xref target="fig-cats-centralized"/>.</t>
        <figure anchor="fig-cats-centralized">
          <name>An Example of CATS Metric Distribution in a Centralized Model</name>
          <artset>
            <artwork type="svg"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="608" width="608" viewBox="0 0 608 608" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
                <path d="M 8,288 L 8,320" fill="none" stroke="black"/>
                <path d="M 8,368 L 8,416" fill="none" stroke="black"/>
                <path d="M 48,328 L 48,360" fill="none" stroke="black"/>
                <path d="M 80,288 L 80,320" fill="none" stroke="black"/>
                <path d="M 144,368 L 144,416" fill="none" stroke="black"/>
                <path d="M 160,112 L 160,160" fill="none" stroke="black"/>
                <path d="M 176,496 L 176,528" fill="none" stroke="black"/>
                <path d="M 184,168 L 184,384" fill="none" stroke="black"/>
                <path d="M 208,208 L 208,272" fill="none" stroke="black"/>
                <path d="M 208,304 L 208,328" fill="none" stroke="black"/>
                <path d="M 208,344 L 208,464" fill="none" stroke="black"/>
                <path d="M 216,112 L 216,160" fill="none" stroke="black"/>
                <path d="M 224,320 L 224,352" fill="none" stroke="black"/>
                <path d="M 280,144 L 280,200" fill="none" stroke="black"/>
                <path d="M 288,320 L 288,352" fill="none" stroke="black"/>
                <path d="M 288,536 L 288,560" fill="none" stroke="black"/>
                <path d="M 312,496 L 312,528" fill="none" stroke="black"/>
                <path d="M 344,208 L 344,272" fill="none" stroke="black"/>
                <path d="M 376,176 L 376,256" fill="none" stroke="black"/>
                <path d="M 392,304 L 392,464" fill="none" stroke="black"/>
                <path d="M 408,160 L 408,208" fill="none" stroke="black"/>
                <path d="M 408,240 L 408,288" fill="none" stroke="black"/>
                <path d="M 408,544 L 408,576" fill="none" stroke="black"/>
                <path d="M 416,464 L 416,512" fill="none" stroke="black"/>
                <path d="M 432,432 L 432,480" fill="none" stroke="black"/>
                <path d="M 448,336 L 448,384" fill="none" stroke="black"/>
                <path d="M 472,544 L 472,576" fill="none" stroke="black"/>
                <path d="M 480,392 L 480,424" fill="none" stroke="black"/>
                <path d="M 488,160 L 488,208" fill="none" stroke="black"/>
                <path d="M 488,240 L 488,288" fill="none" stroke="black"/>
                <path d="M 496,336 L 496,384" fill="none" stroke="black"/>
                <path d="M 512,432 L 512,480" fill="none" stroke="black"/>
                <path d="M 520,128 L 520,560" fill="none" stroke="black"/>
                <path d="M 160,112 L 216,112" fill="none" stroke="black"/>
                <path d="M 104,128 L 152,128" fill="none" stroke="black"/>
                <path d="M 224,128 L 520,128" fill="none" stroke="black"/>
                <path d="M 224,144 L 280,144" fill="none" stroke="black"/>
                <path d="M 160,160 L 216,160" fill="none" stroke="black"/>
                <path d="M 408,160 L 488,160" fill="none" stroke="black"/>
                <path d="M 376,176 L 400,176" fill="none" stroke="black"/>
                <path d="M 208,208 L 344,208" fill="none" stroke="black"/>
                <path d="M 408,208 L 488,208" fill="none" stroke="black"/>
                <path d="M 352,224 L 368,224" fill="none" stroke="black"/>
                <path d="M 208,240 L 344,240" fill="none" stroke="black"/>
                <path d="M 408,240 L 488,240" fill="none" stroke="black"/>
                <path d="M 376,256 L 400,256" fill="none" stroke="black"/>
                <path d="M 208,272 L 344,272" fill="none" stroke="black"/>
                <path d="M 8,288 L 80,288" fill="none" stroke="black"/>
                <path d="M 408,288 L 488,288" fill="none" stroke="black"/>
                <path d="M 208,304 L 392,304" fill="none" stroke="black"/>
                <path d="M 8,320 L 80,320" fill="none" stroke="black"/>
                <path d="M 224,320 L 288,320" fill="none" stroke="black"/>
                <path d="M 184,336 L 216,336" fill="none" stroke="black"/>
                <path d="M 448,336 L 496,336" fill="none" stroke="black"/>
                <path d="M 224,352 L 288,352" fill="none" stroke="black"/>
                <path d="M 504,352 L 520,352" fill="none" stroke="black"/>
                <path d="M 8,368 L 144,368" fill="none" stroke="black"/>
                <path d="M 152,384 L 184,384" fill="none" stroke="black"/>
                <path d="M 448,384 L 496,384" fill="none" stroke="black"/>
                <path d="M 152,400 L 200,400" fill="none" stroke="black"/>
                <path d="M 8,416 L 144,416" fill="none" stroke="black"/>
                <path d="M 432,432 L 504,432" fill="none" stroke="black"/>
                <path d="M 208,464 L 392,464" fill="none" stroke="black"/>
                <path d="M 432,480 L 504,480" fill="none" stroke="black"/>
                <path d="M 176,496 L 312,496" fill="none" stroke="black"/>
                <path d="M 320,512 L 416,512" fill="none" stroke="black"/>
                <path d="M 176,528 L 312,528" fill="none" stroke="black"/>
                <path d="M 408,544 L 472,544" fill="none" stroke="black"/>
                <path d="M 288,560 L 400,560" fill="none" stroke="black"/>
                <path d="M 480,560 L 520,560" fill="none" stroke="black"/>
                <path d="M 408,576 L 472,576" fill="none" stroke="black"/>
                <path d="M 504,432 C 512.83064,432 520,439.16936 520,448" fill="none" stroke="black"/>
                <path d="M 504,432 C 512.83064,432 520,424.83064 520,416" fill="none" stroke="black"/>
                <path d="M 504,480 C 512.83064,480 520,487.16936 520,496" fill="none" stroke="black"/>
                <path d="M 504,480 C 512.83064,480 520,472.83064 520,464" fill="none" stroke="black"/>
                <polygon class="arrowhead" points="488,392 476,386.4 476,397.6" fill="black" transform="rotate(270,480,392)"/>
                <polygon class="arrowhead" points="232,144 220,138.4 220,149.6" fill="black" transform="rotate(180,224,144)"/>
                <polygon class="arrowhead" points="232,128 220,122.4 220,133.6" fill="black" transform="rotate(180,224,128)"/>
                <polygon class="arrowhead" points="192,168 180,162.4 180,173.6" fill="black" transform="rotate(270,184,168)"/>
                <polygon class="arrowhead" points="160,400 148,394.4 148,405.6" fill="black" transform="rotate(180,152,400)"/>
                <polygon class="arrowhead" points="160,384 148,378.4 148,389.6" fill="black" transform="rotate(180,152,384)"/>
                <polygon class="arrowhead" points="112,128 100,122.4 100,133.6" fill="black" transform="rotate(180,104,128)"/>
                <g class="text">
                  <text x="192" y="36">Service</text>
                  <text x="248" y="36">CS-ID</text>
                  <text x="284" y="36">1,</text>
                  <text x="332" y="36">instance</text>
                  <text x="400" y="36">CSCI-ID</text>
                  <text x="440" y="36">1</text>
                  <text x="492" y="36">&lt;computing</text>
                  <text x="572" y="36">metrics&gt;</text>
                  <text x="192" y="52">Service</text>
                  <text x="248" y="52">CS-ID</text>
                  <text x="284" y="52">1,</text>
                  <text x="332" y="52">instance</text>
                  <text x="400" y="52">CSCI-ID</text>
                  <text x="440" y="52">2</text>
                  <text x="492" y="52">&lt;computing</text>
                  <text x="572" y="52">metrics&gt;</text>
                  <text x="192" y="68">Service</text>
                  <text x="248" y="68">CS-ID</text>
                  <text x="284" y="68">1,</text>
                  <text x="332" y="68">instance</text>
                  <text x="400" y="68">CSCI-ID</text>
                  <text x="440" y="68">3</text>
                  <text x="492" y="68">&lt;computing</text>
                  <text x="572" y="68">metrics&gt;</text>
                  <text x="192" y="84">Service</text>
                  <text x="248" y="84">CS-ID</text>
                  <text x="284" y="84">2,</text>
                  <text x="340" y="84">&lt;computing</text>
                  <text x="420" y="84">metrics&gt;</text>
                  <text x="96" y="132">:</text>
                  <text x="188" y="132">C-PS</text>
                  <text x="96" y="148">:</text>
                  <text x="96" y="164">:</text>
                  <text x="96" y="180">:</text>
                  <text x="432" y="180">CS-ID</text>
                  <text x="464" y="180">1</text>
                  <text x="96" y="196">:</text>
                  <text x="440" y="196">CSCI-ID</text>
                  <text x="480" y="196">1</text>
                  <text x="96" y="212">:</text>
                  <text x="96" y="228">:</text>
                  <text x="264" y="228">C-SMA</text>
                  <text x="416" y="228">Service</text>
                  <text x="468" y="228">Site</text>
                  <text x="496" y="228">2</text>
                  <text x="96" y="244">:</text>
                  <text x="96" y="260">:</text>
                  <text x="268" y="260">CATS-Forwarder</text>
                  <text x="336" y="260">2</text>
                  <text x="432" y="260">CS-ID</text>
                  <text x="464" y="260">1</text>
                  <text x="96" y="276">:</text>
                  <text x="440" y="276">CSCI-ID</text>
                  <text x="480" y="276">2</text>
                  <text x="96" y="292">:</text>
                  <text x="288" y="292">|</text>
                  <text x="44" y="308">Client</text>
                  <text x="96" y="308">:</text>
                  <text x="144" y="308">Network</text>
                  <text x="96" y="324">:</text>
                  <text x="144" y="324">metrics</text>
                  <text x="96" y="340">:</text>
                  <text x="256" y="340">C-NMA</text>
                  <text x="96" y="356">:</text>
                  <text x="472" y="356">C-SMA</text>
                  <text x="508" y="372">&lt;-</text>
                  <text x="68" y="388">CATS-Forwarder</text>
                  <text x="136" y="388">1</text>
                  <text x="300" y="420">Underlay</text>
                  <text x="308" y="436">Infrastructure</text>
                  <text x="456" y="452">CS-ID</text>
                  <text x="488" y="452">1</text>
                  <text x="424" y="468">-</text>
                  <text x="464" y="468">CSCI-ID</text>
                  <text x="504" y="468">3</text>
                  <text x="288" y="484">|</text>
                  <text x="236" y="516">CATS-Forwarder</text>
                  <text x="304" y="516">3</text>
                  <text x="416" y="532">Service</text>
                  <text x="468" y="532">Site</text>
                  <text x="496" y="532">3</text>
                  <text x="432" y="564">CS-ID</text>
                  <text x="464" y="564">2</text>
                </g>
              </svg>
            </artwork>
            <artwork type="ascii-art"><![CDATA[
                        Service CS-ID 1, instance CSCI-ID 1 <computing metrics>
                        Service CS-ID 1, instance CSCI-ID 2 <computing metrics>
                        Service CS-ID 1, instance CSCI-ID 3 <computing metrics>
                        Service CS-ID 2, <computing metrics>

                       +------+
               :<------| C-PS |<------------------------------------.
               :       |      |<------.                             |
               :       +------+       |               +---------+   |
               :          ^           |           +---|CS-ID 1  |   |
               :          |           |           |   |CSCI-ID 1|   |
               :          |  +----------------+   |   +---------+   |
               :          |  |    C-SMA       |---| Service Site 2  |
               :          |  +----------------+   |   +---------+   |
               :          |  |CATS-Forwarder 2|   +---|CS-ID 1  |   |
               :          |  +----------------+       |CSCI-ID 2|   |
    +--------+ :          |            |              +---------+   |
    | Client | :  Network |  +----------------------+               |
    +--------+ :  metrics |  | +-------+            |               |
         |     :          +----| C-NMA |            |      +-----+  |
         |     :          |  | +-------+            |      |C-SMA|--+
    +----------------+    |  |                      |      |     |<-.
    |CATS-Forwarder 1|<---'  |                      |      +-----+  |
    |                |<------|                      |          ^    |
    +----------------+       |       Underlay       |          |    |
                             |     Infrastructure   |    +---------+|
                             |                      |    |CS-ID 1  ||
                             +----------------------+  +-|CSCI-ID 3||
                                       |               | +---------+|
                         +----------------+            |            |
                         |CATS-Forwarder 3|------------+            |
                         +----------------+         Service Site 3  |
                                       |              +-------+     |
                                       +--------------|CS-ID 2|-----+
                                                      +-------+
]]></artwork>
          </artset>
        </figure>
        <t>In <xref target="fig-cats-centralized"/>, the C-SMA collocated with "CATS-Forwarder 2" distributes the computing metrics for both service contact instances (i.e., (CS-ID 1, CSCI-ID 1) and (CS-ID 1, CSCI-ID 2)) to the centralized C-PS. In this case, the C-PS is a logically centralized element deployed independently with the CATS-Forwarder 1. Similarly, the C-SMA agent located at "Service Site 3" advertises the computing metrics for the two services hosted by "Service Site 3" to the centralized C-PS as well. Furthermore, the C-PS receives the network metrics sent from the C-NMA.  All metrics are used by the C-PS to select the most relevant path that leads to the Egress CATS-Forwarder. The selected paths will be sent from the C-PS to CATS-Forwarder 1 to indicate traffic steering.</t>
        <t>If the CATS framework is implemented using an hybrid model, the metric can be distributed, e.g., as illustrated in the <xref target="fig-cats-hybrid"/>. For example, the metrics 1,2,3 associated with the CS-ID1 are collected by the centralized C-PS, and the metrics 4 and 5 are distributed via distributed protocols to the ingress CATS-Forwarder directly. For a service with CS-ID2, all the metrics are collected by the centralized C-PS. The CATS-computed path result will be distributed to the Ingress CATS-Forwarders from the C-PS by considering both the metrics from the C-SMA and C-NMA. Furthermore, the Ingress CATS-Forwarder may also have some ability to compute the path for the subsequent service accessing packets.</t>
        <figure anchor="fig-cats-hybrid">
          <name>An Example of CATS Metric Distribution in Hybrid Model</name>
          <artset>
            <artwork type="svg"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="624" width="592" viewBox="0 0 592 624" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
                <path d="M 8,272 L 8,304" fill="none" stroke="black"/>
                <path d="M 8,368 L 8,448" fill="none" stroke="black"/>
                <path d="M 48,312 L 48,360" fill="none" stroke="black"/>
                <path d="M 48,424 L 48,448" fill="none" stroke="black"/>
                <path d="M 80,272 L 80,304" fill="none" stroke="black"/>
                <path d="M 144,368 L 144,416" fill="none" stroke="black"/>
                <path d="M 168,96 L 168,144" fill="none" stroke="black"/>
                <path d="M 192,152 L 192,384" fill="none" stroke="black"/>
                <path d="M 192,480 L 192,512" fill="none" stroke="black"/>
                <path d="M 224,96 L 224,144" fill="none" stroke="black"/>
                <path d="M 224,192 L 224,256" fill="none" stroke="black"/>
                <path d="M 224,288 L 224,312" fill="none" stroke="black"/>
                <path d="M 224,328 L 224,448" fill="none" stroke="black"/>
                <path d="M 240,304 L 240,336" fill="none" stroke="black"/>
                <path d="M 296,128 L 296,184" fill="none" stroke="black"/>
                <path d="M 304,304 L 304,336" fill="none" stroke="black"/>
                <path d="M 304,520 L 304,544" fill="none" stroke="black"/>
                <path d="M 328,480 L 328,512" fill="none" stroke="black"/>
                <path d="M 360,192 L 360,256" fill="none" stroke="black"/>
                <path d="M 392,160 L 392,240" fill="none" stroke="black"/>
                <path d="M 408,288 L 408,448" fill="none" stroke="black"/>
                <path d="M 424,144 L 424,192" fill="none" stroke="black"/>
                <path d="M 424,224 L 424,272" fill="none" stroke="black"/>
                <path d="M 424,528 L 424,560" fill="none" stroke="black"/>
                <path d="M 432,448 L 432,496" fill="none" stroke="black"/>
                <path d="M 448,416 L 448,464" fill="none" stroke="black"/>
                <path d="M 464,320 L 464,368" fill="none" stroke="black"/>
                <path d="M 488,528 L 488,560" fill="none" stroke="black"/>
                <path d="M 496,376 L 496,408" fill="none" stroke="black"/>
                <path d="M 504,144 L 504,192" fill="none" stroke="black"/>
                <path d="M 504,224 L 504,272" fill="none" stroke="black"/>
                <path d="M 512,320 L 512,368" fill="none" stroke="black"/>
                <path d="M 528,416 L 528,464" fill="none" stroke="black"/>
                <path d="M 536,112 L 536,544" fill="none" stroke="black"/>
                <path d="M 168,96 L 224,96" fill="none" stroke="black"/>
                <path d="M 112,112 L 160,112" fill="none" stroke="black"/>
                <path d="M 232,112 L 536,112" fill="none" stroke="black"/>
                <path d="M 232,128 L 296,128" fill="none" stroke="black"/>
                <path d="M 168,144 L 224,144" fill="none" stroke="black"/>
                <path d="M 424,144 L 504,144" fill="none" stroke="black"/>
                <path d="M 392,160 L 416,160" fill="none" stroke="black"/>
                <path d="M 224,192 L 360,192" fill="none" stroke="black"/>
                <path d="M 424,192 L 504,192" fill="none" stroke="black"/>
                <path d="M 368,208 L 384,208" fill="none" stroke="black"/>
                <path d="M 224,224 L 360,224" fill="none" stroke="black"/>
                <path d="M 424,224 L 504,224" fill="none" stroke="black"/>
                <path d="M 392,240 L 416,240" fill="none" stroke="black"/>
                <path d="M 224,256 L 360,256" fill="none" stroke="black"/>
                <path d="M 8,272 L 80,272" fill="none" stroke="black"/>
                <path d="M 424,272 L 504,272" fill="none" stroke="black"/>
                <path d="M 224,288 L 408,288" fill="none" stroke="black"/>
                <path d="M 8,304 L 80,304" fill="none" stroke="black"/>
                <path d="M 240,304 L 304,304" fill="none" stroke="black"/>
                <path d="M 192,320 L 232,320" fill="none" stroke="black"/>
                <path d="M 464,320 L 512,320" fill="none" stroke="black"/>
                <path d="M 240,336 L 304,336" fill="none" stroke="black"/>
                <path d="M 520,336 L 536,336" fill="none" stroke="black"/>
                <path d="M 8,368 L 144,368" fill="none" stroke="black"/>
                <path d="M 464,368 L 512,368" fill="none" stroke="black"/>
                <path d="M 152,384 L 192,384" fill="none" stroke="black"/>
                <path d="M 152,400 L 216,400" fill="none" stroke="black"/>
                <path d="M 16,416 L 144,416" fill="none" stroke="black"/>
                <path d="M 448,416 L 520,416" fill="none" stroke="black"/>
                <path d="M 8,448 L 48,448" fill="none" stroke="black"/>
                <path d="M 224,448 L 408,448" fill="none" stroke="black"/>
                <path d="M 448,464 L 520,464" fill="none" stroke="black"/>
                <path d="M 192,480 L 328,480" fill="none" stroke="black"/>
                <path d="M 336,496 L 432,496" fill="none" stroke="black"/>
                <path d="M 192,512 L 328,512" fill="none" stroke="black"/>
                <path d="M 424,528 L 488,528" fill="none" stroke="black"/>
                <path d="M 304,544 L 416,544" fill="none" stroke="black"/>
                <path d="M 496,544 L 536,544" fill="none" stroke="black"/>
                <path d="M 424,560 L 488,560" fill="none" stroke="black"/>
                <path d="M 112,576 L 360,576" fill="none" stroke="black"/>
                <path d="M 520,416 C 528.83064,416 536,423.16936 536,432" fill="none" stroke="black"/>
                <path d="M 520,416 C 528.83064,416 536,408.83064 536,400" fill="none" stroke="black"/>
                <path d="M 520,464 C 528.83064,464 536,471.16936 536,480" fill="none" stroke="black"/>
                <path d="M 520,464 C 528.83064,464 536,456.83064 536,448" fill="none" stroke="black"/>
                <polygon class="arrowhead" points="504,376 492,370.4 492,381.6" fill="black" transform="rotate(270,496,376)"/>
                <polygon class="arrowhead" points="240,128 228,122.4 228,133.6" fill="black" transform="rotate(180,232,128)"/>
                <polygon class="arrowhead" points="240,112 228,106.4 228,117.6" fill="black" transform="rotate(180,232,112)"/>
                <polygon class="arrowhead" points="200,152 188,146.4 188,157.6" fill="black" transform="rotate(270,192,152)"/>
                <polygon class="arrowhead" points="160,384 148,378.4 148,389.6" fill="black" transform="rotate(180,152,384)"/>
                <polygon class="arrowhead" points="120,576 108,570.4 108,581.6" fill="black" transform="rotate(180,112,576)"/>
                <polygon class="arrowhead" points="120,112 108,106.4 108,117.6" fill="black" transform="rotate(180,112,112)"/>
                <g class="text">
                  <text x="136" y="36">Service</text>
                  <text x="192" y="36">CS-ID</text>
                  <text x="228" y="36">1,</text>
                  <text x="276" y="36">instance</text>
                  <text x="344" y="36">CSCI-ID</text>
                  <text x="384" y="36">1</text>
                  <text x="436" y="36">&lt;computing</text>
                  <text x="508" y="36">metric</text>
                  <text x="564" y="36">1,2,3&gt;</text>
                  <text x="136" y="52">Service</text>
                  <text x="192" y="52">CS-ID</text>
                  <text x="228" y="52">1,</text>
                  <text x="276" y="52">instance</text>
                  <text x="344" y="52">CSCI-ID</text>
                  <text x="384" y="52">2</text>
                  <text x="436" y="52">&lt;computing</text>
                  <text x="508" y="52">metric</text>
                  <text x="564" y="52">1,2,3&gt;</text>
                  <text x="136" y="68">Service</text>
                  <text x="192" y="68">CS-ID</text>
                  <text x="228" y="68">1,</text>
                  <text x="276" y="68">instance</text>
                  <text x="344" y="68">CSCI-ID</text>
                  <text x="384" y="68">3</text>
                  <text x="436" y="68">&lt;computing</text>
                  <text x="508" y="68">metric</text>
                  <text x="564" y="68">1,2,3&gt;</text>
                  <text x="136" y="84">Service</text>
                  <text x="192" y="84">CS-ID</text>
                  <text x="228" y="84">2,</text>
                  <text x="284" y="84">&lt;computing</text>
                  <text x="364" y="84">metrics&gt;</text>
                  <text x="104" y="116">:</text>
                  <text x="196" y="116">C-PS</text>
                  <text x="104" y="132">:</text>
                  <text x="104" y="148">:</text>
                  <text x="104" y="164">:</text>
                  <text x="448" y="164">CS-ID</text>
                  <text x="480" y="164">1</text>
                  <text x="104" y="180">:</text>
                  <text x="456" y="180">CSCI-ID</text>
                  <text x="496" y="180">1</text>
                  <text x="104" y="196">:</text>
                  <text x="104" y="212">:</text>
                  <text x="280" y="212">C-SMA</text>
                  <text x="432" y="212">Service</text>
                  <text x="484" y="212">Site</text>
                  <text x="512" y="212">2</text>
                  <text x="104" y="228">:</text>
                  <text x="104" y="244">:</text>
                  <text x="284" y="244">CATS-Forwarder</text>
                  <text x="352" y="244">2</text>
                  <text x="448" y="244">CS-ID</text>
                  <text x="480" y="244">1</text>
                  <text x="104" y="260">:</text>
                  <text x="456" y="260">CSCI-ID</text>
                  <text x="496" y="260">2</text>
                  <text x="104" y="276">:</text>
                  <text x="304" y="276">|</text>
                  <text x="44" y="292">Client</text>
                  <text x="104" y="292">:</text>
                  <text x="152" y="292">Network</text>
                  <text x="104" y="308">:</text>
                  <text x="152" y="308">metrics</text>
                  <text x="104" y="324">:</text>
                  <text x="272" y="324">C-NMA</text>
                  <text x="104" y="340">:</text>
                  <text x="488" y="340">C-SMA</text>
                  <text x="104" y="356">:</text>
                  <text x="524" y="356">&lt;-</text>
                  <text x="68" y="388">CATS-Forwarder</text>
                  <text x="136" y="388">1</text>
                  <text x="316" y="404">Underlay</text>
                  <text x="324" y="420">Infrastructure</text>
                  <text x="28" y="436">C-PS</text>
                  <text x="104" y="436">:</text>
                  <text x="472" y="436">CS-ID</text>
                  <text x="504" y="436">1</text>
                  <text x="104" y="452">:</text>
                  <text x="440" y="452">-</text>
                  <text x="480" y="452">CSCI-ID</text>
                  <text x="520" y="452">3</text>
                  <text x="104" y="468">:</text>
                  <text x="304" y="468">|</text>
                  <text x="104" y="484">:</text>
                  <text x="104" y="500">:</text>
                  <text x="252" y="500">CATS-Forwarder</text>
                  <text x="320" y="500">3</text>
                  <text x="104" y="516">:</text>
                  <text x="432" y="516">Service</text>
                  <text x="484" y="516">Site</text>
                  <text x="512" y="516">3</text>
                  <text x="104" y="532">:</text>
                  <text x="104" y="548">:</text>
                  <text x="448" y="548">CS-ID</text>
                  <text x="480" y="548">2</text>
                  <text x="104" y="564">:</text>
                  <text x="368" y="564">:</text>
                  <text x="104" y="580">:</text>
                  <text x="368" y="580">:</text>
                  <text x="72" y="596">Service</text>
                  <text x="128" y="596">CS-ID</text>
                  <text x="164" y="596">1,</text>
                  <text x="208" y="596">contact</text>
                  <text x="276" y="596">instance</text>
                  <text x="344" y="596">CSCI-ID</text>
                  <text x="388" y="596">3,</text>
                  <text x="444" y="596">&lt;computing</text>
                  <text x="516" y="596">metric</text>
                  <text x="564" y="596">4,5&gt;</text>
                </g>
              </svg>
            </artwork>
            <artwork type="ascii-art"><![CDATA[
              Service CS-ID 1, instance CSCI-ID 1 <computing metric 1,2,3>
              Service CS-ID 1, instance CSCI-ID 2 <computing metric 1,2,3>
              Service CS-ID 1, instance CSCI-ID 3 <computing metric 1,2,3>
              Service CS-ID 2, <computing metrics>
                     +------+
             :<------| C-PS |<-------------------------------------.
             :       |      |<-------.                             |
             :       +------+        |               +---------+   |
             :          ^            |           +---|CS-ID 1  |   |
             :          |            |           |   |CSCI-ID 1|   |
             :          |   +----------------+   |   +---------+   |
             :          |   |    C-SMA       |---| Service Site 2  |
             :          |   +----------------+   |   +---------+   |
             :          |   |CATS-Forwarder 2|   +---|CS-ID 1  |   |
             :          |   +----------------+       |CSCI-ID 2|   |
 +--------+  :          |             |              +---------+   |
 | Client |  :  Network |   +----------------------+               |
 +--------+  :  metrics |   | +-------+            |               |
      |      :          +-----| C-NMA |            |      +-----+  |
      |      :          |   | +-------+            |      |C-SMA|--+
      |      :          |   |                      |      |     |<-.
 +----------------+     |   |                      |      +-----+  |
 |CATS-Forwarder 1|<----'   |                      |          ^    |
 |                |---------|       Underlay       |          |    |
 |----------------+         |     Infrastructure   |    +---------+|
 |C-PS|      :              |                      |    |CS-ID 1  ||
 +----+      :              +----------------------+  +-|CSCI-ID 3||
             :                        |               | +---------+|
             :          +----------------+            |            |
             :          |CATS-Forwarder 3|------------+            |
             :          +----------------+         Service Site 3  |
             :                        |              +-------+     |
             :                        '-------+------|CS-ID 2|-----'
             :                                :      +-------+
             :<-------------------------------:
      Service CS-ID 1, contact instance CSCI-ID 3, <computing metric 4,5>
]]></artwork>
          </artset>
        </figure>
      </section>
      <section anchor="service-access-processing">
        <name>Service Access Processing</name>
        <t>A C-PS selects paths that lead to Egress CATS-Forwarders according to both service and network metrics that were advertised. A C-PS may be collocated with an Ingress CATS-Forwarder (as shown in <xref target="fig-cats-example-overlay"/>) or logically centralized (in a centralized model or hybrid model).</t>
        <t>This document does not specify any specific algorithm for path selection purposes to be supported by C-PSes in order to not constrain the CATS framework to one possible selection only. Instead, it is expected that a service request or local policy may feed the C-PS with appropriate information on that selection logic that takes the suitable metric information as input and the selected service contact instance as output. Such "appropriate information" may be utilized to differentiate selection mechanisms to enable service-specific selections.</t>
        <t>In the example shown in <xref target="fig-cats-example-overlay"/>, the client sends a service access via the network through the "CATS-Forwarder 1", which is an Ingress CATS-Forwarder. Note that, a service access may consist of one or more service packets (e.g., Session Initiation Protocol (SIP) <xref target="RFC3261"/>, HTTP <xref target="RFC9112"/>, IPv6 <xref target="RFC8200"/>, SRv6 <xref target="RFC8754"/> or Real-Time Streaming Protocol (RTSP) <xref target="RFC7826"/>) that carry the CS-ID and potential parameters. The Ingress CATS-Forwarder classifies the packets using the information provided by the CATS classifier (C-TC). When a matching classification entry is found for the packets, the Ingress CATS-Forwarder encapsulates and forwards them to the C-PS selected Egress CATS-Forwarder. When these packets reach the Egress CATS-Forwarder, the outer header of the possible overlay encapsulation will be removed and the inner packets will be sent to the relevant service contact instance.</t>
        <ul empty="true">
          <li>
            <t>Note that multi-homed clients may be connected to multiple CATS infrastructures that may be operated by the same or distinct service providers. This version of the framework does not cover multihoming specifics.</t>
          </li>
        </ul>
      </section>
      <section anchor="service-contact-instance-affinity">
        <name>Service Contact Instance Affinity</name>
        <t>Service contact instance affinity means that packets that belong to a flow associated with a service should always be sent to the same service contact instance. Furthermore, packets of a given flow should be forwarded along the same path to avoid mis-ordering and to prevent the introduction of unpredictable latency variations. The CATS framework must ensure that service instance selection and path steering decisions remain consistent for a flow. Specifically, the same Egress CATS-Forwarder need to be solicited to forward the packets.</t>
        <t>The affinity is configured on the C-PS when the service is deployed, or is determined at the time of newly formulated service requests.</t>
        <t>Note that different services may have different notions of what constitutes a 'flow' and may, thus, identify a flow differently. Typically, a flow is identified by the 5-tuple transport coordinates (source address and destination address, source and destination port numbers, and protocol). However, for instance, an RTP video stream may use different port numbers for video and audio channels: in that case, affinity may be identified as a combination of the two 5-tuple flow identifiers so that both flows are addressed to the same service contact instance.</t>
        <t>Hence, when specifying a protocol to communicate information about service contact instance affinity, the protocol should support
flexible mechanisms for identifying flows. Or, from a more general perspective, there should be a mechanism to specify and identify the set of packets that are subject to a service contact instance affinity.</t>
        <t>More importantly, the means for identifying a flow for ensuring instance affinity should be application-independent to avoid the need for service-specific instance affinity methods. However, service contact instance affinity information may be configurable on a per-service basis. For each service, the information can include the flow/packets identification type and means, affinity timeout value, etc.</t>
        <t>This document does not define any mechanism for defining or enforcing service contact instance affinity.</t>
      </section>
    </section>
    <section anchor="operational-and-mangeability-considerations">
      <name>Operational and Mangeability Considerations</name>
      <section anchor="provisioning-of-cats-components">
        <name>Provisioning of CATS Components</name>
        <t>Enabling CATS in a network can be done incrementally. That is, not all ingress routers need to be upgraded to support CATS.</t>
        <t>In addition the CATS steering policies that are communicated by a C-PS to an Ingress CATS-Forwarder, some provisioning tasks are required. This includes, but not limited to:</t>
        <ul spacing="normal">
          <li>
            <t>Provide C-PS elements with the locators of available Ingress CATS-Forwarder. Such locators may also be discovered from the network.</t>
          </li>
          <li>
            <t>Enable required setup to connect C-PS elements with C-NMA and C-SMA.</t>
          </li>
          <li>
            <t>Allocate various identifiers CS-ID/CSCI-ID and bind them to specific service contact instances.</t>
          </li>
          <li>
            <t>Provide C-PS element with the set of optimization metrics (per service) and an optimization policy.</t>
          </li>
          <li>
            <t>Expose Encapsulation capabilities supported by CATS-Frowarders.</t>
          </li>
          <li>
            <t>Configure specific encapsulation capabilities of CATS-Forwarders for use, including any credentials for mutual authentication between peer CATS-Forwarders.</t>
          </li>
          <li>
            <t>Expose classification capabilities of C-TC elements.</t>
          </li>
          <li>
            <t>Retrieve active classification table of C-TC elements.</t>
          </li>
          <li>
            <t>Reset the classification table of C-TC elements.</t>
          </li>
          <li>
            <t>Set the traffic counter at CATS-Forwarders to ease correlation between both Ingress and Egress CATS-Forwarders. Such correlation is needed to help identify issues induced by the underlying encapsulation.</t>
          </li>
          <li>
            <t>Enable tools to check the correct behavior of various entities (e.g., classification rules, steering rules, and forwarding behavior)</t>
          </li>
        </ul>
        <t>The above task can be enabled using a variety of means (NETCONF <xref target="RFC6241"/>, IPFIX <xref target="RFC7011"/>, etc.). It is out of scope to discuss required CATS extension to these protocols.</t>
      </section>
      <section anchor="deployment-considerations">
        <name>Deployment Considerations</name>
        <t>This document does not make any assumption about how the various CATS functional elements are implemented and deployed. Concretely, whether a CATS deployment follows a fully distributed design or relies upon a mix of centralized (e.g., a C-PS) and distributed CATS functions (e.g., CATS traffic classifiers) is deployment-specific and may reflect the preferences and policies of the (CATS) service provider.</t>
        <t>For example, in a centralized design, both the computing related metrics from the C-SMAs and the network metrics are collected by a (logically) centralized path computation logic (e.g., a PCE). In this case, the CATS computation logic may process incoming service requests to compute paths to service contact instances. More generally, the paths might be computed before the service request comes. Based on the metrics and computed paths, the C-PS can select the most appropriate path and then synchronize with CATS traffic classifiers (C-TCs).</t>
        <t>According to the method of distributing and collecting the computing related metrics, three deployment models can be considered for the deployment of the CATS framework:</t>
        <ul spacing="normal">
          <li>
            <dl>
              <dt><strong>Distributed model</strong>:</dt>
              <dd>
                <t>Computing metrics are distributed among network devices directly using distributed protocols without interactions with a centralized control plane. Service scheduling function is performed by the CATS-Forwarders in the distribution model, Therefore, the C-PS is integrated into an Ingress CATS-Forwarder.</t>
              </dd>
            </dl>
          </li>
          <li>
            <dl>
              <dt><strong>Centralized model</strong>:</dt>
              <dd>
                <t>Computing metrics are collected by a centralized control plane, and then the centralized control plane computes the forwarding path for service requests and syncs up with the Ingress CATS-Forwarder. In this model, C-PS is implemented in the centralized control plane.</t>
              </dd>
            </dl>
          </li>
          <li>
            <dl>
              <dt><strong>Hybrid model</strong>:</dt>
              <dd>
                <t>Is a combination of distribution and centralized models.</t>
              </dd>
              <dt/>
              <dd>
                <t>A part of computing metrics are distributed among involved network devices, and others may be collected by a centralized control plane. For example, some static information (e.g., capabilities information) can be distributed among network devices since they are quite stable (change infrequently). Frequent changing information (e.g., resource utilization) can be collected by a centralized control plane to avoid frequent flooding in the distributed control plane. Service scheduling function can be performed by a centralized control plane and/or the CATS-Forwarder. The entire or partial C-PS function may be implemented in the centralized control plane, depending on the specific implementation and deployment.</t>
              </dd>
            </dl>
          </li>
        </ul>
      </section>
    </section>
    <section anchor="security-considerations">
      <name>Security Considerations</name>
      <t>The computing resource information changes over time very frequently, especially with the creation and termination of service instances. When such information is carried in a routing protocol, too many updates may affect network stability. This issue could be exploited by an attacker (e.g., by spawning and deleting service contact instances very rapidly). CATS solutions must support guards against such misbehaviors. For example, these solutions should support aggregation techniques, dampening mechanisms, and threshold-triggered distribution updates.</t>
      <t>The information distributed by the C-SMAs and C-NMAs may be sensitive. Such information could indeed disclose intelligence about the network and the location of compute resources hosted in service sites. This information may be used by an attacker to identify weak spots in an operator's network. Furthermore, such information may be modified by an attacker resulting in disrupted service delivery for the clients, even including misdirection of traffic to an attacker's service implementation. CATS solutions must support authentication and integrity-protection mechanisms between C-SMAs/C-NMAs and C-PSes, and between C-PSes and Ingress CATS-Forwarders. Also, C-SMA agents need to support a mechanism to authenticate the services for which they provide information to C-PS computation logics, among other CATS functions.</t>
    </section>
    <section anchor="privacy-considerations">
      <name>Privacy Considerations</name>
      <t>CATS solutions must support preventing on-path nodes in the underlay infrastructure to fingerprint and track clients (e.g., determine which client accesses which service). More generally, personal data must not be exposed to external parties by CATS beyond what is carried in the packet that was originally issued by the client.</t>
      <t>In some cases, the service will need to know about applications, clients, and even user identity. This information is sensitive and should be encrypted. To prevent the information leaking between CATS components, the C-PS computed path information should be encrypted in distribution. The specific encryption method may be applied at the network layer, transport layer, or at the application/protocol level depending on the implementation, so this is out of the scope of this document.</t>
      <t>For more discussion about privacy, refer to <xref target="RFC6462"/> and <xref target="RFC6973"/>.</t>
    </section>
    <section anchor="iana-considerations">
      <name>IANA Considerations</name>
      <t>This document makes no requests for IANA action.</t>
    </section>
  </middle>
  <back>
    <references anchor="sec-informative-references">
      <name>Informative References</name>
      <reference anchor="I-D.ietf-cats-usecases-requirements">
        <front>
          <title>Computing-Aware Traffic Steering (CATS) Problem Statement, Use Cases, and Requirements</title>
          <author fullname="Kehan Yao" initials="K." surname="Yao">
            <organization>China Mobile</organization>
          </author>
          <author fullname="Luis M. Contreras" initials="L. M." surname="Contreras">
            <organization>Telefonica</organization>
          </author>
          <author fullname="Hang Shi" initials="H." surname="Shi">
            <organization>Huawei Technologies</organization>
          </author>
          <author fullname="Shuai Zhang" initials="S." surname="Zhang">
            <organization>China Unicom</organization>
          </author>
          <author fullname="Qing An" initials="Q." surname="An">
            <organization>Alibaba Group</organization>
          </author>
          <date day="10" month="June" year="2025"/>
          <abstract>
            <t>   Distributed computing is a computing pattern that service providers
   can follow and use to achieve better service response time and
   optimized energy consumption.  In such a distributed computing
   environment, compute intensive and delay sensitive services can be
   improved by utilizing computing resources hosted in various computing
   facilities.  Ideally, compute services are balanced across servers
   and network resources to enable higher throughput and lower response
   time.  To achieve this, the choice of server and network resources
   should consider metrics that are oriented towards compute
   capabilities and resources instead of simply dispatching the service
   requests in a static way or optimizing solely on connectivity
   metrics.  The process of selecting servers or service instance
   locations, and of directing traffic to them on chosen network
   resources is called "Computing-Aware Traffic Steering" (CATS).

   This document provides the problem statement and the typical
   scenarios for CATS, which shows the necessity of considering more
   factors when steering traffic to the appropriate computing resource
   to better meet the customer's expectations.

            </t>
          </abstract>
        </front>
        <seriesInfo name="Internet-Draft" value="draft-ietf-cats-usecases-requirements-07"/>
      </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="RFC7471">
        <front>
          <title>OSPF Traffic Engineering (TE) Metric Extensions</title>
          <author fullname="S. Giacalone" initials="S." surname="Giacalone"/>
          <author fullname="D. Ward" initials="D." surname="Ward"/>
          <author fullname="J. Drake" initials="J." surname="Drake"/>
          <author fullname="A. Atlas" initials="A." surname="Atlas"/>
          <author fullname="S. Previdi" initials="S." surname="Previdi"/>
          <date month="March" year="2015"/>
          <abstract>
            <t>In certain networks, such as, but not limited to, financial information networks (e.g., stock market data providers), network performance information (e.g., link propagation delay) is becoming critical to data path selection.</t>
            <t>This document describes common extensions to RFC 3630 "Traffic Engineering (TE) Extensions to OSPF Version 2" and RFC 5329 "Traffic Engineering Extensions to OSPF Version 3" to enable network performance information to be distributed in a scalable fashion. The information distributed using OSPF TE Metric Extensions can then be used to make path selection decisions based on network performance.</t>
            <t>Note that this document only covers the mechanisms by which network performance information is distributed. The mechanisms for measuring network performance information or using that information, once distributed, are outside the scope of this document.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="7471"/>
        <seriesInfo name="DOI" value="10.17487/RFC7471"/>
      </reference>
      <reference anchor="RFC8570">
        <front>
          <title>IS-IS Traffic Engineering (TE) Metric Extensions</title>
          <author fullname="L. Ginsberg" initials="L." role="editor" surname="Ginsberg"/>
          <author fullname="S. Previdi" initials="S." role="editor" surname="Previdi"/>
          <author fullname="S. Giacalone" initials="S." surname="Giacalone"/>
          <author fullname="D. Ward" initials="D." surname="Ward"/>
          <author fullname="J. Drake" initials="J." surname="Drake"/>
          <author fullname="Q. Wu" initials="Q." surname="Wu"/>
          <date month="March" year="2019"/>
          <abstract>
            <t>In certain networks, such as, but not limited to, financial information networks (e.g., stock market data providers), network-performance criteria (e.g., latency) are becoming as critical to data-path selection as other metrics.</t>
            <t>This document describes extensions to IS-IS Traffic Engineering Extensions (RFC 5305). These extensions provide a way to distribute and collect network-performance information in a scalable fashion. The information distributed using IS-IS TE Metric Extensions can then be used to make path-selection decisions based on network performance.</t>
            <t>Note that this document only covers the mechanisms with which network-performance information is distributed. The mechanisms for measuring network performance or acting on that information, once distributed, are outside the scope of this document.</t>
            <t>This document obsoletes RFC 7810.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="8570"/>
        <seriesInfo name="DOI" value="10.17487/RFC8570"/>
      </reference>
      <reference anchor="RFC8571">
        <front>
          <title>BGP - Link State (BGP-LS) Advertisement of IGP Traffic Engineering Performance Metric Extensions</title>
          <author fullname="L. Ginsberg" initials="L." role="editor" surname="Ginsberg"/>
          <author fullname="S. Previdi" initials="S." surname="Previdi"/>
          <author fullname="Q. Wu" initials="Q." surname="Wu"/>
          <author fullname="J. Tantsura" initials="J." surname="Tantsura"/>
          <author fullname="C. Filsfils" initials="C." surname="Filsfils"/>
          <date month="March" year="2019"/>
          <abstract>
            <t>This document defines new BGP - Link State (BGP-LS) TLVs in order to carry the IGP Traffic Engineering Metric Extensions defined in the IS-IS and OSPF protocols.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="8571"/>
        <seriesInfo name="DOI" value="10.17487/RFC8571"/>
      </reference>
      <reference anchor="RFC4655">
        <front>
          <title>A Path Computation Element (PCE)-Based Architecture</title>
          <author fullname="A. Farrel" initials="A." surname="Farrel"/>
          <author fullname="J.-P. Vasseur" initials="J.-P." surname="Vasseur"/>
          <author fullname="J. Ash" initials="J." surname="Ash"/>
          <date month="August" year="2006"/>
          <abstract>
            <t>Constraint-based path computation is a fundamental building block for traffic engineering systems such as Multiprotocol Label Switching (MPLS) and Generalized Multiprotocol Label Switching (GMPLS) networks. Path computation in large, multi-domain, multi-region, or multi-layer networks is complex and may require special computational components and cooperation between the different network domains.</t>
            <t>This document specifies the architecture for a Path Computation Element (PCE)-based model to address this problem space. This document does not attempt to provide a detailed description of all the architectural components, but rather it describes a set of building blocks for the PCE architecture from which solutions may be constructed. This memo provides information for the Internet community.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="4655"/>
        <seriesInfo name="DOI" value="10.17487/RFC4655"/>
      </reference>
      <reference anchor="RFC4026">
        <front>
          <title>Provider Provisioned Virtual Private Network (VPN) Terminology</title>
          <author fullname="L. Andersson" initials="L." surname="Andersson"/>
          <author fullname="T. Madsen" initials="T." surname="Madsen"/>
          <date month="March" year="2005"/>
          <abstract>
            <t>The widespread interest in provider-provisioned Virtual Private Network (VPN) solutions lead to memos proposing different and overlapping solutions. The IETF working groups (first Provider Provisioned VPNs and later Layer 2 VPNs and Layer 3 VPNs) have discussed these proposals and documented specifications. This has lead to the development of a partially new set of concepts used to describe the set of VPN services.</t>
            <t>To a certain extent, more than one term covers the same concept, and sometimes the same term covers more than one concept. This document seeks to make the terminology in the area clearer and more intuitive. This memo provides information for the Internet community.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="4026"/>
        <seriesInfo name="DOI" value="10.17487/RFC4026"/>
      </reference>
      <reference anchor="RFC1034">
        <front>
          <title>Domain names - concepts and facilities</title>
          <author fullname="P. Mockapetris" initials="P." surname="Mockapetris"/>
          <date month="November" year="1987"/>
          <abstract>
            <t>This RFC is the revised basic definition of The Domain Name System. It obsoletes RFC-882. This memo describes the domain style names and their used for host address look up and electronic mail forwarding. It discusses the clients and servers in the domain name system and the protocol used between them.</t>
          </abstract>
        </front>
        <seriesInfo name="STD" value="13"/>
        <seriesInfo name="RFC" value="1034"/>
        <seriesInfo name="DOI" value="10.17487/RFC1034"/>
      </reference>
      <reference anchor="RFC5340">
        <front>
          <title>OSPF for IPv6</title>
          <author fullname="R. Coltun" initials="R." surname="Coltun"/>
          <author fullname="D. Ferguson" initials="D." surname="Ferguson"/>
          <author fullname="J. Moy" initials="J." surname="Moy"/>
          <author fullname="A. Lindem" initials="A." surname="Lindem"/>
          <date month="July" year="2008"/>
          <abstract>
            <t>This document describes the modifications to OSPF to support version 6 of the Internet Protocol (IPv6). The fundamental mechanisms of OSPF (flooding, Designated Router (DR) election, area support, Short Path First (SPF) calculations, etc.) remain unchanged. However, some changes have been necessary, either due to changes in protocol semantics between IPv4 and IPv6, or simply to handle the increased address size of IPv6. These modifications will necessitate incrementing the protocol version from version 2 to version 3. OSPF for IPv6 is also referred to as OSPF version 3 (OSPFv3).</t>
            <t>Changes between OSPF for IPv4, OSPF Version 2, and OSPF for IPv6 as described herein include the following. Addressing semantics have been removed from OSPF packets and the basic Link State Advertisements (LSAs). New LSAs have been created to carry IPv6 addresses and prefixes. OSPF now runs on a per-link basis rather than on a per-IP-subnet basis. Flooding scope for LSAs has been generalized. Authentication has been removed from the OSPF protocol and instead relies on IPv6's Authentication Header and Encapsulating Security Payload (ESP).</t>
            <t>Even with larger IPv6 addresses, most packets in OSPF for IPv6 are almost as compact as those in OSPF for IPv4. Most fields and packet- size limitations present in OSPF for IPv4 have been relaxed. In addition, option handling has been made more flexible.</t>
            <t>All of OSPF for IPv4's optional capabilities, including demand circuit support and Not-So-Stubby Areas (NSSAs), are also supported in OSPF for IPv6. [STANDARDS-TRACK]</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="5340"/>
        <seriesInfo name="DOI" value="10.17487/RFC5340"/>
      </reference>
      <reference anchor="RFC3261">
        <front>
          <title>SIP: Session Initiation Protocol</title>
          <author fullname="J. Rosenberg" initials="J." surname="Rosenberg"/>
          <author fullname="H. Schulzrinne" initials="H." surname="Schulzrinne"/>
          <author fullname="G. Camarillo" initials="G." surname="Camarillo"/>
          <author fullname="A. Johnston" initials="A." surname="Johnston"/>
          <author fullname="J. Peterson" initials="J." surname="Peterson"/>
          <author fullname="R. Sparks" initials="R." surname="Sparks"/>
          <author fullname="M. Handley" initials="M." surname="Handley"/>
          <author fullname="E. Schooler" initials="E." surname="Schooler"/>
          <date month="June" year="2002"/>
          <abstract>
            <t>This document describes Session Initiation Protocol (SIP), an application-layer control (signaling) protocol for creating, modifying, and terminating sessions with one or more participants. These sessions include Internet telephone calls, multimedia distribution, and multimedia conferences. [STANDARDS-TRACK]</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="3261"/>
        <seriesInfo name="DOI" value="10.17487/RFC3261"/>
      </reference>
      <reference anchor="RFC9112">
        <front>
          <title>HTTP/1.1</title>
          <author fullname="R. Fielding" initials="R." role="editor" surname="Fielding"/>
          <author fullname="M. Nottingham" initials="M." role="editor" surname="Nottingham"/>
          <author fullname="J. Reschke" initials="J." role="editor" surname="Reschke"/>
          <date month="June" year="2022"/>
          <abstract>
            <t>The Hypertext Transfer Protocol (HTTP) is a stateless application-level protocol for distributed, collaborative, hypertext information systems. This document specifies the HTTP/1.1 message syntax, message parsing, connection management, and related security concerns.</t>
            <t>This document obsoletes portions of RFC 7230.</t>
          </abstract>
        </front>
        <seriesInfo name="STD" value="99"/>
        <seriesInfo name="RFC" value="9112"/>
        <seriesInfo name="DOI" value="10.17487/RFC9112"/>
      </reference>
      <reference anchor="RFC8200">
        <front>
          <title>Internet Protocol, Version 6 (IPv6) Specification</title>
          <author fullname="S. Deering" initials="S." surname="Deering"/>
          <author fullname="R. Hinden" initials="R." surname="Hinden"/>
          <date month="July" year="2017"/>
          <abstract>
            <t>This document specifies version 6 of the Internet Protocol (IPv6). It obsoletes RFC 2460.</t>
          </abstract>
        </front>
        <seriesInfo name="STD" value="86"/>
        <seriesInfo name="RFC" value="8200"/>
        <seriesInfo name="DOI" value="10.17487/RFC8200"/>
      </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="RFC7826">
        <front>
          <title>Real-Time Streaming Protocol Version 2.0</title>
          <author fullname="H. Schulzrinne" initials="H." surname="Schulzrinne"/>
          <author fullname="A. Rao" initials="A." surname="Rao"/>
          <author fullname="R. Lanphier" initials="R." surname="Lanphier"/>
          <author fullname="M. Westerlund" initials="M." surname="Westerlund"/>
          <author fullname="M. Stiemerling" initials="M." role="editor" surname="Stiemerling"/>
          <date month="December" year="2016"/>
          <abstract>
            <t>This memorandum defines the Real-Time Streaming Protocol (RTSP) version 2.0, which obsoletes RTSP version 1.0 defined in RFC 2326.</t>
            <t>RTSP is an application-layer protocol for the setup and control of the delivery of data with real-time properties. RTSP provides an extensible framework to enable controlled, on-demand delivery of real-time data, such as audio and video. Sources of data can include both live data feeds and stored clips. This protocol is intended to control multiple data delivery sessions; provide a means for choosing delivery channels such as UDP, multicast UDP, and TCP; and provide a means for choosing delivery mechanisms based upon RTP (RFC 3550).</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="7826"/>
        <seriesInfo name="DOI" value="10.17487/RFC7826"/>
      </reference>
      <reference anchor="RFC6241">
        <front>
          <title>Network Configuration Protocol (NETCONF)</title>
          <author fullname="R. Enns" initials="R." role="editor" surname="Enns"/>
          <author fullname="M. Bjorklund" initials="M." role="editor" surname="Bjorklund"/>
          <author fullname="J. Schoenwaelder" initials="J." role="editor" surname="Schoenwaelder"/>
          <author fullname="A. Bierman" initials="A." role="editor" surname="Bierman"/>
          <date month="June" year="2011"/>
          <abstract>
            <t>The Network Configuration Protocol (NETCONF) defined in this document provides mechanisms to install, manipulate, and delete the configuration of network devices. It uses an Extensible Markup Language (XML)-based data encoding for the configuration data as well as the protocol messages. The NETCONF protocol operations are realized as remote procedure calls (RPCs). This document obsoletes RFC 4741. [STANDARDS-TRACK]</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="6241"/>
        <seriesInfo name="DOI" value="10.17487/RFC6241"/>
      </reference>
      <reference anchor="RFC7011">
        <front>
          <title>Specification of the IP Flow Information Export (IPFIX) Protocol for the Exchange of Flow Information</title>
          <author fullname="B. Claise" initials="B." role="editor" surname="Claise"/>
          <author fullname="B. Trammell" initials="B." role="editor" surname="Trammell"/>
          <author fullname="P. Aitken" initials="P." surname="Aitken"/>
          <date month="September" year="2013"/>
          <abstract>
            <t>This document specifies the IP Flow Information Export (IPFIX) protocol, which serves as a means for transmitting Traffic Flow information over the network. In order to transmit Traffic Flow information from an Exporting Process to a Collecting Process, a common representation of flow data and a standard means of communicating them are required. This document describes how the IPFIX Data and Template Records are carried over a number of transport protocols from an IPFIX Exporting Process to an IPFIX Collecting Process. This document obsoletes RFC 5101.</t>
          </abstract>
        </front>
        <seriesInfo name="STD" value="77"/>
        <seriesInfo name="RFC" value="7011"/>
        <seriesInfo name="DOI" value="10.17487/RFC7011"/>
      </reference>
      <reference anchor="RFC6462">
        <front>
          <title>Report from the Internet Privacy Workshop</title>
          <author fullname="A. Cooper" initials="A." surname="Cooper"/>
          <date month="January" year="2012"/>
          <abstract>
            <t>On December 8-9, 2010, the IAB co-hosted an Internet privacy workshop with the World Wide Web Consortium (W3C), the Internet Society (ISOC), and MIT's Computer Science and Artificial Intelligence Laboratory (CSAIL). The workshop revealed some of the fundamental challenges in designing, deploying, and analyzing privacy-protective Internet protocols and systems. Although workshop participants and the community as a whole are still far from understanding how best to systematically address privacy within Internet standards development, workshop participants identified a number of potential next steps. For the IETF, these included the creation of a privacy directorate to review Internet-Drafts, further work on documenting privacy considerations for protocol developers, and a number of exploratory efforts concerning fingerprinting and anonymized routing. Potential action items for the W3C included investigating the formation of a privacy interest group and formulating guidance about fingerprinting, referrer headers, data minimization in APIs, usability, and general considerations for non-browser-based protocols.</t>
            <t>Note that this document is a report on the proceedings of the workshop. The views and positions documented in this report are those of the workshop participants and do not necessarily reflect the views of the IAB, W3C, ISOC, or MIT CSAIL. This document is not an Internet Standards Track specification; it is published for informational purposes.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="6462"/>
        <seriesInfo name="DOI" value="10.17487/RFC6462"/>
      </reference>
      <reference anchor="RFC6973">
        <front>
          <title>Privacy Considerations for Internet Protocols</title>
          <author fullname="A. Cooper" initials="A." surname="Cooper"/>
          <author fullname="H. Tschofenig" initials="H." surname="Tschofenig"/>
          <author fullname="B. Aboba" initials="B." surname="Aboba"/>
          <author fullname="J. Peterson" initials="J." surname="Peterson"/>
          <author fullname="J. Morris" initials="J." surname="Morris"/>
          <author fullname="M. Hansen" initials="M." surname="Hansen"/>
          <author fullname="R. Smith" initials="R." surname="Smith"/>
          <date month="July" year="2013"/>
          <abstract>
            <t>This document offers guidance for developing privacy considerations for inclusion in protocol specifications. It aims to make designers, implementers, and users of Internet protocols aware of privacy-related design choices. It suggests that whether any individual RFC warrants a specific privacy considerations section will depend on the document's content.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="6973"/>
        <seriesInfo name="DOI" value="10.17487/RFC6973"/>
      </reference>
      <reference anchor="I-D.yao-cats-awareness-architecture">
        <front>
          <title>Computing and Network Information Awareness (CNIA) system architecture for CATS</title>
          <author fullname="Huijuan Yao" initials="H." surname="Yao">
            <organization>China Mobile</organization>
          </author>
          <author fullname="xuewei wang" initials="X." surname="wang">
            <organization>Ruijie Networks</organization>
          </author>
          <author fullname="Zhiqiang Li" initials="Z." surname="Li">
            <organization>China Mobile</organization>
          </author>
          <author fullname="Daniel Huang" initials="D." surname="Huang">
            <organization>New H3C Technologies</organization>
          </author>
          <author fullname="Changwang Lin" initials="C." surname="Lin">
            <organization>New H3C Technologies</organization>
          </author>
          <date day="22" month="October" year="2023"/>
          <abstract>
            <t>   This document describes a Computing and Network Information
   Awareness (CNIA)system architecture for Computing-Aware Traffic
   Steering (CATS). Based on the CATS framework, this document further
   describes a proposal detailed awareness architecture about the
   network information and computing information. It includes a new
   component and the corresponding interfaces and workflows in the CATS
   control plane.



            </t>
          </abstract>
        </front>
        <seriesInfo name="Internet-Draft" value="draft-yao-cats-awareness-architecture-02"/>
      </reference>
    </references>
    <?line 628?>

<section anchor="acknowledgements">
      <name>Acknowledgements</name>
      <t>The authors would like to thank Joel Halpern, John Scudder, Dino Farinacci, Adrian Farrel,
Cullen Jennings, Linda Dunbar, Jeffrey Zhang, Peng Liu, Fang Gao, Aijun Wang, Cong Li,
Xinxin Yi, Jari Arkko, Mingyu Wu, Haibo Wang, Xia Chen, Jianwei Mao, Guofeng Qian, Zhenbin Li,
Xinyue Zhang, Weier Li, Ines Robles and Nagendra Kumar for their comments and suggestions.</t>
      <t>Some text about various deployment models was originally documented in <xref target="I-D.yao-cats-awareness-architecture"/>.</t>
    </section>
    <section anchor="contributors" numbered="false" toc="include" removeInRFC="false">
      <name>Contributors</name>
      <contact initials="G." surname="Huang" fullname="Guangping Huang">
        <organization>ZTE</organization>
        <address>
          <email>huang.guangping@zte.com.cn</email>
        </address>
      </contact>
      <contact initials="G." surname="Mishra" fullname="Gyan Mishra">
        <organization>Verizon Inc.</organization>
        <address>
          <email>hayabusagsm@gmail.com</email>
        </address>
      </contact>
      <contact initials="H." surname="Yao" fullname="Huijuan Yao">
        <organization>China Mobile</organization>
        <address>
          <email>yaohuijuan@chinamobile.com</email>
        </address>
      </contact>
      <contact initials="Y." surname="Li" fullname="Yizhou Li">
        <organization>Huawei Technologies</organization>
        <address>
          <email>liyizhou@huawei.com</email>
        </address>
      </contact>
      <contact initials="D." surname="Trossen" fullname="Dirk Trossen">
        <organization>Huawei Technologies</organization>
        <address>
          <email>dirk.trossen@huawei.com</email>
        </address>
      </contact>
      <contact initials="L." surname="Iannone" fullname="Luigi Iannone">
        <organization>Huawei Technologies</organization>
        <address>
          <email>luigi.iannone@huawei.com</email>
        </address>
      </contact>
      <contact initials="H." surname="Shi" fullname="Hang Shi">
        <organization>Huawei Technologies</organization>
        <address>
          <email>shihang9@huawei.com</email>
        </address>
      </contact>
      <contact initials="C." surname="Lin" fullname="Changwang Lin">
        <organization>New H3C Technologies</organization>
        <address>
          <email>linchangwang.04414@h3c.com</email>
        </address>
      </contact>
      <contact initials="X." surname="Wang" fullname="Xueshun Wang">
        <organization>CICT</organization>
        <address>
          <email>xswang@fiberhome.com</email>
        </address>
      </contact>
      <contact initials="X." surname="Wang" fullname="Xuewei Wang">
        <organization>Ruijie Networks</organization>
        <address>
          <email>wangxuewei1@ruijie.com.cn</email>
        </address>
      </contact>
      <contact initials="C." surname="Jacquenet" fullname="Christian Jacquenet">
        <organization>Orange</organization>
        <address>
          <email>christian.jacquenet@orange.com</email>
        </address>
      </contact>
    </section>
  </back>
  <!-- ##markdown-source:
H4sIAAAAAAAAA9V923YbR5LgO76iDv0g0QRgi5LsMaen1xxKaslryVqR3e7u
nd09BSAJlFWowtaFFNx0n/mN+b39ko1rXqqyAJD29Nnlgy1UVd4iI+MekZPJ
ZNRkTW7OkvPkVZWuzW1ZfUyuyyq5KNebtsmK5eT8Nq1MclWl19fZPLlsjKng
cfL44vzq8niUzmaVuTlL8JfrYjRPG7Msq+1ZkhXX5Wi0KOcFvDtLFtBPM8lM
cz2Bb+rJtTaZfPnNqG5n66yus7K42m7g4zcvr16NinY9M9XZaAFdno3mZVGb
om7rs6SpWjOCoZ+OYILpWfKhpAkn+GuEXS6rst2cJTjO6KPZwqPF2SiZuLXt
XSV+/cfaVMnLTxt4YIq54Q7yPJ2VVdpkNyZ5ZxocTT6/NNVNNjdJuWmydfYz
fFIWI5j2At6fJW09Set5lo022Vny35tyPk7qsmoqc13Dv7Zr/Mf/GI3StlmV
FU52lAAEYbEX0+T7DH4wFC9WBmZPD8pqmRYyzlnyuk1vTZZcmfmqKPNymZka
vjHrNMsBENP82xV9MJ2Xa3helbj1ZpE1ZQU/52VbNLhnF6usSL3B/zpNXrR2
8L+WxXKD49OzcHxqmbwtZ1lu3MCL9mdp8+0cP1jTe5lEbNTkus1zHu1tuYL/
L5J/Ldt5ukgznGhn0B+qtFjicN0Fub4BM2nv7JTW3O10pt1+W1IvPKnOHL5v
szp5O4V9h95Mldb9OVyZ3FyXRTZPg3EvN2lWeMPm0NM6W7Ymh4Gks3VbZXle
ftvYLrxJEPy/A/hX6UeaP8/ou3JVJC/d03Ayb4qFAWgvTNF4Y/9k/tcCv/92
m67KUqDvpvrHImsAzpcNnLM6Ka+T8zWgPKxnRDPNZm1jUZIn8YcWILbBc/Qa
/8XIAPhx9dJt/QrfTJf65bc/NwTi6bwIetqmRfI2q1dVqr38CQYHrIG1zKde
d+k2nbV1uqzX3y7xkQMV9/S6zX6CwZK/pKX2FMfJbVqu+Ns+Trru/pL9vCpb
e9L2HLA829L3wSlznb3IgLheVWUNFOyg/hbQYNpwg4E+ATWXWfImLYqyMIdN
EltMM24x0Otr2K7kcnXYqutVtoLvv+n15QhX4VEu+PQ2JepV9MjHO3ObvH56
MQjeYq7Np18+e/bk2berp/POeH+eJj8yMvKAf25NvWoLfdghV28urlz/n2rs
+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
sej/AgoxpIHfvgAA

-->

</rfc>
