<?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-10" 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-10"/>
    <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="24"/>
    <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 109?>

<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 113?>

<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 a typical CATS workflow. In order to enable CATS in a given domain, some provisioning is needed; see more details in <xref target="sec-cats-provisioning"/>. <xref target="sec-cats-deployment"/> describes several deployment options (distributed, centralized, and hybrid model) to accommodate a variety of contexts.</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="sec-cats-provisioning">
        <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="sec-cats-deployment">
        <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 anchor="verify-correct-operations">
        <name>Verify Correct Operations</name>
        <t>CATS may be implemented by extending some existing control plane protocols, such as BGP or PCEP. A CATS implementation must log error events for better network management and operation. Means to assess the reachability and trace CATS paths should be supported.</t>
      </section>
      <section anchor="impact-on-network-operations">
        <name>Impact on Network Operations</name>
        <t>Computing metrics are collected and distributed in CATS. A new function is needed to be deployed to manage the cooperation between network elements and computing elements. For example, this function may be provided by an orchestrator connecting with C-SMA and C-NMA. This might bring more complexity of the network management, especially if this function is not leveraged for other purposes beyond CATS.</t>
      </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 634?>

<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:
H4sIAAAAAAAAA9V923Ybx7XgO76iF/0g0QRgi5LsEyYnY4aSInkimyMycZI5
M7MaQAFoq9GN6QspOHTW/Mb83nzJ7GtduqsBkvY5a4YPttDdddu1a9/3rslk
MmqyJjdnyXnypko35rasPibLskouys22bbJiNTm/TSuTXFfpcpnNk6vGmAoe
J08vzq+vjkfpbFaZm7MEf7kuRvO0Mauy2p0lWbEsR6NFOS/g3VmygH6aSWaa
5QS+qSdLbTJ59uWobmebrK6zsrjebeHjd6+v34yKdjMz1dloAV2ejeZlUZui
buuzpKlaM4Khn49ggulZ8qGkCSf4a4Rdrqqy3Z4lOM7oo9nBo8XZKJm4tR1c
JX7959pUyetPW3hgirnhDvI8nZVV2mQ3JvnONDiafH5lqptsbpJy22Sb7Cf4
pCxGMO0FvD9L2nqS1vMsG22zs+S/NuV8nNRl1VRmWcO/dhv8x38bjdK2WZcV
TnaUAARhsRfT5E8Z/GAoXqwNzJ4elNUqLWScs+Rtm96aLLk283VR5uUqMzV8
YzZplgMgpvk3a/pgOi838LwqcevNImvKCn7Oy7ZocM8u1lmReoP/fZq8au3g
fy+L1RbHp2fh+NQyeV/Osty4gRftT9Lmmzl+sKH3MonYqMmyzXMe7X25hv8v
kj+U7TxdpBlOtDPo91VarHC47oJc34CZtHd2ShvudjrTbr8pqReeVGcOf2qz
Onk/hX2H3kyV1v05XJvcLMsim6fBuFfbNCu8YXPoaZOtWpPDQNLZpq2yPC+/
aWwX3iQI/t8C/Kv0I82fZ/RtuS6S1+5pOJl3xcIAtBemaLyxfzT/Y4Hff7NL
12Up0HdT/XORNQDnqwbOWZ2Uy+R8AygP6xnRTLNZ21iU5En8sQWIbfEcvcV/
MTIAfly/dlu/xjfTlX75zU8NgXg6L4KedmmRvM/qdZVqL3+BwQFrYC3zqddd
uktnbZ2u6s03K3zkQMU9vW2zH2Gw5G9pqT3FcXKXlmv+to+Trru/ZT+ty9ae
tAMHLM929H1wylxnrzIgrtdVWQMFu1d/C2gwbbjBQJ+AmqsseZcWRVmY+00S
W0wzbjHQ61vYruRqfb9V1+tsDd//pteXI1yFR7ng09uUqFfRIx/fmdvk7fOL
QfAWc20+/fLFi2cvvlk/n3fG++s0+YGRkQf8a2vqdVvoww65endx7fr/VGPP
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
TI/vN8mQuwGpRSz6vzhONZHnwgAA

-->

</rfc>
