💾 Archived View for radia.bortzmeyer.org › rfc-mirror › rfc9473.txt captured on 2024-07-09 at 05:37:36.

View Raw

More Information

⬅️ Previous capture (2023-12-28)

-=-=-=-=-=-=-





Internet Research Task Force (IRTF)                          R. Enghardt
Request for Comments: 9473                                       Netflix
Category: Informational                                    C. Krähenbühl
ISSN: 2070-1721                                               ETH Zürich
                                                          September 2023


                    A Vocabulary of Path Properties

Abstract

   Path properties express information about paths across a network and
   the services provided via such paths.  In a path-aware network, path
   properties may be fully or partially available to entities such as
   endpoints.  This document defines and categorizes path properties.
   Furthermore, the document identifies several path properties that
   might be useful to endpoints or other entities, e.g., for selecting
   between paths or for invoking some of the provided services.  This
   document is a product of the Path Aware Networking Research Group
   (PANRG).

Status of This Memo

   This document is not an Internet Standards Track specification; it is
   published for informational purposes.

   This document is a product of the Internet Research Task Force
   (IRTF).  The IRTF publishes the results of Internet-related research
   and development activities.  These results might not be suitable for
   deployment.  This RFC represents the consensus of the Path Aware
   Networking Research Group of the Internet Research Task Force (IRTF).
   Documents approved for publication by the IRSG are not candidates for
   any level of Internet Standard; see Section 2 of RFC 7841.

   Information about the current status of this document, any errata,
   and how to provide feedback on it may be obtained at
   https://www.rfc-editor.org/info/rfc9473.

Copyright Notice

   Copyright (c) 2023 IETF Trust and the persons identified as the
   document authors.  All rights reserved.

   This document is subject to BCP 78 and the IETF Trust's Legal
   Provisions Relating to IETF Documents
   (https://trustee.ietf.org/license-info) in effect on the date of
   publication of this document.  Please review these documents
   carefully, as they describe your rights and restrictions with respect
   to this document.

Table of Contents

   1.  Introduction
   2.  Terminology
     2.1.  Terminology Usage for Specific Technologies
   3.  Use Cases for Path Properties
     3.1.  Path Selection
     3.2.  Protocol Selection
     3.3.  Service Invocation
   4.  Examples of Path Properties
   5.  Security Considerations
   6.  IANA Considerations
   7.  Informative References
   Acknowledgments
   Authors' Addresses

1.  Introduction

   The current Internet architecture does not explicitly support
   endpoint discovery of forwarding paths through the network nor the
   discovery of properties and services associated with these paths.
   Path-aware networking, as defined in Section 1.1 of [RFC9217],
   describes "endpoint discovery of the properties of paths they use for
   communication across an internetwork, and endpoint reaction to these
   properties that affects routing and/or data transfer".  This document
   provides a generic definition of path properties, addressing the
   first of the questions in path-aware networking [RFC9217].

   As terms related to paths have been used with different meanings in
   different areas of networking, first, this document provides a common
   terminology to define paths, path elements, and flows.  Based on
   these terms, the document defines path properties.  Then, this
   document provides some examples of use cases for path properties.
   Finally, the document lists several path properties that may be
   useful for the mentioned use cases.  This list is intended to be
   neither exhaustive nor definitive.

   Note that this document does not assume that any of the listed path
   properties are actually available to any entity.  The question of how
   entities can discover and distribute path properties in a trustworthy
   way is out of scope for this document.

   This document represents the consensus of the Path Aware Networking
   Research Group (PANRG).

2.  Terminology

   Entity:  A physical or virtual device or function, or a collection of
      devices or functions, that plays a role related to path-aware
      networking for particular paths and flows.  An entity can be on-
      path or off-path.  On the path, an entity may participate in
      forwarding the flow, i.e., what may be called "data plane
      functionality".  On or off the path, an entity may influence
      aspects of how the flow is forwarded, i.e., what may be called
      "control plane functionality", such as path selection or service
      invocation.  An entity influencing forwarding aspects is usually
      aware of path properties, e.g., by observing or measuring them or
      by learning them from another entity.

   Node:  An on-path entity that processes packets, e.g., sends,
      receives, forwards, or modifies them.  A node may be physical or
      virtual, e.g., a physical device, a service function provided as a
      virtual element, or even a single queue within a switch.  A node
      may also be an entity that consists of a collection of devices or
      functions, e.g., an entire Autonomous System (AS).

   Link:  A medium or communication facility that connects two or more
      nodes with each other.  A link enables a node to send packets to
      other nodes.  Links can be physical, e.g., a Wi-Fi network that
      connects an Access Point to stations, or virtual, e.g., a virtual
      switch that connects two virtual machines hosted on the same
      physical machine.  A link is unidirectional.  As such,
      bidirectional communication can be modeled as two links between
      the same nodes in opposite directions.

   Path element:  Either a node or a link.  For example, a path element
      can be an Abstract Network Element (ANE) as defined in [RFC9275].

   Path:  A sequence of adjacent path elements over which a packet can
      be transmitted, starting and ending with a node.

      Paths are unidirectional and time dependent, i.e., there can be a
      variety of paths from one node to another, and the path over which
      packets are transmitted may change.  A path definition can be
      strict (i.e., the exact sequence of path elements remains the
      same) or loose (i.e., the start and end node remain the same, but
      the path elements between them may vary over time).

      The representation of a path and its properties may depend on the
      entity considering the path.  On the one hand, the representation
      may differ due to entities having partial visibility of path
      elements comprising a path or their visibility changing over time.
      On the other hand, the representation may differ due to treating
      path elements at different levels of abstraction.  For example, a
      path may be given as a sequence of physical nodes and the links
      connecting these nodes, be given as a sequence of logical nodes
      such as a sequence of ASes or an Explicit Route Object (ERO), or
      only consist of a specific source and destination that is known to
      be reachable from that source.

      A multicast or broadcast setting where a packet is sent by one
      node and received by multiple nodes is described by multiple paths
      over which the packet is sent, one path for each combination of
      sending and receiving node; these paths do not have to be disjoint
      as defined by the disjointness path property, see Section 4.

   Endpoint:  The endpoints of a path are the start and end node of the
      path.  For example, an endpoint can be a host as defined in
      [RFC1122], which can be a client (e.g., a node running a web
      browser) or a server (e.g., a node running a web server).

   Reverse Path:  The path that is used by a remote node in the context
      of bidirectional communication.

   Subpath:  Given a path, a subpath is a sequence of adjacent path
      elements of this path.

   Flow:  One or multiple packets to which the traits of a path or set
      of subpaths may be applied in a functional sense.  For example, a
      flow can consist of all packets sent within a TCP session with the
      same five-tuple between two hosts, or it can consist of all
      packets sent on the same physical link.

   Property:  A trait of one or a sequence of path elements, or a trait
      of a flow with respect to one or a sequence of path elements.  An
      example of a link property is the maximum data rate that can be
      sent over the link.  An example of a node property is the
      administrative domain that the node belongs to.  An example of a
      property of a flow with respect to a subpath is the aggregated
      one-way delay of the flow being sent from one node to another node
      over this subpath.  A property is thus described by a tuple
      containing the path element(s), the flow or an empty set if no
      packets are relevant for the property, the name of the property
      (e.g., maximum data rate), and the value of the property (e.g., 1
      Gbps).

   Aggregated property:  A collection of multiple values of a property
      into a single value, according to a function.  A property can be
      aggregated over:

      *  multiple path elements (i.e., a subpath), for example, the MTU
         of a path as the minimum MTU of all links on the path,

      *  multiple packets (i.e., a flow), for example, the median one-
         way latency of all packets between two nodes,

      *  or both path elements and packets, for example, the mean of the
         queueing delays of a flow on all nodes along a path.

      The aggregation function can be numerical (e.g., median, sum,
      minimum) or logical (e.g., "true if all are true", "true if at
      least 50% of values are true"), or it can be an arbitrary function
      that maps multiple input values to an output value.

   Observed property:  A property that is observed for a specific path
      element, subpath, or path.  A property may be observed using
      measurements, for example, the one-way delay of a specific packet
      transmitted from node to node.

   Assessed property:  An approximate calculation or assessment of the
      value of a property.  An assessed property includes the
      reliability of the calculation or assessment.  The notion of
      reliability depends on the property.  For example, a path property
      based on an approximate calculation may describe the expected
      median one-way latency of packets sent on a path within the next
      second, including the confidence level and interval.  A non-
      numerical assessment may instead include the likelihood that the
      property holds.

   Target property:  An objective that is set for a property over a path
      element, subpath, or path.  Note that a target property can be set
      for observed properties, such as one-way delay, and also for
      properties that cannot be observed by the entity setting the
      target, such as inclusion of certain nodes on a path.

2.1.  Terminology Usage for Specific Technologies

   The terminology defined in this document is intended to be general
   and applicable to existing and future path-aware technologies.  Using
   this terminology, a path-aware technology can define and consider
   specific path elements and path properties on a specific level of
   abstraction.  For instance, a technology may define path elements as
   IP routers, e.g., in source routing [RFC1940].  Alternatively, it may
   consider path elements on a different layer of the Internet
   architecture [RFC1122] or as a collection of entities not tied to a
   specific layer, such as an AS or ERO.  Even within a single path-
   aware technology, specific definitions might differ depending on the
   context in which they are used.  For example, the endpoints might be
   the communicating hosts in the context of the transport layer, ASes
   that contain the hosts in the context of routing, or specific
   applications in the context of the application layer.

3.  Use Cases for Path Properties

   When a path-aware network exposes path properties to endpoints or
   other entities, these entities may use this information to achieve
   different goals.  This section lists several use cases for path
   properties.

   Note that this is not an exhaustive list; as with every new
   technology and protocol, novel use cases may emerge, and new path
   properties may become relevant.  Moreover, for any particular
   technology, entities may have visibility of and control over
   different path elements and path properties and consider them on
   different levels of abstraction.  Therefore, a new technology may
   implement an existing use case related to different path elements or
   on a different level of abstraction.

3.1.  Path Selection

   Nodes may be able to send flows via one (or a subset) out of multiple
   possible paths, and an entity may be able to influence the decision
   about which path(s) to use.  Path selection may be feasible if there
   are several paths to the same destination (e.g., in case of a mobile
   device with two wireless interfaces, both providing a path) or if
   there are several destinations, and thus several paths, providing the
   same service (e.g., Application-Layer Traffic Optimization (ALTO)
   [RFC5693], an application layer peer-to-peer protocol allowing
   endpoints a better-than-random peer selection).  Entities can express
   their intent to achieve a specific goal by specifying target
   properties for their paths, e.g., related to performance or security.
   Then, paths can be selected that best meet the target properties,
   e.g., the entity can select these paths from all available paths or
   express the target properties to the network and rely on the network
   to select appropriate paths.

   Target properties relating to network performance typically refer to
   observed properties, such as one-way delay, one-way packet loss, and
   link capacity.  Entities then select paths based on their target
   property and the assessed property of the available paths that best
   match the application requirements.  For such performance-related
   target properties, the observed property is similar to a Service
   Level Indicator (SLI), and the assessed property is similar to a
   Service Level Objective (SLO) for IETF Network Slices
   [NETWORK-SLICES].  As an example path-selection strategy, an entity
   may select a path with a short one-way delay for sending a small
   delay-sensitive query, while it may select a path with high link
   capacities on all links for retrieving a large file.

   It is also possible for an entity to set target properties that it
   cannot (directly) observe, similar to Service Level Expectations
   (SLEs) for IETF Network Slices [NETWORK-SLICES].  This may apply to
   security-related target properties (e.g., to mandate that all
   enterprise traffic goes through a specific firewall) and path
   selection (e.g., to enforce traffic policies by allowing or
   disallowing sending flows over paths that involve specific networks
   or nodes).

   Care needs to be taken when selecting paths based on observed path
   properties, as path properties that were previously measured may not
   be helpful in predicting current or future path properties, and such
   path selection may lead to unintended feedback loops.  Also, there
   may be trade-offs between path properties (e.g., one-way delay and
   link capacity), and entities may influence these trade-offs with
   their choices.  Finally, path selection may impact fairness.  For
   example, if multiple entities concurrently attempt to meet their
   target properties using the same network resources, one entity's
   choices may influence the conditions on the path as experienced by
   flows of another entity.

   As a baseline, a path-selection algorithm should aim to do a better
   job of meeting the target properties, and consequently accommodating
   the user's requirements, than the default case of not selecting a
   path most of the time.

   Path selection can be done either by the communicating node(s) or by
   other entities within the network.  A network (e.g., an AS) can
   adjust its path selection for internal or external routing based on
   path properties.  In BGP, the Multi-Exit Discriminator (MED)
   attribute is used in the decision-making process to select which path
   to choose among those having the same AS path length and origin
   [RFC4271]; in a path-aware network, instead of using this single MED
   value, other properties such as link capacity or link usage could
   additionally be used to improve load balancing or performance
   [PERFORMANCE-ROUTING].

3.2.  Protocol Selection

   Before sending data over a specific path, an entity may select an
   appropriate protocol or configure protocol parameters depending on
   path properties.  For example, an endpoint may cache state if a path
   allows the use of QUIC [RFC9000]; if so, it may first attempt to
   connect using QUIC before falling back to another protocol when
   connecting over this path again.  A video-streaming application may
   choose an (initial) video quality based on the achievable data rate
   or the monetary cost of sending data (e.g., volume-based or flat-rate
   cost model).

3.3.  Service Invocation

   In addition to path or protocol selection, an entity may choose to
   invoke additional functions in the context of Service Function
   Chaining [RFC7665], which may influence which nodes are on the path.
   For example, a 0-RTT Transport Converter [RFC8803] will be involved
   in a path only when invoked by an endpoint; such invocation will lead
   to the use of Multipath TCP (MPTCP) [RFC8684] or tcpcrypt [RFC8548]
   capabilities, while such use is not supported via the default
   forwarding path.  Another example is a connection that is composed of
   multiple streams where each stream has specific service requirements.
   An endpoint may decide to invoke a given service function (e.g.,
   transcoding) only for some streams while others are not processed by
   that service function.

4.  Examples of Path Properties

   This section gives some examples of path properties that may be
   useful, e.g., for the use cases described in Section 3.

   Within the context of any particular technology, available path
   properties may differ as entities have insight into and are able to
   influence different path elements and path properties.  For example,
   an endpoint may have some visibility into path elements that are
   close and on a low level of abstraction (e.g., individual nodes
   within the first few hops), or it may have visibility into path
   elements that are far away and/or on a higher level of abstraction
   (e.g., the list of ASes traversed).  This visibility may depend on
   factors such as the physical or network distance or the existence of
   trust or contractual relationships between the endpoint and the path
   element(s).  A path property can be defined relative to individual
   path elements, a sequence of path elements, or "end-to-end", i.e.,
   relative to a path that comprises of two endpoints and a single
   virtual link connecting them.

   Path properties may be relatively dynamic, e.g., the one-way delay of
   a packet sent over a specific path, or non-dynamic, e.g., the MTU of
   an Ethernet link that only changes infrequently.  Usefulness over
   time differs depending on how dynamic a property is: the merit of a
   momentarily observed dynamic path property may diminish greatly as
   time goes on, e.g., it is possible for the observed values of one-way
   delay to change on timescales that are shorter than the one-way delay
   between the measurement point and an entity making a decision such as
   path selection, which may cause the measurement to be outdated when
   it reaches the decision-making entity.  Therefore, consumers of
   dynamic path properties need to apply caution when using them, e.g.,
   by aggregating them appropriately or applying a dampening function to
   their changes to avoid oscillation.  In contrast, the observed value
   of a less dynamic path property might stay relevant for a longer
   period of time, e.g., a NAT typically stays on a particular path
   during the lifetime of a connection involving packets sent over this
   path.

   Access Technology:  The physical- or link-layer technology used for
      transmitting or receiving a flow on one or multiple path elements.
      If known, the access technology may be given as an abstract link
      type, e.g., as Wi-Fi, wired Ethernet, or cellular.  It may also be
      given as a specific technology used on a link, e.g., 3GPP cellular
      or 802.11 Wireless Local Area Network (WLAN).  Other path elements
      relevant to the access technology may include nodes related to
      processing packets on the physical or link layer, such as elements
      of a cellular core network.  Note that there is no common registry
      of possible values for this property.

   Monetary Cost:  The price to be paid to transmit or receive a
      specific flow across a network to which one or multiple path
      elements belong.

   Service Function:  A service function that a path element applies to
      a flow, see [RFC7665].  Examples of abstract service functions
      include firewalls, Network Address Translation (NAT), and TCP
      Performance Enhancing Proxies.  Some stateful service functions,
      such as NAT, need to observe the same flow in both directions,
      e.g., by being an element of both the path and the reverse path.

   Transparency:  When a node performs an action A on a flow F, the node
      is transparent to F with respect to some (meta-)information M if
      the node performs A independently of M.  M can, for example, be
      the existence of a protocol (header) in a packet or the content of
      a protocol header, payload, or both.  For example, A can be
      blocking packets or reading and modifying (other protocol) headers
      or payloads.  Transparency can be modeled using a function f,
      which takes as input F and M and outputs the action taken by the
      node.  If a taint analysis shows that the output of f is not
      tainted (impacted) by M, or if the output of f is constant for
      arbitrary values of M, then the node is considered to be
      transparent.  An IP router could be transparent to transport
      protocol headers such as TCP/UDP but not transparent to IP headers
      since its forwarding behavior depends on the IP headers.  A
      firewall that only allows outgoing TCP connections by blocking all
      incoming TCP SYN packets regardless of their IP address is
      transparent to IP but not to TCP headers.  Finally, a NAT that
      actively modifies IP and TCP/UDP headers based on their content is
      not transparent to either IP or TCP/UDP headers.  Note that
      according to this definition, a node that modifies packets in
      accordance with the endpoints, such as a transparent HTTP proxy,
      as defined in [RFC9110], and a node listening and reacting to
      implicit or explicit signals, see [RFC8558], are not considered
      transparent.

      Transparency only applies to nodes and not to links, as a link
      cannot modify or perform any other actions on the packets by
      itself.  For example, if the content of a packet is altered when
      forwarded over a Generic Routing Encapsulation (GRE) tunnel
      [RFC2784] [RFC7676], per this document the software instances that
      terminate the tunnel are considered nodes over which the actions
      are performed; thus, the transparency definition applies to these
      nodes.

   Administrative Domain:  The identity of an individual or an
      organization that controls access to a path element (or several
      path elements).  Examples of administrative domains are an IGP
      area, an AS, or a service provider network.

   Routing Domain Identifier:  An identifier indicating the routing
      domain of a path element.  Path elements in the same routing
      domain are in the same administrative domain and use a common
      routing protocol to communicate with each other.  An example of a
      routing domain identifier is the globally unique Autonomous System
      Number (ASN) as defined in [RFC1930].

   Disjointness:  For a set of two paths or subpaths, the number of
      shared path elements can be a measure of intersection (e.g.,
      Jaccard coefficient, which is the number of shared elements
      divided by the total number of elements).  Conversely, the number
      of non-shared path elements can be a measure of disjointness
      (e.g., 1 - Jaccard coefficient).  A multipath protocol might use
      disjointness as a metric to reduce the number of single points of
      failure.  As paths can be defined at different levels of
      abstraction, two paths may be disjoint at one level of abstraction
      but not on another.

   Symmetric Path:  Two paths are symmetric if the path and its reverse
      path consist of the same path elements on the same level of
      abstraction, but in reverse order.  For example, a path that
      consists of layer 3 switches and links between them and a reverse
      path with the same path elements but in reverse order are
      considered "routing" symmetric, as the same path elements on the
      same level of abstraction (IP forwarding) are traversed in the
      opposite direction.  Symmetry can depend on the level of
      abstraction on which the path is defined or modeled.  If there are
      two parallel physical links between two nodes, modeling them as
      separate links may result in a flow using asymmetric paths, and
      modeling them as a single virtual link may result in symmetric
      paths, e.g., if the difference between the two physical links is
      irrelevant in a particular context.

   Path MTU:  The maximum size, in octets, of a packet or frame that can
      be transmitted without fragmentation.

   Transport Protocols available:  Whether a specific transport protocol
      can be used to establish a connection over a path or subpath,
      e.g., whether the path is QUIC-capable or MPTCP-capable, based on
      input such as policy, cached knowledge, or probing results.

   Protocol Features available:  Whether a specific protocol feature is
      available over a path or subpath, e.g., Explicit Congestion
      Notification (ECN) or TCP Fast Open.

   Some path properties express the performance of the transmission of a
   packet or flow over a link or subpath.  Such transmission performance
   properties can be observed or assessed, e.g., by endpoints or by path
   elements on the path, or they may be available as cost metrics, see
   [RFC9439].  Transmission performance properties may be made available
   in an aggregated form, such as averages or minimums.  Properties
   related to a path element that constitutes a single layer 2 domain
   are abstracted from the used physical- and link-layer technology,
   similar to [RFC8175].

   Link Capacity:  The link capacity is the maximum data rate at which
      data that was sent over a link can correctly be received at the
      node adjacent to the link.  This property is analogous to the link
      capacity defined in [RFC5136] and [RFC9097] but is not restricted
      to IP-layer traffic.

   Link Usage:  The link usage is the actual data rate at which data
      that was sent over a link is correctly received at the node
      adjacent to the link.  This property is analogous to the link
      usage defined in [RFC5136] and [RFC9097] but is not restricted to
      IP-layer traffic.

   One-Way Delay:  The one-way delay is the delay between a node sending
      a packet and another node on the same path receiving the packet.
      This property is analogous to the one-way delay defined in
      [RFC7679] but is not restricted to IP-layer traffic.

   One-Way Delay Variation:  The variation of the one-way delays within
      a flow.  This property is similar to the one-way delay variation
      defined in [RFC3393], but it is not restricted to IP-layer traffic
      and it is defined for packets on the same flow instead of packets
      sent between a source and destination IP address.

   One-Way Packet Loss:  Packets sent by a node but not received by
      another node on the same path after a certain time interval are
      considered lost.  This property is analogous to the one-way loss
      defined in [RFC7680] but is not restricted to IP-layer traffic.
      Metrics such as loss patterns [RFC3357] and loss episodes
      [RFC6534] can be expressed as aggregated properties.

5.  Security Considerations

   If entities are basing policy or path-selection decisions on path
   properties, they need to rely on the accuracy of path properties that
   other devices communicate to them.  In order to be able to trust such
   path properties, entities may need to establish a trust relationship
   or be able to independently verify the authenticity, integrity, and
   correctness of path properties received from another entity.

   Entities that reveal their target path properties to the network can
   negatively impact their own privacy, e.g., if the target property
   leaks personal information about a user, such as their identity or
   which (type of) application is used.  Such information could then
   allow network operators to block or reprioritize traffic for certain
   users and/or applications.  Conversely, if privacy-enhancing
   technologies, e.g., MASQUE proxies [RFC9298], are used on a path, the
   path may only be partially visible to any single entity.  This may
   diminish the usefulness of path-aware technologies over this path.

   The need for, and potential definition of, security- and privacy-
   related path properties, such as confidentiality and integrity
   protection of payloads, are the subject of ongoing discussion and
   research, for example, see [RFC9049] and [RFC9217].  As the
   discussion of such properties is not mature enough, they are out of
   scope for this document.  One aspect discussed in this context is
   that security-related properties are difficult to characterize since
   they are only meaningful with respect to a threat model that depends
   on the use case, application, environment, and other factors.
   Likewise, properties for trust relations between entities cannot be
   meaningfully defined without a concrete threat model, and defining a
   threat model is out of scope for this document.  Properties related
   to confidentiality, integrity, and trust seem to be orthogonal to the
   path terminology and path properties defined in this document, since
   they are tied to the communicating nodes and the protocols they use
   (e.g., client and server using HTTPS, or client and remote network
   node using a VPN service) as well as additional context, such as
   keying material and who has access to such a context.  In contrast,
   the path as defined in this document is typically oblivious to these
   aspects.  Intuitively, the path describes what function the network
   applies to packets, while confidentiality, integrity, and trust
   describe what function the communicating parties apply to packets.

6.  IANA Considerations

   This document has no IANA actions.

7.  Informative References

   [NETWORK-SLICES]
              Farrel, A., Drake, J., Rokui, R., Homma, S., Makhijani,
              K., Contreras, L. M., and J. Tantsura, "A Framework for
              Network Slices in Networks Built from IETF Technologies",
              Work in Progress, Internet-Draft, draft-ietf-teas-ietf-
              network-slices-24, 25 August 2023,
              <https://datatracker.ietf.org/doc/html/draft-ietf-teas-
              ietf-network-slices-24>.

   [PERFORMANCE-ROUTING]
              Xu, X., Hegde, S., Talaulikar, K., Boucadair, M., and C.
              Jacquenet, "Performance-based BGP Routing Mechanism", Work
              in Progress, Internet-Draft, draft-ietf-idr-performance-
              routing-03, 21 December 2020,
              <https://datatracker.ietf.org/doc/html/draft-ietf-idr-
              performance-routing-03>.

   [RFC1122]  Braden, R., Ed., "Requirements for Internet Hosts -
              Communication Layers", STD 3, RFC 1122,
              DOI 10.17487/RFC1122, October 1989,
              <https://www.rfc-editor.org/info/rfc1122>.

   [RFC1930]  Hawkinson, J. and T. Bates, "Guidelines for creation,
              selection, and registration of an Autonomous System (AS)",
              BCP 6, RFC 1930, DOI 10.17487/RFC1930, March 1996,
              <https://www.rfc-editor.org/info/rfc1930>.

   [RFC1940]  Estrin, D., Li, T., Rekhter, Y., Varadhan, K., and D.
              Zappala, "Source Demand Routing: Packet Format and
              Forwarding Specification (Version 1)", RFC 1940,
              DOI 10.17487/RFC1940, May 1996,
              <https://www.rfc-editor.org/info/rfc1940>.

   [RFC2784]  Farinacci, D., Li, T., Hanks, S., Meyer, D., and P.
              Traina, "Generic Routing Encapsulation (GRE)", RFC 2784,
              DOI 10.17487/RFC2784, March 2000,
              <https://www.rfc-editor.org/info/rfc2784>.

   [RFC3357]  Koodli, R. and R. Ravikanth, "One-way Loss Pattern Sample
              Metrics", RFC 3357, DOI 10.17487/RFC3357, August 2002,
              <https://www.rfc-editor.org/info/rfc3357>.

   [RFC3393]  Demichelis, C. and P. Chimento, "IP Packet Delay Variation
              Metric for IP Performance Metrics (IPPM)", RFC 3393,
              DOI 10.17487/RFC3393, November 2002,
              <https://www.rfc-editor.org/info/rfc3393>.

   [RFC4271]  Rekhter, Y., Ed., Li, T., Ed., and S. Hares, Ed., "A
              Border Gateway Protocol 4 (BGP-4)", RFC 4271,
              DOI 10.17487/RFC4271, January 2006,
              <https://www.rfc-editor.org/info/rfc4271>.

   [RFC5136]  Chimento, P. and J. Ishac, "Defining Network Capacity",
              RFC 5136, DOI 10.17487/RFC5136, February 2008,
              <https://www.rfc-editor.org/info/rfc5136>.

   [RFC5693]  Seedorf, J. and E. Burger, "Application-Layer Traffic
              Optimization (ALTO) Problem Statement", RFC 5693,
              DOI 10.17487/RFC5693, October 2009,
              <https://www.rfc-editor.org/info/rfc5693>.

   [RFC6534]  Duffield, N., Morton, A., and J. Sommers, "Loss Episode
              Metrics for IP Performance Metrics (IPPM)", RFC 6534,
              DOI 10.17487/RFC6534, May 2012,
              <https://www.rfc-editor.org/info/rfc6534>.

   [RFC7665]  Halpern, J., Ed. and C. Pignataro, Ed., "Service Function
              Chaining (SFC) Architecture", RFC 7665,
              DOI 10.17487/RFC7665, October 2015,
              <https://www.rfc-editor.org/info/rfc7665>.

   [RFC7676]  Pignataro, C., Bonica, R., and S. Krishnan, "IPv6 Support
              for Generic Routing Encapsulation (GRE)", RFC 7676,
              DOI 10.17487/RFC7676, October 2015,
              <https://www.rfc-editor.org/info/rfc7676>.

   [RFC7679]  Almes, G., Kalidindi, S., Zekauskas, M., and A. Morton,
              Ed., "A One-Way Delay Metric for IP Performance Metrics
              (IPPM)", STD 81, RFC 7679, DOI 10.17487/RFC7679, January
              2016, <https://www.rfc-editor.org/info/rfc7679>.

   [RFC7680]  Almes, G., Kalidindi, S., Zekauskas, M., and A. Morton,
              Ed., "A One-Way Loss Metric for IP Performance Metrics
              (IPPM)", STD 82, RFC 7680, DOI 10.17487/RFC7680, January
              2016, <https://www.rfc-editor.org/info/rfc7680>.

   [RFC8175]  Ratliff, S., Jury, S., Satterwhite, D., Taylor, R., and B.
              Berry, "Dynamic Link Exchange Protocol (DLEP)", RFC 8175,
              DOI 10.17487/RFC8175, June 2017,
              <https://www.rfc-editor.org/info/rfc8175>.

   [RFC8548]  Bittau, A., Giffin, D., Handley, M., Mazieres, D., Slack,
              Q., and E. Smith, "Cryptographic Protection of TCP Streams
              (tcpcrypt)", RFC 8548, DOI 10.17487/RFC8548, May 2019,
              <https://www.rfc-editor.org/info/rfc8548>.

   [RFC8558]  Hardie, T., Ed., "Transport Protocol Path Signals",
              RFC 8558, DOI 10.17487/RFC8558, April 2019,
              <https://www.rfc-editor.org/info/rfc8558>.

   [RFC8684]  Ford, A., Raiciu, C., Handley, M., Bonaventure, O., and C.
              Paasch, "TCP Extensions for Multipath Operation with
              Multiple Addresses", RFC 8684, DOI 10.17487/RFC8684, March
              2020, <https://www.rfc-editor.org/info/rfc8684>.

   [RFC8803]  Bonaventure, O., Ed., Boucadair, M., Ed., Gundavelli, S.,
              Seo, S., and B. Hesmans, "0-RTT TCP Convert Protocol",
              RFC 8803, DOI 10.17487/RFC8803, July 2020,
              <https://www.rfc-editor.org/info/rfc8803>.

   [RFC9000]  Iyengar, J., Ed. and M. Thomson, Ed., "QUIC: A UDP-Based
              Multiplexed and Secure Transport", RFC 9000,
              DOI 10.17487/RFC9000, May 2021,
              <https://www.rfc-editor.org/info/rfc9000>.

   [RFC9049]  Dawkins, S., Ed., "Path Aware Networking: Obstacles to
              Deployment (A Bestiary of Roads Not Taken)", RFC 9049,
              DOI 10.17487/RFC9049, June 2021,
              <https://www.rfc-editor.org/info/rfc9049>.

   [RFC9097]  Morton, A., Geib, R., and L. Ciavattone, "Metrics and
              Methods for One-Way IP Capacity", RFC 9097,
              DOI 10.17487/RFC9097, November 2021,
              <https://www.rfc-editor.org/info/rfc9097>.

   [RFC9110]  Fielding, R., Ed., Nottingham, M., Ed., and J. Reschke,
              Ed., "HTTP Semantics", STD 97, RFC 9110,
              DOI 10.17487/RFC9110, June 2022,
              <https://www.rfc-editor.org/info/rfc9110>.

   [RFC9217]  Trammell, B., "Current Open Questions in Path-Aware
              Networking", RFC 9217, DOI 10.17487/RFC9217, March 2022,
              <https://www.rfc-editor.org/info/rfc9217>.

   [RFC9275]  Gao, K., Lee, Y., Randriamasy, S., Yang, Y., and J. Zhang,
              "An Extension for Application-Layer Traffic Optimization
              (ALTO): Path Vector", RFC 9275, DOI 10.17487/RFC9275,
              September 2022, <https://www.rfc-editor.org/info/rfc9275>.

   [RFC9298]  Schinazi, D., "Proxying UDP in HTTP", RFC 9298,
              DOI 10.17487/RFC9298, August 2022,
              <https://www.rfc-editor.org/info/rfc9298>.

   [RFC9439]  Wu, Q., Yang, Y., Lee, Y., Dhody, D., Randriamasy, S., and
              L. Contreras, "Application-Layer Traffic Optimization
              (ALTO) Performance Cost Metrics", RFC 9439,
              DOI 10.17487/RFC9439, August 2023,
              <https://www.rfc-editor.org/info/rfc9439>.

Acknowledgments

   Thanks to the Path Aware Networking Research Group for the discussion
   and feedback.  Specifically, thanks to Mohamed Boucadair for the
   detailed review, various text suggestions, and shepherding; thanks to
   Brian Trammell for suggesting the flow definition; and thanks to Luis
   M. Contreras, Spencer Dawkins, Paul Hoffman, Jake Holland, Colin
   Perkins, Adrian Perrig, and Matthias Rost for the reviews, comments,
   and suggestions.  Many thanks to Dave Oran for his careful IRSG
   review.

Authors' Addresses

   Reese Enghardt
   Netflix
   Email: ietf@tenghardt.net


   Cyrill Krähenbühl
   ETH Zürich
   Email: cyrill.kraehenbuehl@inf.ethz.ch