Internet Engineering Task Force (IETF) J. Rajamanickam, Ed.
Request for Comments: 9994 R. Gandhi, Ed.
Updates: 9789 Cisco Systems, Inc.
Category: Standards Track R. Zigler
ISSN: 2070-1721 Broadcom
H. Song
Futurewei Technologies
K. Kompella
Juniper Networks
June 2026
This document specifies the MPLS Network Action (MNA) Sub-Stack for carrying network actions and Ancillary Data (AD) in the MPLS label stack. MNA can be used to influence packet-forwarding decisions, carry additional Operations, Administration, and Maintenance (OAM) information in the MPLS packet, or perform user-defined operations.
この文書は、MPLS ラベル スタックでネットワーク アクションと補助データ (AD) を伝送するための MPLS ネットワーク アクション (MNA) サブスタックを指定します。MNA を使用すると、パケット転送の決定に影響を与えたり、MPLS パケットで追加の運用、管理、保守 (OAM) 情報を伝送したり、ユーザー定義の操作を実行したりできます。
This document updates RFC 9789 to refine the list of pieces of information that must be included in any document that defines an MNA.
この文書は RFC 9789 を更新し、MNA を定義する文書に含める必要がある情報のリストを改良します。
This is an Internet Standards Track document.
これはインターネット標準化トラックの文書です。
This document is a product of the Internet Engineering Task Force (IETF). It represents the consensus of the IETF community. It has received public review and has been approved for publication by the Internet Engineering Steering Group (IESG). Further information on Internet Standards is available in Section 2 of RFC 7841.
このドキュメントは Internet Engineering Task Force (IETF) の成果物です。これは IETF コミュニティのコンセンサスを表しています。この文書は公開レビューを受け、Internet Engineering Steering Group (IESG) によって公開が承認されています。インターネット標準の詳細については、RFC 7841 のセクション 2 を参照してください。
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/rfc9994.
この文書の現在のステータス、正誤表、およびそれに対するフィードバックの提供方法に関する情報は、https://www.rfc-editor.org/info/rfc9994 で入手できます。
Copyright (c) 2026 IETF Trust and the persons identified as the document authors. All rights reserved.
Copyright (c) 2026 IETF Trust および文書の著者として特定された人物。無断転載を禁じます。
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. Code Components extracted from this document must include Revised BSD License text as described in Section 4.e of the Trust Legal Provisions and are provided without warranty as described in the Revised BSD License.
この文書は、BCP 78 およびこの文書の発行日に有効な IETF 文書に関する IETF トラストの法的規定 (https://trustee.ietf.org/license-info) の対象となります。これらの文書には、この文書に関するお客様の権利と制限が記載されているため、注意深くお読みください。このドキュメントから抽出されたコード コンポーネントには、トラスト法的規定のセクション 4.e に記載されている改訂 BSD ライセンス テキストが含まれている必要があり、改訂 BSD ライセンスに記載されているように保証なしで提供されます。
1. Introduction
2. Conventions Used in This Document
2.1. Requirements Language
2.2. Abbreviations
2.3. Terminology
3. Overview
4. Label Stack Entry Formats
4.1. LSE Format A: The MNA Sub-Stack Indicator
4.2. LSE Format B: The Initial Opcode
4.3. LSE Format C: Subsequent Opcodes
4.4. LSE Format D: Additional Data
5. The MNA Sub-Stack
5.1. Opcodes
5.2. Ancillary Data
5.3. Scope
5.4. Unknown Network Action Handling
5.5. Ordering
6. Special Opcodes
6.1. bSPL Protection
6.2. Flag-Based NAIs Without AD
6.3. No-Operation Opcode
6.4. Extension Opcode
7. NAS Placement in the Label Stack
7.1. Actions When Pushing Labels
8. Node Capability Signaling
9. Processing the Network Action Sub-Stack
9.1. Encapsulating Node Responsibilities
9.2. Transit Node Responsibilities
9.3. Penultimate Node Responsibilities
9.4. Egress Node Responsibilities
10. Network Action Indicator Opcode Definition
11. Security Considerations
12. Operational Considerations
12.1. Manageability Considerations
12.2. Performance and Scale Considerations
12.3. Backward Compatibility
13. IANA Considerations
13.1. MNA bSPL Label
13.2. MPLS Network Actions Parameters
13.2.1. Network Action Flags Without Ancillary Data
13.2.2. Network Action Opcodes
14. References
14.1. Normative References
14.2. Informative References
Appendix A. Examples
A.1. Network Action Encoding Examples
A.1.1. Network Action Flags Without AD
A.1.2. Network Action Opcode with AD
A.1.3. Network Action Opcode with More AD with Format B
A.1.4. Network Action Opcode with More AD with Format C
A.2. Network Action Processing Order
A.2.1. Network Action Processing Order
Acknowledgments
Contributors
Authors' Addresses
[RFC3032] defines the encoding of the MPLS label stack, the basic structure used to define a forwarding path. There are applications that require MPLS packets to perform special network actions and carry optional Ancillary Data (AD) that can affect the packet-forwarding decision or trigger Operations, Administration, and Maintenance (OAM) logging, for example, as described in [RFC9791]. AD can be used to carry additional information, for example, for network slice purposes (see [RFC9791]).
[RFC3032] は、転送パスを定義するために使用される基本構造である MPLS ラベル スタックのエンコーディングを定義しています。たとえば、[RFC9791] で説明されているように、特別なネットワーク アクションを実行し、パケット転送の決定に影響を与えたり、運用、管理、保守 (OAM) ログをトリガーしたりできるオプションの補助データ (AD) を伝送するために、MPLS パケットを必要とするアプリケーションがあります。AD は、ネットワークスライスなどの目的で追加情報を運ぶために使用できます ([RFC9791] を参照)。
The requirements for in-stack network action and In-Stack Data (ISD) are described in [RFC9613].
スタック内ネットワークアクションとスタック内データ (ISD) の要件は [RFC9613] で説明されています。
This document defines the syntax and semantics of network actions and AD encoded in an MPLS label stack. In-stack actions and AD are contained in a Network Action Sub-Stack (NAS), which is recognized by a new base Special-Purpose Label (bSPL). This document follows the framework specified in [RFC9789].
この文書は、MPLS ラベル スタックでエンコードされたネットワーク アクションと AD の構文とセマンティクスを定義します。スタック内アクションと AD は、新しい基本特殊目的ラベル (bSPL) によって認識されるネットワーク アクション サブスタック (NAS) に含まれています。この文書は、[RFC9789] で指定されたフレームワークに従います。
Section 5 of [RFC9789] provides details about information that a document defining a network action must contain. Section 10 of this document updates [RFC9789] by providing a refined list of pieces of information that must be included in any document that defines an MNA.
[RFC9789] のセクション 5 には、ネットワークアクションを定義する文書に含める必要がある情報の詳細が記載されています。この文書のセクション 10 は、MNA を定義する文書に含める必要がある情報の詳細なリストを提供することにより、[RFC9789] を更新します。
The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in BCP 14 [RFC2119] [RFC8174] when, and only when, they appear in all capitals, as shown here.
このドキュメント内のキーワード「MUST」、「MUST NOT」、「REQUIRED」、「SHALL」、「SHALL NOT」、「SHOULD」、「SHOULD NOT」、「RECOMMENDED」、「NOT RECOMMENDED」、「MAY」、および「OPTIONAL」は、ここに示すようにすべて大文字で表示されている場合にのみ、BCP 14 [RFC2119] [RFC8174] で説明されているように解釈されます。
+==============+====================================+===============+
| Abbreviation | Meaning | Reference |
+==============+====================================+===============+
| AD | Ancillary Data | [RFC9613] |
+--------------+------------------------------------+---------------+
| bSPL | base Special-Purpose Label | [RFC9017] |
+--------------+------------------------------------+---------------+
| BoS | Bottom of Stack | [RFC9789] |
+--------------+------------------------------------+---------------+
| ECMP | Equal-Cost Multipath | [RFC6790] |
+--------------+------------------------------------+---------------+
| HbH | Hop-by-Hop | [RFC9789] |
+--------------+------------------------------------+---------------+
| I2E | Ingress to Egress | [RFC9789] |
+--------------+------------------------------------+---------------+
| IHS | I2E, HbH, or Select | This document |
+--------------+------------------------------------+---------------+
| ISD | In-Stack Data | [RFC9613] |
+--------------+------------------------------------+---------------+
| LSE | Label Stack Entry | [RFC9789] |
+--------------+------------------------------------+---------------+
| LSP | Label Switched Path | [RFC3031] |
+--------------+------------------------------------+---------------+
| MNA | MPLS Network Action | [RFC9789] |
+--------------+------------------------------------+---------------+
| NAI | Network Action Indicator | [RFC9613] |
+--------------+------------------------------------+---------------+
| NAL | Network Action Length | This document |
+--------------+------------------------------------+---------------+
| NAS | Network Action Sub-Stack | [RFC9789] |
+--------------+------------------------------------+---------------+
| NSI | Network Action Sub-Stack | This document |
| | Indicator | |
+--------------+------------------------------------+---------------+
| NASL | Network Action Sub-Stack | This document |
| | Length | |
+--------------+------------------------------------+---------------+
| OAM | Operations, Administration, | [RFC6291] |
| | and Maintenance | |
+--------------+------------------------------------+---------------+
| RLD | Readable Label Depth | [RFC9789] |
+--------------+------------------------------------+---------------+
| TC | Traffic Class | [RFC5462] |
+--------------+------------------------------------+---------------+
| TTL | Time to Live | [RFC3032] |
+--------------+------------------------------------+---------------+
Table 1: Abbreviations
表 1: 略語
The following terms are used in this document.
この文書では次の用語が使用されます。
MPLS Egress Node:
MPLS 出力ノード:
An MPLS edge node in its role in handling traffic as it leaves an MPLS domain [RFC3031].
MPLS エッジ ノードは、MPLS ドメインから離れるときにトラフィックを処理する役割を果たします [RFC3031]。
MPLS Ingress Node:
MPLS 入力ノード:
An MPLS edge node in its role in handling traffic as it enters an MPLS domain [RFC3031].
MPLS エッジ ノードは、MPLS ドメインに入るときにトラフィックを処理する役割を果たします [RFC3031]。
MPLS Domain:
MPLS ドメイン:
A contiguous set of nodes that operate MPLS routing and forwarding and that are also in one Routing or Administrative Domain [RFC3031].
MPLS ルーティングと転送を操作し、1 つのルーティング ドメインまたは管理ドメイン [RFC3031] 内にある連続したノードのセット。
Encapsulating Node:
カプセル化ノード:
A node that adds a NAS to the label stack.
ラベル スタックに NAS を追加するノード。
The MPLS NAS is a set of Label Stack Entries (LSEs) that appear as part of an MPLS label stack and serve to encode information about the network actions that should be invoked for the packet. Multiple NASes may appear in a label stack and be placed as described in Section 5.
MPLS NAS は、MPLS ラベル スタックの一部として表示される一連のラベル スタック エントリ (LSE) であり、パケットに対して呼び出されるネットワーク アクションに関する情報をエンコードする役割を果たします。複数の NAS がラベル スタックに表示され、セクション 5 で説明されているように配置される場合があります。
This document specifies how network actions and their optional AD are encoded as part of a NAS as a stack of LSEs. Mechanisms that allow sharing of AD between multiple network actions encoded in the same NAS can be described in other documents and do not rely on any explicit provision in the encodings described in this document.
この文書では、ネットワーク アクションとそのオプションの AD が、LSE のスタックとして NAS の一部としてエンコードされる方法を指定します。同じ NAS 内でエンコードされた複数のネットワーク アクション間で AD の共有を可能にするメカニズムは、他のドキュメントで説明できますが、このドキュメントで説明されているエンコーディングの明示的な規定には依存しません。
This document defines new LSE formats beyond those in [RFC3032] that define behaviors or are processed in different ways than MPLS labels as defined in [RFC3031]. Three new LSE formats are defined to carry 7 bits of network action opcodes and varying amounts of opcode-specific AD. Specifically, Format B LSE carries up to 13 bits of AD in an LSE. Format C LSE carries up to 20 bits of AD in an LSE. Format D LSE is used when additional AD is needed by the opcodes in Format B or Format C LSEs.
この文書は、動作を定義するか、[RFC3031] で定義されている MPLS ラベルとは異なる方法で処理される [RFC3032] のフォーマットを超える新しい LSE フォーマットを定義します。3 つの新しい LSE フォーマットは、7 ビットのネットワーク アクション オペコードとさまざまな量のオペコード固有の AD を伝送するように定義されています。具体的には、フォーマット B LSE は、LSE 内で最大 13 ビットの AD を伝送します。フォーマット C LSE は、LSE 内で最大 20 ビットの AD を伝送します。フォーマット D LSE は、フォーマット B またはフォーマット C LSE のオペコードによって追加の AD が必要な場合に使用されます。
As shown in Figure 1, the first LSE in an MNA Sub-Stack uses Format A. The second LSE uses Format B and is followed by a Format D LSE to carry additional data. Next, there may be a Format C LSE for an additional network action followed by another Format D LSE for additional data. Additional Format C and Format D LSEs may be added as needed for additional network actions and data.
図 1 に示すように、MNA サブスタックの最初の LSE はフォーマット A を使用します。2 番目の LSE はフォーマット B を使用し、その後に追加データを伝送するフォーマット D LSE が続きます。次に、追加のネットワーク アクション用のフォーマット C LSE があり、その後に追加データ用のフォーマット D LSE が続く場合があります。追加のネットワーク アクションとデータの必要に応じて、追加のフォーマット C およびフォーマット D LSE を追加できます。
0 1 2 3
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+--
| MNA-Label=bSPL | TC |S| TTL |A
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+--
| Opcode | 13-bit Data |R|IHS|S| NASL |U| NAL |B
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+--
|1| 22-bit Data |S| 8-bit Data |D*
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+--
| Opcode | 16-bit Data |S|4b Data|U| NAL |C
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+--
|1| 22-bit Data |S| 8-bit Data |D*
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+--
| Opcode | 16-bit Data |S|4b Data|U| NAL |C
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+--
~ ~
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+--
* Format D LSE presence indicated by NAL greater than one
Figure 1: An MNA Sub-Stack Encoding Example
図 1: MNA サブスタックのエンコーディング例
The NAS uses a variety of different formats of LSEs for different purposes. This section describes the syntax of the various formats while the overall structure of the NAS and the semantics of the various LSEs are described in the sections below.
NAS は、さまざまな目的にさまざまな形式の LSE を使用します。このセクションではさまざまな形式の構文について説明し、NAS の全体的な構造とさまざまな LSE のセマンティクスについては以下のセクションで説明します。
LSE Format A is an LSE as described in [RFC3032] and [RFC5462]. The label value is 4 for the MNA bSPL label from the "Base Special-Purpose MPLS Label Values" IANA registry (see Section 13.1) to indicate the presence of an MNA in the packet and the beginning of an MNA Sub-Stack in the label stack.
LSE フォーマット A は、[RFC3032] および [RFC5462] で説明されている LSE です。「Base Special-Purpose MPLS Label Values」IANA レジストリ (セクション 13.1 を参照) の MNA bSPL ラベルのラベル値は 4 で、パケット内の MNA の存在とラベル スタック内の MNA サブスタックの始まりを示します。
0 1 2 3
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| MNA-Label=bSPL | TC |S| TTL |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
Figure 2: LSE Format A: The MNA Sub-Stack Indicator
図 2: LSE フォーマット A: MNA サブスタック インジケーター
S (1 bit):
S(1ビット):
The BoS [RFC3032]. MUST be set to 0 on transmitted packets. If a packet is received with an LSE containing the bSPL (4) and with S bit set to 1, then the packet MUST be dropped.
BoS [RFC3032]。送信パケットでは 0 に設定しなければなりません。bSPL (4) を含む LSE で S ビットが 1 に設定されたパケットを受信した場合、そのパケットはドロップされなければなりません (MUST)。
LSE Format B is used to encode the first opcode in the NAS, plus a number of other fields about the NAS. The Data field of this LSE can carry up to 13 bits of AD.
LSE フォーマット B は、NAS の最初のオペコードと、NAS に関する他の多くのフィールドをエンコードするために使用されます。この LSE のデータ フィールドは、最大 13 ビットの AD を伝送できます。
0 1 2 3
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Opcode | 13-bit Data |R|IHS|S| NASL |U| NAL |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
Figure 3: LSE Format B: The Initial Opcode
図 3: LSE フォーマット B: 初期オペコード
Opcode (7 bits):
オペコード (7 ビット):
The operation code for this LSE. See Section 5.1.
この LSE のオペレーション コード。See Section 5.1.
Data (13 bits):
データ (13 ビット):
Opcode-specific AD.
オペコード固有の AD。
R (1 bit): Reserved.
R (1 ビット): 予約済み。
This bit MUST be set to zero on transmission and ignored upon receipt.
このビットは送信時にゼロに設定され、受信時には無視されなければなりません。
IHS (2 bits):
IHS (2ビット):
The scope of all the network actions in this NAS. See Section 5.3.
この NAS 内のすべてのネットワーク アクションの範囲。セクション 5.3 を参照してください。
S (1 bit):
S(1ビット):
The BoS [RFC3032]. If the NASL value is non-zero, then the S bit MUST be 0. If a packet is received with the S bit set to 1 and a non-zero NASL value, then the packet MUST be dropped. The encapsulating node MUST ensure that the S bit is set to 1 only in the last LSE in the MPLS header.
BoS [RFC3032]。NASL 値が 0 以外の場合、S ビットは 0 でなければなりません。S ビットが 1 に設定され、NASL 値が 0 以外の状態でパケットを受信した場合、パケットはドロップされなければなりません。カプセル化ノードは、MPLS ヘッダーの最後の LSE でのみ S ビットが 1 に設定されていることを保証しなければなりません (MUST)。
NASL (4 bits):
NASL (4 ビット):
The Network Action Sub-Stack Length. The number of Format C and Format D LSEs in the NAS, i.e., not including the leading Format A LSE and the Format B LSE.
ネットワークアクションのサブスタックの長さ。NAS 内のフォーマット C およびフォーマット D LSE の数。つまり、先頭のフォーマット A LSE およびフォーマット B LSE は含まれません。
U (1 bit):
U(1ビット):
Unknown Network Action Handling. See Section 5.4.
不明なネットワーク アクションの処理。セクション 5.4 を参照してください。
NAL (3 bits):
NAL (3 ビット):
Network Action Length. The number of LSEs of additional data, encoded in Format D LSEs (Section 4.4), following this Format B LSE. The NAL value MUST be less than or equal to the NASL value in the Format B LSE. If not, the packet MUST be dropped. A Format C LSE would be following when the NAL value is less than the NASL value.
ネットワークアクションの長さ。このフォーマット B LSE に続くフォーマット D LSE (セクション 4.4) でエンコードされた追加データの LSE の数。NAL 値は、フォーマット B LSE の NASL 値以下でなければなりません。そうでない場合、パケットはドロップされなければなりません。NAL 値が NASL 値より小さい場合、フォーマット C LSE が続きます。
LSE Format C is used to encode the subsequent opcodes in the NAS.
LSE フォーマット C は、NAS 内で後続のオペコードをエンコードするために使用されます。
0 1 2 3
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Opcode | 16-bit Data |S|4b Data|U| NAL |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
Figure 4: LSE Format C: Subsequent Opcodes
図 4: LSE フォーマット C: 後続のオペコード
Opcode (7 bits):
オペコード (7 ビット):
The operation code for this LSE. See Section 5.1.
この LSE のオペレーション コード。セクション 5.1 を参照してください。
Data (16 bits + 4 bits):
データ (16 ビット + 4 ビット):
Opcode-specific AD.
オペコード固有の AD。
S (1 bit):
S(1ビット):
The BoS [RFC3032]. If the NAL value is non-zero and if the S bit is set to 1, then the packet MUST be dropped. If this is not the last LSE in the NAS and if the S bit is set to 1, then the packet MUST be dropped. The encapsulating node MUST ensure that the S bit is set to 1 only in the last LSE.
BoS [RFC3032]。NAL 値がゼロ以外で、S ビットが 1 に設定されている場合、パケットはドロップされなければなりません (MUST)。これが NAS 内の最後の LSE ではなく、S ビットが 1 に設定されている場合、パケットはドロップされなければなりません (MUST)。カプセル化ノードは、最後の LSE でのみ S ビットが 1 に設定されるようにしなければなりません (MUST)。
U (1 bit):
U(1ビット):
Unknown Network Action Handling. See Section 5.4.
不明なネットワーク アクションの処理。セクション 5.4 を参照してください。
NAL (3 bits):
NAL (3 ビット):
Network Action Length. The number of LSEs of additional data, encoded in Format D LSEs (Section 4.4) following this Format C LSE. The NAL value MUST be less than or equal to the NASL value in the Format B LSE. If not, the packet MUST be dropped.
ネットワークアクションの長さ。このフォーマット C LSE に続くフォーマット D LSE (セクション 4.4) でエンコードされた追加データの LSE の数。NAL 値は、フォーマット B LSE の NASL 値以下でなければなりません。そうでない場合、パケットはドロップされなければなりません。
A Format A and a Format B LSE MUST be present when a Format C LSE is carried in the NAS.
フォーマット C LSE が NAS に搭載される場合、フォーマット A およびフォーマット B LSE が存在しなければなりません。
LSE Format D is used to encode additional data that did not fit in the LSE with the preceding opcode.
LSE フォーマット D は、前述のオペコードで LSE に収まらなかった追加データをエンコードするために使用されます。
0 1 2 3
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|1| 22-bit Data |S| 8-bit Data |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
Figure 5: LSE Format D: Additional Data
図 5: LSE フォーマット D: 追加データ
1 (1 bit):
1 (1 ビット):
The most significant bit MUST be set. This prevents legacy implementations from misinterpreting this LSE as containing a special purpose label if the data begins with zeros.
最上位ビットを設定する必要があります。これにより、データがゼロで始まる場合に、レガシー実装がこの LSE を特別な目的のラベルが含まれていると誤って解釈するのを防ぎます。
S (1 bit):
S(1ビット):
The BoS [RFC3032]. If this is not the last LSE for the network action based on the NAL value and if the S bit is set to 1, then the packet MUST be dropped. If this is not the last LSE in the NAS and if the S bit is set to 1, then the packet MUST be dropped. The encapsulating node MUST ensure that the S bit is set to 1 only in the last LSE.
BoS [RFC3032]。これが NAL 値に基づくネットワーク アクションの最後の LSE ではなく、S ビットが 1 に設定されている場合、パケットはドロップされなければなりません (MUST)。これが NAS 内の最後の LSE ではなく、S ビットが 1 に設定されている場合、パケットはドロップされなければなりません (MUST)。カプセル化ノードは、最後の LSE でのみ S ビットが 1 に設定されるようにしなければなりません (MUST)。
Data (22 bits + 8 bits):
データ (22 ビット + 8 ビット):
Opcode-specific AD.
オペコード固有の AD。
A Format A and a Format B LSE MUST be present when a Format D LSE is carried in the NAS.
フォーマット D LSE が NAS に搭載される場合、フォーマット A およびフォーマット B LSE が存在しなければなりません。
The MNA Sub-Stack MUST begin with a Format A LSE (Section 4.1). The label value of the LSE contains the MNA bSPL (4) to indicate the presence of the MNA Sub-Stack.
MNA サブスタックは、フォーマット A LSE (セクション 4.1) で始まらなければなりません (MUST)。LSE のラベル値には、MNA サブスタックの存在を示す MNA bSPL (4) が含まれています。
The TC and TTL values of the Format A LSE retain their semantics as defined in [RFC3032] and [RFC5462]. The TTL and TC values in the Format A LSE are copied from the forwarding label at the top of the label stack. The penultimate node on the path copies the TTL and TC values from the preceding LSE to the next LSE on the label stack, overwriting the TTL and TC values of the next LSE, as specified in Section 3.5 of [RFC3443] and Section 2.6.3 of [RFC3270] in the Uniform Mode LSPs. If the node performing this copy is not aware of MNA, this could overwrite the values in the Format A LSE of the NAS.
フォーマット A LSE の TC 値と TTL 値は、[RFC3032] および [RFC5462] で定義されているセマンティクスを保持します。フォーマット A LSE の TTL 値と TC 値は、ラベル スタックの最上位にある転送ラベルからコピーされます。パス上の最後から 2 番目のノードは、均一モード LSP の [RFC3443] のセクション 3.5 および [RFC3270] のセクション 2.6.3 で規定されているように、ラベル スタック上の前の LSE から次の LSE に TTL および TC 値をコピーし、次の LSE の TTL および TC 値を上書きします。このコピーを実行するノードが MNA を認識しない場合、NAS のフォーマット A LSE の値が上書きされる可能性があります。
The second LSE in a NAS MUST be a Format B LSE (Section 4.2). This LSE contains an initial opcode plus additional fields that describe the NAS.
NAS 内の 2 番目の LSE は、フォーマット B LSE でなければなりません (セクション 4.2)。この LSE には、初期オペコードに加えて、NAS を説明する追加フィールドが含まれています。
The Format B LSE (Section 4.2) could optionally carry additional data in Format D (Section 4.4) LSEs, up to the length encoded in the LSE's NAL value.
フォーマット B LSE (セクション 4.2) は、オプションで、LSE の NAL 値にエンコードされた長さまで、フォーマット D (セクション 4.4) LSE の追加データを伝送できます。
A NAS MAY contain more Format C (Section 4.3) and Format D (Section 4.4) LSEs, up to the length encoded in the NASL value. All Format D LSEs MUST follow a Format C or Format B LSE and be included in that LSE's NAL value.
NAS には、NASL 値にエンコードされた長さまで、さらに多くのフォーマット C (セクション 4.3) およびフォーマット D (セクション 4.4) の LSE を含めることができます (MAY)。すべてのフォーマット D LSE は、フォーマット C またはフォーマット B LSE に従い、その LSE の NAL 値に含まれなければなりません (MUST)。
The opcode is a 7-bit field that indicates the semantics of its LSE. Several opcodes are assigned special semantics (Section 6). Other opcodes act as NAIs and are assigned through IANA (see Sections 10 and 13.2.2).
オペコードは、その LSE のセマンティクスを示す 7 ビットのフィールドです。いくつかのオペコードには特別なセマンティクスが割り当てられています (セクション 6)。他のオペコードは NAI として機能し、IANA を通じて割り当てられます (セクション 10 および 13.2.2 を参照)。
The data field carries opcode-specific data that is AD for a network action. In the case of opcode 1, the data field carries Flag-Based NAIs without AD.
データ フィールドには、ネットワーク アクションの AD であるオペコード固有のデータが含まれます。オペコード 1 の場合、データ フィールドは AD なしでフラグベースの NAI を伝送します。
The label value (most significant 20 bits) in one or more consecutive LSEs is commonly used for load-balancing data flows in an ECMP environment. Modifying the first 20 bits in an LSE might alter a packet's path and result in out-of-order delivery of packets belonging to a given flow. To maintain the stability of deployed services in ECMP environments that rely on label value information for load-balancing, care must be taken when encoding network action data in the given LSE. If the network action data may differ among packets in the same flow or change during forwarding across the MPLS network, it MUST NOT be placed in the most significant 20 bits of a Format B LSE (Section 4.2), a Format C LSE (Section 4.3), or a Format D LSE (Section 4.4). Thus, the available bits for data that can change by a transit node or differ among packets of the same flow in Format A and Format B LSEs is 0, in a Format C LSE 7 (bits 20-22 and 25-28), and in a Format D LSE 11 (bits 20-22 and 24-31).
1 つ以上の連続する LSE のラベル値 (最上位 20 ビット) は、ECMP 環境でのデータ フローの負荷分散に通常使用されます。LSE の最初の 20 ビットを変更すると、パケットのパスが変更され、特定のフローに属するパケットの配信が順序どおりに行われない可能性があります。負荷分散のためにラベル値情報に依存する ECMP 環境でデプロイされたサービスの安定性を維持するには、特定の LSE でネットワーク アクション データをエンコードするときに注意する必要があります。ネットワークアクションデータが同じフロー内のパケット間で異なる可能性がある場合、または MPLS ネットワーク全体での転送中に変更される可能性がある場合、それをフォーマット B LSE (セクション 4.2)、フォーマット C LSE (セクション 4.3)、またはフォーマット D LSE (セクション 4.4) の最上位 20 ビットに配置してはなりません (MUST NOT)。したがって、フォーマット A およびフォーマット B LSE では、トランジット ノードによって変更される可能性がある、または同じフローのパケット間で異なる可能性があるデータに使用可能なビットは 0、フォーマット C LSE 7 (ビット 20 ~ 22 および 25 ~ 28)、およびフォーマット D LSE 11 (ビット 20 ~ 22 および 24 ~ 31) では、0 です。
Similarly, to preserve service stability, such data also MUST NOT be carried in the most significant 23 bits of these LSEs when the legacy implementation also uses the TC value, in addition to the label value, in all LSEs when computing ECMP decisions.
同様に、サービスの安定性を維持するために、レガシー実装が ECMP 決定を計算するときにすべての LSE でラベル値に加えて TC 値も使用する場合、そのようなデータをこれらの LSE の最上位 23 ビットで伝送してはなりません (MUST NOT)。
The available mitigations for these problems are to use additional Format D LSEs to carry the data or to place the data in Post-Stack Data as described in [RFC9789].
これらの問題に対する利用可能な軽減策は、[RFC9789] で説明されているように、追加のフォーマット D LSE を使用してデータを伝送するか、ポストスタック データにデータを配置することです。
In network deployments where it is known that a load-balancing of data flows is not used, or if only the explicitly signaled entropy value is used, and it is certain that the load-balancing path selection will not be based on the label value of the LSEs, then the data in the label value of the LSEs in the ISD MAY be mutable within the data flow without causing the out-of-order delivery of packets.
データ フローのロード バランシングが使用されないことがわかっているネットワーク展開、または明示的に通知されたエントロピー値のみが使用され、ロード バランシング パスの選択が LSE のラベル値に基づいていないことが確実な場合、ISD 内の LSE のラベル値のデータは、パケットの順序どおりの配信を引き起こすことなく、データ フロー内で変更可能であってもよい(MAY)。
The IHS field in the Format B LSE indicates the scope of all the NAIs encoded in the NAS. Scope defines which nodes along the MPLS path should perform the network actions found within the NAS. The specific values of the IHS field are as follows:
フォーマット B LSE の IHS フィールドは、NAS でエンコードされたすべての NAI の範囲を示します。スコープは、MPLS パス上のどのノードが NAS 内で見つかったネットワーク アクションを実行するかを定義します。IHS フィールドの具体的な値は次のとおりです。
+======+=========================+
| Bits | Scope |
+======+=========================+
| 00 | I2E |
+------+-------------------------+
| 01 | HbH |
+------+-------------------------+
| 10 | Select |
+------+-------------------------+
| 11 | Reserved for future use |
+------+-------------------------+
Table 2: IHS Scope Values
表 2: IHS 範囲の値
Ingress to Egress (I2E):
入力から出力へ (I2E):
The network actions in this NAS MUST NOT be processed by any node except the egress node.
この NAS のネットワーク アクションは、出力ノード以外のノードによって処理されてはなりません (MUST NOT)。
Hop-by-Hop (HbH):
ホップバイホップ (HbH):
All nodes along the path MUST process the NAS.
パス上のすべてのノードは NAS を処理しなければなりません。
Select:
選択してください:
Only specific nodes along the path that bring NAS to the top of the stack will perform the action.
NAS をスタックの最上位に置くパス上の特定のノードのみがアクションを実行します。
A given NAS can only carry NAIs with the same scope (I2E/HbH/Select). To support multiple scopes for a single packet, multiple NASes MAY be included in a single label stack.
特定の NAS は、同じスコープ (I2E/HbH/Select) の NAI のみを伝送できます。単一のパケットに対して複数のスコープをサポートするために、複数の NAS を単一のラベル スタックに含めることができます (MAY)。
The egress node is included in the HbH scope. This implies that the penultimate node MUST NOT remove a NAS with HbH scope. The egress node may receive a NAS at the top of the label stack as discussed in Section 9.4.
出口ノードは HbH スコープに含まれます。これは、最後から 2 番目のノードが HbH スコープを持つ NAS を削除してはいけないことを意味します。セクション9.4で説明したように、出口ノードはラベルスタックの最上位でNASを受け取る場合があります。
A NAS with I2E scope, if present, MUST be encoded after any HbH or Select scope NASes. This makes it easier for the transit nodes to process a NAS with HbH or Select scope.
I2E スコープを備えた NAS (存在する場合) は、HbH または Select スコープ NAS の後にエンコードする必要があります。これにより、トランジット ノードが HbH または Select スコープを使用して NAS を処理することが容易になります。
If a packet is received with the IHS scope set to "Reserved for future use", the packet is processed based on the U bit in the Format B LSE in the NAS.
IHS スコープが「将来の使用のために予約」に設定されたパケットを受信した場合、パケットは NAS のフォーマット B LSE の U ビットに基づいて処理されます。
The Unknown Network Action Handling (U) field in a Format B LSE (Section 4.2) and Format C LSE (Section 4.3) is a 1-bit value that defines the action to be taken by a node that does not understand an action within the NAS. The different types of Unknown Network Action Handling actions are defined below.
フォーマット B LSE (セクション 4.2) およびフォーマット C LSE (セクション 4.3) の Unknown Network Action Handling (U) フィールドは、NAS 内のアクションを理解できないノードが実行するアクションを定義する 1 ビットの値です。さまざまなタイプの不明なネットワーク アクション処理アクションを以下に定義します。
+=====+=====================+
| Bit | Action |
+=====+=====================+
| 0 | Skip to the next NA |
+-----+---------------------+
| 1 | Drop the packet |
+-----+---------------------+
Table 3: Unknown Network Action Handling
表 3: 不明なネットワーク アクションの処理
When a packet with an Unknown Network Action Handling is dropped, the node should maintain a local counter for this event and may send a rate-limited notification to the operator.
不明なネットワーク アクション処理を伴うパケットがドロップされた場合、ノードはこのイベントのローカル カウンタを維持する必要があり、レート制限された通知をオペレータに送信する場合があります。
The network actions encoded in the NAS MUST be processed in the order that they appear in the NAS, from the top of the NAS to the bottom. NAIs encoded as flags (see Section 6.2) MUST be processed from the most significant bit to the least significant bit. If a label stack contains multiple NASes, they MUST be processed in the order that they appear in the label stack, subject to the restrictions in Section 7.
NAS 内でエンコードされたネットワーク アクションは、NAS に表示される順序で、NAS の上部から下部まで処理されなければなりません。フラグとしてエンコードされた NAI (セクション 6.2 を参照) は、最上位ビットから最下位ビットまで処理されなければなりません (MUST)。ラベル スタックに複数の NAS が含まれる場合、セクション 7 の制限に従って、ラベル スタックに表示される順序で処理しなければなりません (MUST)。
Below are the special opcodes defined to build a basic in-stack MNA solution and assigned in the "Network Action Opcodes" IANA registry (see Section 13.2.2). In the future, additional special opcodes may be defined and their code points assigned from this registry.
以下は、基本的なスタック内 MNA ソリューションを構築するために定義され、「ネットワーク アクション オペコード」IANA レジストリに割り当てられた特別なオペコードです (セクション 13.2.2 を参照)。将来的には、追加の特別なオペコードが定義され、そのコード ポイントがこのレジストリから割り当てられる可能性があります。
Opcode:
オペコード:
0
0
Purpose:
目的:
Legacy implementations may scan the label stack looking for bSPL values. As long as the opcode field is non-zero, an LSE cannot be misinterpreted as containing a bSPL. Therefore, opcode 0 is reserved and not to be used.
従来の実装では、ラベル スタックをスキャンして bSPL 値を探す場合があります。opcode フィールドがゼロ以外である限り、LSE が bSPL を含むものとして誤って解釈されることはありません。したがって、オペコード 0 は予約されており、使用されません。
Opcode:
オペコード:
1
1
Purpose:
目的:
This opcode is used for network actions that do not require AD. A single flag can be used to indicate each of these network actions.
このオペコードは、AD を必要としないネットワーク アクションに使用されます。単一のフラグを使用して、これらのネットワーク アクションのそれぞれを示すことができます。
LSE Formats:
LSE フォーマット:
B, C, D
B、C、D
Data:
データ:
The data field carries NAIs, which should be evaluated from the most significant bit to the least significant bit. If this opcode is used with LSE Format B only, then up to 13 flags may be carried. If this opcode is used with LSE Format C only, then up to 20 flags may be carried. Format D LSEs can be used with Format C LSEs to encode more than 20 flags. Flags are assigned from the "Network Action Flags Without Ancillary Data" registry (Section 13.2.1). If flags need to be evaluated in a different order, multiple LSEs using this opcode may be used to specify the requested order. The Flag-Based NAIs MUST follow the procedure for data specified in Section 5.2.
データ フィールドには NAI が含まれており、最上位ビットから最下位ビットまで評価する必要があります。このオペコードが LSE フォーマット B のみで使用される場合、最大 13 個のフラグを伝送できます。このオペコードが LSE フォーマット C のみで使用される場合、最大 20 個のフラグを保持できます。フォーマット D LSE をフォーマット C LSE と一緒に使用すると、20 を超えるフラグをエンコードできます。フラグは、「補助データを含まないネットワーク アクション フラグ」レジストリ (セクション 13.2.1) から割り当てられます。フラグを別の順序で評価する必要がある場合は、このオペコードを使用する複数の LSE を使用して、要求された順序を指定できます。フラグベースの NAI は、セクション 5.2 で指定されたデータの手順に従わなければなりません (MUST)。
Scope:
範囲:
This opcode can be used with any scope.
このオペコードは任意のスコープで使用できます。
Opcode:
オペコード:
2
2
Purpose:
目的:
This opcode is used to indicate that it does not perform any network action and MUST be skipped.
このオペコードは、ネットワーク アクションを実行しないため、スキップしなければならないことを示すために使用されます。
LSE Format:
LSEフォーマット:
B
B
Scope:
範囲:
Any scope value may be set and MUST be ignored.
任意のスコープ値を設定できますが、無視しなければなりません (MUST)。
Opcode:
オペコード:
127
127
Purpose:
目的:
This opcode is used to extend the current opcode range beyond 127 in the future. If this opcode is not supported, then the packet with opcode 127 MUST be dropped regardless of the setting of the U bit. Use of this opcode is outside the scope of this document.
このオペコードは、現在のオペコード範囲を将来 127 を超えて拡張するために使用されます。このオペコードがサポートされていない場合、U ビットの設定に関係なく、オペコード 127 を持つパケットはドロップされなければなりません (MUST)。このオペコードの使用は、このドキュメントの範囲外です。
The node adding a NAS to the label stack places a copy of the NAS where the relevant nodes can read it. Each downstream node along the path has a Readable Label Depth (RLD). If the NAS is to be processed by a downstream MNA-capable node, then the entire NAS MUST be placed so that it is within RLD by the time the packet reaches the downstream MNA-capable node. The RLD of the downstream MNA-capable node MUST be learned as described in Section 2.3.1 of [RFC9789].
ラベル スタックに NAS を追加するノードは、関連するノードがそれを読み取ることができる場所に NAS のコピーを配置します。パスに沿った各下流ノードには、読み取り可能なラベル深さ (RLD) があります。NAS がダウンストリーム MNA 対応ノードによって処理される場合、パケットがダウンストリーム MNA 対応ノードに到達するまでに NAS 全体が RLD 内に収まるように配置する必要があります。下流の MNA 対応ノードの RLD は、[RFC9789] のセクション 2.3.1 の説明に従って学習しなければなりません (MUST)。
If the label stack is deep, several copies of the NAS may need to be encoded in the label stack.
ラベル スタックが深い場合、NAS のいくつかのコピーをラベル スタック内でエンコードする必要がある場合があります。
For a NAS with HbH scope, every node will process the top copy of the NAS. However, the NAS MUST NOT appear at the top of the stack at any MNA-incapable node on the path that is ensured by the encapsulating node using the node capability, as described in Section 8.
HbH スコープを備えた NAS の場合、すべてのノードが NAS の最上位コピーを処理します。ただし、NAS は、セクション 8 で説明されているように、ノード機能を使用してカプセル化ノードによって保証されるパス上の MNA 非対応ノードのスタックの最上位に表示されてはなりません (MUST NOT)。
A NAS MUST NOT appear at the top of the stack after popping the forwarding label on an MNA-incapable node on the path.
パス上の MNA 非対応ノードで転送ラベルをポップした後、NAS がスタックの最上位に表示されてはなりません。
The behavior of a node where a NAS with I2E and HbH scopes is also removed along with popping the forwarding label on a PHP node is outside the scope of this document.
I2E および HbH スコープを持つ NAS も削除され、PHP ノードで転送ラベルがポップされるノードの動作は、このドキュメントの範囲外です。
A NAS with Select scope is processed by the node that brings the NAS to the top of the stack (for example, in the case of using the MPLS label pop operation in Segment Routing); then, the NAS is removed from the stack. The Select scope NAS needs to be inserted after the forwarding label and before the next forwarding label. It could be inserted before or after a NAS with HbH scope. Note that the case of a NAS with Select scope with an MPLS label swap operation (for example, with RSVP-TE LSPs) is for future study.
選択スコープを持つ NAS は、NAS をスタックの最上位にするノードによって処理されます (たとえば、セグメント ルーティングで MPLS ラベル ポップ操作を使用する場合)。その後、NAS はスタックから削除されます。スコープの選択 NAS は、転送ラベルの後、次の転送ラベルの前に挿入する必要があります。HbH スコープを備えた NAS の前後に挿入できます。MPLS ラベル スワップ操作 (RSVP-TE LSP など) を使用する選択スコープを備えた NAS のケースは今後の検討課題であることに注意してください。
For a NAS with I2E scope, only one copy of the NAS needs to be added at the bottom of the stack.
I2E スコープの NAS の場合、スタックの一番下に追加する必要があるのは NAS のコピー 1 つだけです。
A transit node that is not the penultimate node that pops a forwarding label and exposes a copy of a NAS MUST remove that NAS.
転送ラベルをポップして NAS のコピーを公開する最後から 2 番目のノードではないトランジット ノードは、その NAS を削除しなければなりません (MUST)。
An MNA-capable node performing Penultimate Hop Popping (PHP) that pops the forwarding label with only the NAS(es) remaining on the stack MUST NOT remove the NAS(es). Instead, it forwards the packet with the NAS(es) at the top of the stack to the next node. Note that the behavior of the PHP node, as defined in [RFC3270] for TC processing and as defined in [RFC3443] for TTL processing, is not modified regardless of whether the PHP node supports MNA.
スタック上に NAS のみを残して転送ラベルをポップする、PHP (Penultimate Hop Popping) を実行する MNA 対応ノードは、NAS を削除してはなりません (MUST NOT)。代わりに、スタックの最上位にある NAS を持つパケットを次のノードに転送します。TC 処理については [RFC3270] で定義され、TTL 処理については [RFC3443] で定義されているように、PHP ノードの動作は、PHP ノードが MNA をサポートするかどうかに関係なく変更されないことに注意してください。
The node that receives the NAS at the top of the label stack MUST process and remove it.
ラベルスタックの最上位で NAS を受け取るノードは、NAS を処理して削除する必要があります。
An MNA-capable node may need to push additional labels as well as push new network actions onto a received packet.
MNA 対応ノードは、受信パケットに新しいネットワーク アクションをプッシュするだけでなく、追加のラベルをプッシュする必要がある場合があります。
While pushing additional labels onto the label stack of the received packet, the MNA-capable node MUST verify that the entire topmost NAS with HbH scope is still within the RLD of the downstream MNA-capable nodes. If required, the MNA-capable node MAY create a copy of the topmost NAS with HbH scope and insert it within the RLD of the downstream MNA-capable nodes on the label stack.
MNA 対応ノードは、受信パケットのラベル スタックに追加のラベルをプッシュする際、HbH スコープを持つ最上位の NAS 全体が依然として下流の MNA 対応ノードの RLD 内にあることを確認しなければなりません (MUST)。必要に応じて、MNA 対応ノードは、HbH スコープを持つ最上位の NAS のコピーを作成し、それをラベル スタック上の下流 MNA 対応ノードの RLD 内に挿入してもよい(MAY)。
When an MNA-capable node needs to push a new NAS with HbH scope on to a received packet that already has a NAS with HbH scope, it SHOULD copy (and merge) the network actions (including their AD) from the received topmost NAS with HbH scope in the new NAS with HbH scope. The new NAS MUST be placed within the RLD of the downstream MNA-capable nodes. This behavior can be based on local policy.
MNA 対応ノードが、HbH スコープを持つ新しい NAS を、すでに HbH スコープを持つ NAS を持つ受信パケットにプッシュする必要がある場合、受信した HbH スコープを持つ最上位の NAS からのネットワーク アクション (AD を含む) を、HbH スコープを持つ新しい NAS にコピー (およびマージ) する必要があります (SHOULD)。新しい NAS は、ダウンストリームの MNA 対応ノードの RLD 内に配置する必要があります。この動作はローカル ポリシーに基づいている可能性があります。
The new network actions added MUST NOT conflict with the network actions in the received NAS with HbH scope. The mechanism to resolve such conflicts depends on the network actions and can be based on local policy. The MNA-capable node that pushes entries MUST understand any network actions that it is pushing that may result in a conflict and MUST resolve any conflicts between new and received network actions. In the usual case of a conflict of duplicating a network action, the definition of a network action MUST give guidance on conflict resolution.
追加された新しいネットワーク アクションは、HbH スコープを持つ受信した NAS のネットワーク アクションと競合してはなりません。このような競合を解決するメカニズムはネットワークのアクションに依存し、ローカル ポリシーに基づいて行うことができます。エントリをプッシュする MNA 対応ノードは、競合を引き起こす可能性のあるプッシュしているネットワーク アクションを理解しなければならず (MUST)、新しいネットワーク アクションと受信したネットワーク アクション間の競合を解決しなければなりません (MUST)。ネットワークアクションの複製による競合の通常の場合、ネットワークアクションの定義は競合解決に関する指針を提供しなければなりません(MUST)。
The encapsulating node MUST make sure that the NAS can be processed by the transit and egress nodes. In addition, the encapsulated packet MUST NOT exceed the path MTU as described in [RFC3032].
カプセル化ノードは、NAS が通過ノードと出力ノードによって処理できることを確認しなければなりません。さらに、カプセル化されたパケットは、[RFC3032] に記載されているパス MTU を超えてはなりません (MUST NOT)。
* The node responsible for selecting a path through the MPLS network needs to know and consider the MNA-capabilities and RLD of the transit nodes as well as the MNA-capabilities of the egress node as described in Section 2.3 of [RFC9789].
* MPLS ネットワークを介したパスの選択を担当するノードは、[RFC9789] のセクション 2.3 で説明されているように、通過ノードの MNA 機能と RLD、さらに出口ノードの MNA 機能を知り、考慮する必要があります。
* Information about the capabilities of the nodes may be configured, collected through management protocols, or distributed by control protocols (such as advertising by routing protocols).
* ノードの機能に関する情報は、管理プロトコルを通じて構成、収集、または制御プロトコル (ルーティング プロトコルによる広告など) によって配布できます。
* The node responsible for selecting a path through the MPLS network learns about the capabilities of nodes using mechanisms that are out of scope for this document.
* MPLS ネットワークを介したパスの選択を担当するノードは、このドキュメントの範囲外であるメカニズムを使用してノードの機能を学習します。
* In the case of Segment Routing over MPLS (SR-MPLS), as well as the RLD, the path computation system needs to know the Maximum SID Depth (MSD) [RFC8664] that can be imposed at the ingress node of a given SR path. This ensures that the label stack depth of a computed path does not exceed the maximum number of labels (i.e., MSD) the node is capable of imposing and the maximum number of labels that can be read by the MNA-processing nodes in the path. The MSD MUST include the MNA Sub-Stacks that will be added.
* Segment Routing over MPLS (SR-MPLS) および RLD の場合、パス計算システムは、特定の SR パスの入口ノードに適用できる最大 SID 深さ (MSD) [RFC8664] を知っている必要があります。これにより、計算されたパスのラベル スタックの深さが、ノードが課すことができるラベルの最大数 (つまり、MSD) と、パス内の MNA 処理ノードによって読み取られるラベルの最大数を超えないことが保証されます。MSD には、追加される MNA サブスタックが含まれなければなりません。
* The encapsulating node MUST learn about the RLD of the nodes in the path as described in Section 2.3.1 of [RFC9789].
* カプセル化ノードは、[RFC9789] のセクション 2.3.1 で説明されているように、パス内のノードの RLD について学習しなければなりません (MUST)。
This section defines the specific responsibilities for nodes along an LSP [RFC3031].
このセクションでは、LSP [RFC3031] に沿ったノードの特定の責任を定義します。
The encapsulating node MAY add NASes to the label stack in accordance with its policies, the placement restrictions in Section 7, and the capabilities learned from Section 8.
カプセル化ノードは、そのポリシー、セクション 7 の配置制限、およびセクション 8 から学んだ機能に従って、ラベル スタックに NAS を追加してもよい(MAY)。
If there is an existing label stack, the encapsulating node MUST NOT modify the first 20 bits of any LSE in the label stack when the ECMP technique in the network uses hashing of the labels on the label stack.
既存のラベル スタックが存在する場合、ネットワークの ECMP 技術がラベル スタック上のラベルのハッシュを使用する場合、カプセル化ノードはラベル スタック内の LSE の最初の 20 ビットを変更してはなりません (MUST NOT)。
The transit node is the node that processes a NAS in the label stack but does not push any new NAS.
トランジット ノードは、ラベル スタック内の NAS を処理しますが、新しい NAS をプッシュしないノードです。
The transit node MUST follow the procedure for data specified in Section 5.2.
トランジットノードは、セクション 5.2 で指定されたデータの手順に従わなければなりません (MUST)。
Transit nodes MUST process the NASes in the label stack according to the rules set out in Section 5.5.
トランジットノードは、セクション 5.5 に定められたルールに従って、ラベルスタック内の NAS を処理しなければなりません (MUST)。
A transit node that processes a NAS and does not recognize the value of an opcode MUST follow the rules according to the setting of the Unknown Network Action Handling value in the NAS as described in Section 5.4.
NAS を処理し、オペコードの値を認識しないトランジット ノードは、セクション 5.4 で説明されているように、NAS の不明なネットワーク アクション処理値の設定に従ったルールに従わなければなりません (MUST)。
In addition to the transit node responsibilities, the penultimate node and penultimate SR-MPLS segment node MUST NOT remove the last copy of an HbH or I2E NAS when it is exposed after removing the forwarding (transport) label. This allows the egress node to process the NAS.
トランジット ノードの責任に加えて、最後から 2 番目のノードおよび最後から 2 番目の SR-MPLS セグメント ノードは、転送 (トランスポート) ラベルを削除した後に HbH または I2E NAS が公開された場合、その最後のコピーを削除してはなりません。これにより、出力ノードが NAS を処理できるようになります。
The egress node MUST remove any NAS it receives.
出口ノードは、受信した NAS を削除しなければなりません。
The following information MUST be defined for a new NAI opcode request in the document that specifies the network action. This updates the list found in Section 5 of [RFC9789] and should be used instead of that list.
次の情報は、ネットワークアクションを指定する文書内の新しい NAI オペコード要求に対して定義されなければなりません (MUST)。これは [RFC9789] のセクション 5 にあるリストを更新するものであり、そのリストの代わりに使用する必要があります。
Format:
形式:
The definition of the new network action MUST specify the LSE formats. The opcode can define the network action in Format B or C or both Formats B and C. Both Format B and C LSEs MAY optionally carry Format D LSEs.
新しいネットワーク アクションの定義では、LSE 形式を指定する必要があります。オペコードは、フォーマット B または C、またはフォーマット B と C の両方でネットワーク アクションを定義できます。フォーマット B と C の両方の LSE は、オプションでフォーマット D LSE を運ぶことができます。
Scope:
範囲:
The definition of the new network action MUST specify at least one scope (I2E, HbH, Select) for the network action and MAY specify more than one scope.
新しいネットワーク アクションの定義では、ネットワーク アクションに対して少なくとも 1 つのスコープ (I2E、HbH、Select) を指定しなければなりません (MUST)。また、複数のスコープを指定してもよいです。
Ancillary Data:
補助データ:
The definition of the new network action MUST specify the quantity, syntax, and semantics of any associated AD. The AD MAY be variable length, but the NAL MUST be computable based on the data added in the NAS.
新しいネットワーク アクションの定義では、関連付けられた AD の量、構文、およびセマンティクスを指定する必要があります。AD は可変長であってもよい (MAY) が、NAL は NAS に追加されたデータに基づいて計算可能でなければならない (MUST)。
Processing:
処理:
The definition of the new network action MUST specify the detailed procedure for processing the network action.
新しいネットワークアクションの定義では、ネットワークアクションを処理するための詳細な手順を指定しなければなりません。
Interactions:
インタラクション:
The definition of the new network action MUST specify its interaction including merging with other currently defined network action if there is any.
新しいネットワーク アクションの定義では、現在定義されている他のネットワーク アクション (存在する場合) とのマージを含む相互作用を指定する必要があります。
An assignment for a NAI MAY make requests from any combination of the "Network Action Opcodes" or "Network Action Flags Without Ancillary Data" assignments (see Section 13). This decision should optimize for eventual encoding efficiency. If the NAI does not require any AD, then a flag is preferred as only one bit is used in the encoding.
NAI の割り当ては、「ネットワーク アクション オペコード」または「補助データのないネットワーク アクション フラグ」割り当ての任意の組み合わせからリクエストを行ってもよい(セクション 13 を参照)。この決定により、最終的なエンコード効率が最適化されます。NAI が AD を必要としない場合は、エンコードで 1 ビットのみが使用されるため、フラグが推奨されます。
The security considerations in [RFC3032] and [RFC9789] also apply to this document.
[RFC3032] および [RFC9789] のセキュリティに関する考慮事項は、この文書にも適用されます。
In addition, MNA creates a new dimension in security concerns:
さらに、MNA はセキュリティ上の懸念に新たな次元をもたらします。
* The actions of an encapsulating node can affect any or all of the nodes along the path. In the most common and benign situations, a syntactically incorrect packet could result in packet loss or corruption, for example.
* カプセル化ノードのアクションは、パス上の任意のノードまたはすべてのノードに影響を与える可能性があります。最も一般的で問題のない状況では、構文的に正しくないパケットにより、パケットの損失や破損などが発生する可能性があります。
* The semantics of a network action are unbounded and may be insecure. A network action could be defined that makes arbitrary changes to the memory of the forwarding router, which could then be used by the encapsulating node to compromise every MNA-capable router in the network.
* ネットワーク アクションのセマンティクスには制限がなく、安全でない可能性があります。転送ルーターのメモリに任意の変更を加えるネットワーク アクションを定義すると、カプセル化ノードがその変更を使用して、ネットワーク内のすべての MNA 対応ルーターを侵害する可能性があります。
* The MNA architecture supports locally defined network actions. For such actions, there will be limited oversight to ensure that the semantics do not create security issues. Implementors and network operators will need to ensure that even the locally defined network actions do not compromise the security of the network by following the security considerations specified in this document.
* MNA アーキテクチャは、ローカルに定義されたネットワーク アクションをサポートします。このようなアクションについては、セマンティクスによってセキュリティ上の問題が発生しないことを保証するために、限定的な監視が行われます。実装者とネットワーク オペレータは、このドキュメントで指定されているセキュリティに関する考慮事項に従って、ローカルで定義されたネットワーク アクションであってもネットワークのセキュリティを侵害しないようにする必要があります。
* The MPLS domain border nodes MUST ensure that the MPLS packets with MNA from any domain with a different administrative control can be filtered to prevent entering the provider MPLS domain. The filtering capability MAY be enabled on a per-network-action basis, and it can be based on a local policy. The filtering capability MUST be implemented on those nodes before deploying MNA in the provider MPLS domain. The RLD on the filtering node MUST be higher than the RLD on all other nodes in the provider MPLS domain.
* MPLS ドメイン境界ノードは、異なる管理制御を持つドメインからの MNA を持つ MPLS パケットがプロバイダー MPLS ドメインに入らないようにフィルタリングできることを保証しなければなりません (MUST)。フィルタリング機能は、ネットワーク アクションごとに有効にすることができます (MAY)。また、ローカル ポリシーに基づいて有効にすることもできます。フィルタリング機能は、プロバイダー MPLS ドメインに MNA を展開する前に、これらのノードに実装する必要があります。フィルタリング ノードの RLD は、プロバイダ MPLS ドメイン内の他のすべてのノードの RLD よりも高くなければなりません。
* The MNA architecture supports modifying the AD on the intermediate nodes so the critical network functions either should not rely on the data or should be aware of the risks and use other means to verify the security of the whole network.
* MNA アーキテクチャは中間ノード上の AD の変更をサポートしているため、重要なネットワーク機能はデータに依存しないか、リスクを認識して他の手段を使用してネットワーク全体のセキュリティを検証する必要があります。
* System designers must be aware that information included in AD may be transmitted "in the clear". Network actions that require the exchange of sensitive data MUST be defined in such a way that the data is encrypted in transit. Otherwise, sensitive data MUST NOT be transmitted using these mechanisms.
* システム設計者は、AD に含まれる情報が「平文」で送信される可能性があることを認識する必要があります。機密データの交換を必要とするネットワーク アクションは、転送中にデータが暗号化されるような方法で定義しなければなりません。それ以外の場合は、これらのメカニズムを使用して機密データを送信してはなりません。
* Mis-delivery of a packet due to malformed forwarding action data could be considered a security risk.
* 不正な転送アクション データによるパケットの誤配信は、セキュリティ リスクとみなされる可能性があります。
An MNA implementation MAY collect the following counters:
MNA 実装は、次のカウンタを収集してもよい (MAY)。
* Packets with MNA received
* MNAを含むパケットを受信しました
* MNA Sub-Stacks processed
* 処理された MNA サブスタック
* MNA per-network-action counters
* MNA ネットワークアクションごとのカウンター
* Packets with MNA dropped due to unknown actions
* 不明なアクションにより MNA を含むパケットがドロップされる
* Packets with MNA skipped due to unknown actions
* 不明なアクションにより MNA を含むパケットがスキップされる
* Packets with MNA dropped due to malformed NAS
* 不正な形式の NAS により MNA を含むパケットがドロップされる
Additionally, tracking both successful invocations and failures for each specific network action is RECOMMENDED to provide granular visibility. Nodes MAY generate rate-limited notifications or alarms for significant operational events, such as sustained high rates of MNA packet drops or frequent encounters of malformed MNA Sub-Stacks, to alert operators to potential issues. Comprehensive logging of MNA processing details and outcomes can aid in the network diagnostics and post-mortem analysis.
さらに、詳細な可視性を提供するために、特定のネットワーク アクションごとに成功した呼び出しと失敗した呼び出しの両方を追跡することが推奨されます。ノードは、潜在的な問題についてオペレータに警告するために、継続的な高率の MNA パケットドロップや不正な MNA サブスタックの頻繁な遭遇などの重大な運用イベントに対して、レート制限された通知またはアラームを生成してもよい(MAY)。MNA 処理の詳細と結果の包括的なログは、ネットワーク診断と事後分析に役立ちます。
Performance and scale assessments are outside the scope of this document; the authors of any future MNA application documents are encouraged to address them.
パフォーマンスとスケールの評価は、このドキュメントの範囲外です。将来の MNA 申請書類の作成者は、それらに対処することが推奨されます。
This section discusses interactions between MNA-capable and MNA-incapable nodes.
このセクションでは、MNA 対応ノードと MNA 非対応ノード間の対話について説明します。
An MNA encapsulating node MUST ensure that the MPLS NAS is not at the top of the MPLS label stack when the packet arrives at an MNA-incapable node. If such a packet did arrive at an MNA-incapable node, it will most likely be dropped as described in Section 2.1.1 of [RFC7325].
MNA カプセル化ノードは、パケットが MNA 非対応ノードに到着するときに、MPLS NAS が MPLS ラベル スタックの最上位にないことを保証しなければなりません (MUST)。そのようなパケットが MNA 非対応ノードに到着した場合、[RFC7325] のセクション 2.1.1 で説明されているようにドロップされる可能性が高くなります。
Any node could scan the label stack, potentially looking for a label value containing a bSPL. To ensure that the LSE formats described herein do not appear to contain a bSPL value, the opcode value of 0 has been reserved. By ensuring that there is a non-zero value in the high-order 7 bits, we are assured that the high-order 20 bits cannot be misinterpreted as containing a bSPL value (0-15).
どのノードもラベル スタックをスキャンして、bSPL を含むラベル値を探す可能性があります。ここで説明する LSE フォーマットに bSPL 値が含まれていないようにするために、オペコード値 0 が予約されています。上位 7 ビットにゼロ以外の値が存在することを保証することで、上位 20 ビットが bSPL 値 (0 ~ 15) を含むものとして誤って解釈されないことが保証されます。
The TC and TTL values of the Format A LSE are not repurposed for encoding, as the penultimate node on the MPLS packet path may propagate TTL from the transport (or forwarding) label to the next label on the label stack, overwriting the TTL on the next label. If the penultimate node is a legacy node, it might perform this action, potentially corrupting other values stored in the TC and TTL values. To protect against this, we retain the TC and TTL values in the Format A LSE.
MPLS パケット パス上の最後から 2 番目のノードがトランスポート (または転送) ラベルからラベル スタック上の次のラベルに TTL を伝播し、次のラベルの TTL を上書きする可能性があるため、フォーマット A LSE の TC 値と TTL 値はエンコードには再利用されません。最後から 2 番目のノードがレガシー ノードである場合、このアクションが実行され、TC 値と TTL 値に格納されている他の値が破損する可能性があります。これを防ぐために、TC 値と TTL 値をフォーマット A LSE に保持します。
When adding the Entropy Label Indicator (ELI) (bSPL 7) and Entropy Label (EL) as defined in [RFC6790], along with an MNA NAS, the RLD MUST be considered for the placement of both, and they both can be placed in any order. If a transit LSR chooses to use as much of the whole label stack as feasible as a key for the load-balancing function, the MNA-reserved label MUST NOT be used as a key for the load-balancing function, as specified in Section 4.3 of [RFC6790]. Note that the behavior of an MNA-incapable transit LSR that scans the label stack for ELI and EL but encounters a different, unrecognized reserved label first, is not modified by this document.
MNA NAS とともに、[RFC6790] で定義されているエントロピー ラベル インジケーター (ELI) (bSPL 7) とエントロピー ラベル (EL) を追加する場合、両方の配置について RLD を考慮しなければならず (MUST)、両方を任意の順序で配置できます。トランジット LSR が負荷分散機能のキーとして可能な限りラベル スタック全体を使用することを選択した場合、[RFC6790] のセクション 4.3 に規定されているように、MNA が予約したラベルを負荷分散機能のキーとして使用してはなりません (MUST NOT)。ELI および EL のラベル スタックをスキャンするが、最初に異なる認識されていない予約ラベルに遭遇する MNA 非対応のトランジット LSR の動作は、このドキュメントでは変更されないことに注意してください。
Similarly, when adding the Flow-ID Label Indicator (FLI) (including the extension label 15) and Flow-ID Label (FL) as defined in [RFC9714], along with an MNA NAS, the RLD MUST be considered for the placement of both, and they both can be placed in any order. Note that the behavior of an MNA-incapable transit LSR that scans the label stack for FLI (including the extension label 15) and FL, but encounters a different, unrecognized reserved label first, is not modified by this document.
同様に、[RFC9714] で定義されている Flow-ID Label Indicator (FLI) (拡張ラベル 15 を含む) と Flow-ID Label (FL) を MNA NAS とともに追加する場合、両方の配置について RLD を考慮しなければならず (MUST)、両方を任意の順序で配置できます。FLI (拡張ラベル 15 を含む) および FL のラベル スタックをスキャンするが、最初に異なる認識されていない予約ラベルに遭遇する MNA 非対応トランジット LSR の動作は、この文書では変更されないことに注意してください。
However, as the existing behavior is not specified for transit LSRs, upon encountering any unrecognized bSPLs or extended SPLs (eSPLs) below the top of the label stack, some existing implementations may have chosen to implement non-standardized actions, such as discarding packets. Any uses of a new bSPL or eSPL would cause issues with such existing implementations using the non-standardized actions upon encountering unrecognized bSPLs or eSPLs below the top of the label stack. Since this is a generic problem, any clarifications for the treatment of unrecognized bSPL or eSPL are outside the scope of this document.
ただし、既存の動作はトランジット LSR に対して指定されていないため、ラベル スタックの最上位より下で認識されていない bSPL または拡張 SPL (eSPL) に遭遇すると、一部の既存の実装では、パケットの破棄などの非標準化アクションの実装を選択している可能性があります。新しい bSPL または eSPL を使用すると、ラベル スタックの最上部より下に認識されない bSPL または eSPL が発生したときに、標準化されていないアクションを使用する既存の実装で問題が発生します。これは一般的な問題であるため、認識されていない bSPL または eSPL の処理に関する説明は、この文書の範囲外です。
IANA has allocated the value 4 for the MNA bSPL label from the "Base Special-Purpose MPLS Label Values" registry to indicate the presence of an MNA Sub-Stack in the label stack. The description of the value is "MPLS Network Actions".
IANA は、ラベル スタック内の MNA サブスタックの存在を示すために、「Base Special-Purpose MPLS Label Values」レジストリから MNA bSPL ラベルに値 4 を割り当てました。値の説明は「MPLS ネットワーク アクション」です。
IANA has created a registry group called "MPLS Network Actions". This registry group contains the "Network Action Flags Without Ancillary Data" registry (see Section 13.2.1) and the "Network Action Opcodes" registry (see Section 13.2.2).
IANA は、「MPLS Network Actions」と呼ばれるレジストリ グループを作成しました。このレジストリ グループには、「補助データのないネットワーク アクション フラグ」レジストリ (セクション 13.2.1 を参照) および「ネットワーク アクション オペコード」レジストリ (セクション 13.2.2 を参照) が含まれています。
For the "Network Action Flags Without Ancillary Data" registry, registration requests should comply with Section 10. Depending on the range, the registration procedure for this registry is "IETF Review", "Experimental Use", or "Private Use" (as defined in [RFC8126]). The fields in this registry are "Bit Position" (integer), "Description" (string), and "Reference" (string).
「補助データを含まないネットワーク アクション フラグ」レジストリの場合、登録要求はセクション 10 に準拠する必要があります。範囲に応じて、このレジストリの登録手順は「IETF レビュー」、「実験的使用」、または ([RFC8126] で定義されている) 「私的使用」になります。このレジストリのフィールドは、「ビット位置」(整数)、「説明」(文字列)、および「参照」(文字列) です。
Bit Position refers to the position relative to the most significant bit in LSE Format B or C Data fields and any subsequent Format D LSEs. Bit Position 0 is the most significant bit in an LSE Format B or C Data field. Bit Position 20 is the most significant bit in the first LSE Format D Data field. There are 20 bits available in LSE Format C and 30 bits available in LSE Format D. There are, at most, 14 Format D LSEs per opcode (due to the NASL limit of 15 and the constraint of Format D requiring a Format C LSE), so there are at most 20 + 14 * 30 = 440 bit positions. The value listed in the Bit Position column is an integer with value between 0-439. The initial registry has no entries.
ビット位置とは、LSE フォーマット B または C データ フィールドおよび後続のフォーマット D LSE の最上位ビットに対する相対的な位置を指します。ビット位置 0 は、LSE フォーマット B または C データ フィールドの最上位ビットです。ビット位置 20 は、最初の LSE フォーマット D データ フィールドの最上位ビットです。LSE フォーマット C では 20 ビットが利用可能で、LSE フォーマット D では 30 ビットが利用可能です。オペコードごとに最大 14 のフォーマット D LSE が存在します (NASL 制限が 15 であることと、フォーマット C LSE を必要とするフォーマット D の制約のため)。つまり、最大 20 + 14 * 30 = 440 ビット位置があります。「ビット位置」列にリストされる値は、0 ~ 439 の整数です。初期レジストリにはエントリがありません。
The registration procedures for code point allocation for this registry are defined in Table 4:
このレジストリのコード ポイント割り当ての登録手順は、表 4 で定義されています。
+========+========================+
| Range | Registration Procedure |
+========+========================+
| 0-14 | IETF Review |
+--------+------------------------+
| 15-16 | Experimental Use |
+--------+------------------------+
| 17-19 | Private Use |
+--------+------------------------+
| 20-439 | IETF Review |
+--------+------------------------+
Table 4: Registration Procedures for the "Network Action Flags Without Ancillary Data" Registry
表 4: 「補助データを含まないネットワーク アクション フラグ」レジストリの登録手順
For the "Network Action Opcodes" registry, registration requests should comply with Section 10 as well as the Security Considerations section (Section 11). Depending on the range, the registration procedure for this registry is "IETF Review", "Experimental Use", or "Private Use" (as defined in [RFC8126]). The fields are "Opcode" (integer), "Description" (string), and "Reference" (string). Opcode is an integer with value 1-126.
「ネットワーク アクション オペコード」レジストリの場合、登録要求はセクション 10 およびセキュリティに関する考慮事項セクション (セクション 11) に準拠する必要があります。範囲に応じて、このレジストリの登録手順は「IETF レビュー」、「実験的使用」、または ([RFC8126] で定義されている) 「私的使用」のいずれかになります。フィールドは、「Opcode」(整数)、「Description」(文字列)、および「Reference」(文字列)です。オペコードは、値 1 ~ 126 の整数です。
+=========+========================+
| Range | Registration Procedure |
+=========+========================+
| 1-110 | IETF Review |
+---------+------------------------+
| 111-114 | Experimental Use |
+---------+------------------------+
| 115-126 | Private Use |
+---------+------------------------+
| 127 | IETF Review |
+---------+------------------------+
Table 5: Registration Procedures for the "Network Action Opcodes" Registry
表 5: 「ネットワーク アクション オペコード」レジストリの登録手順
IANA has allocated values for the following network action opcodes from the "Network Action Opcodes" registry.
IANA は、「ネットワーク アクション オペコード」レジストリから次のネットワーク アクション オペコードの値を割り当てました。
+========+===========================+===========+
| Opcode | Description | Reference |
+========+===========================+===========+
| 0 | Reserved | RFC 9994 |
+--------+---------------------------+-----------+
| 1 | Flag-Based Network Action | RFC 9994 |
| | Indicators without AD | |
+--------+---------------------------+-----------+
| 2 | No operation Opcode | RFC 9994 |
+--------+---------------------------+-----------+
| 127 | Opcode Range Extension | RFC 9994 |
| | Beyond 127 | |
+--------+---------------------------+-----------+
Table 6: Initial Contents of the "Network Action Opcodes" Registry
表 6: 「Network Action Opcodes」レジストリの初期内容
[RFC2119] Bradner, S., "Key words for use in RFCs to Indicate
Requirement Levels", BCP 14, RFC 2119,
DOI 10.17487/RFC2119, March 1997,
<https://www.rfc-editor.org/info/rfc2119>.
[RFC3032] Rosen, E., Tappan, D., Fedorkow, G., Rekhter, Y.,
Farinacci, D., Li, T., and A. Conta, "MPLS Label Stack
Encoding", RFC 3032, DOI 10.17487/RFC3032, January 2001,
<https://www.rfc-editor.org/info/rfc3032>.
[RFC3270] Le Faucheur, F., Ed., Wu, L., Davie, B., Davari, S.,
Vaananen, P., Krishnan, R., Cheval, P., and J. Heinanen,
"Multi-Protocol Label Switching (MPLS) Support of
Differentiated Services", RFC 3270, DOI 10.17487/RFC3270,
May 2002, <https://www.rfc-editor.org/info/rfc3270>.
[RFC3443] Agarwal, P. and B. Akyol, "Time To Live (TTL) Processing
in Multi-Protocol Label Switching (MPLS) Networks",
RFC 3443, DOI 10.17487/RFC3443, January 2003,
<https://www.rfc-editor.org/info/rfc3443>.
[RFC5462] Andersson, L. and R. Asati, "Multiprotocol Label Switching
(MPLS) Label Stack Entry: "EXP" Field Renamed to "Traffic
Class" Field", RFC 5462, DOI 10.17487/RFC5462, February
2009, <https://www.rfc-editor.org/info/rfc5462>.
[RFC6790] Kompella, K., Drake, J., Amante, S., Henderickx, W., and
L. Yong, "The Use of Entropy Labels in MPLS Forwarding",
RFC 6790, DOI 10.17487/RFC6790, November 2012,
<https://www.rfc-editor.org/info/rfc6790>.
[RFC8174] Leiba, B., "Ambiguity of Uppercase vs Lowercase in RFC
2119 Key Words", BCP 14, RFC 8174, DOI 10.17487/RFC8174,
May 2017, <https://www.rfc-editor.org/info/rfc8174>.
[RFC9017] Andersson, L., Kompella, K., and A. Farrel, "Special-
Purpose Label Terminology", RFC 9017,
DOI 10.17487/RFC9017, April 2021,
<https://www.rfc-editor.org/info/rfc9017>.
[RFC9789] Andersson, L., Bryant, S., Bocci, M., and T. Li, "MPLS
Network Actions (MNAs) Framework", RFC 9789,
DOI 10.17487/RFC9789, July 2025,
<https://www.rfc-editor.org/info/rfc9789>.
[RFC3031] Rosen, E., Viswanathan, A., and R. Callon, "Multiprotocol
Label Switching Architecture", RFC 3031,
DOI 10.17487/RFC3031, January 2001,
<https://www.rfc-editor.org/info/rfc3031>.
[RFC6291] Andersson, L., van Helvoort, H., Bonica, R., Romascanu,
D., and S. Mansfield, "Guidelines for the Use of the "OAM"
Acronym in the IETF", BCP 161, RFC 6291,
DOI 10.17487/RFC6291, June 2011,
<https://www.rfc-editor.org/info/rfc6291>.
[RFC7325] Villamizar, C., Ed., Kompella, K., Amante, S., Malis, A.,
and C. Pignataro, "MPLS Forwarding Compliance and
Performance Requirements", RFC 7325, DOI 10.17487/RFC7325,
August 2014, <https://www.rfc-editor.org/info/rfc7325>.
[RFC8126] Cotton, M., Leiba, B., and T. Narten, "Guidelines for
Writing an IANA Considerations Section in RFCs", BCP 26,
RFC 8126, DOI 10.17487/RFC8126, June 2017,
<https://www.rfc-editor.org/info/rfc8126>.
[RFC8664] Sivabalan, S., Filsfils, C., Tantsura, J., Henderickx, W.,
and J. Hardwick, "Path Computation Element Communication
Protocol (PCEP) Extensions for Segment Routing", RFC 8664,
DOI 10.17487/RFC8664, December 2019,
<https://www.rfc-editor.org/info/rfc8664>.
[RFC9613] Bocci, M., Ed., Bryant, S., and J. Drake, "Requirements
for Solutions that Support MPLS Network Actions (MNAs)",
RFC 9613, DOI 10.17487/RFC9613, August 2024,
<https://www.rfc-editor.org/info/rfc9613>.
[RFC9714] Cheng, W., Ed., Min, X., Ed., Zhou, T., Dai, J., and Y.
Peleg, "Encapsulation for MPLS Performance Measurement
with the Alternate-Marking Method", RFC 9714,
DOI 10.17487/RFC9714, February 2025,
<https://www.rfc-editor.org/info/rfc9714>.
[RFC9791] Saad, T., Makhijani, K., Song, H., and G. Mirsky, "Use
Cases for MPLS Network Action Indicators and Ancillary
Data", RFC 9791, DOI 10.17487/RFC9791, July 2025,
<https://www.rfc-editor.org/info/rfc9791>.
0 1 2 3
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| MNA-Label=bSPL | TC |S| TTL |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Opcode=1 | 13-bit Flags |R|IHS|S|NASL=0 |U|NAL=0|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
Figure 6: NAS with Network Action Flags
図 6: ネットワーク アクション フラグのある NAS
This is an example of a NAS with Flag-Based NAIs without AD.
これは、AD を使用しないフラグベース NAI を備えた NAS の例です。
Details:
詳細:
Opcode=1:
オペコード=1:
This opcode indicates that the LSE carries Flag-Based NAIs without AD.
このオペコードは、LSE が AD なしでフラグベースの NAI を伝送することを示します。
Data:
データ:
The data field carries the Flag-Based NAIs.
データフィールドにはフラグベースの NAI が含まれます。
S:
S:
This is the bottom of the stack bit. Set if and only if this LSE is the bottom of the stack.
これはスタック ビットの底部です。この LSE がスタックの最下位である場合にのみ設定します。
U:
U:
Action to be taken if one of the NAIs is not recognized by the processing node.
NAI の 1 つが処理ノードによって認識されない場合に実行されるアクション。
NASL:
NASL:
The NASL value is set to 0, as there are no additional LSEs.
追加の LSE がないため、NASL 値は 0 に設定されます。
NAL:
NAL:
The NAL value is set to 0, as there are no additional AD encoded using Format D.
フォーマット D を使用してエンコードされた追加の AD がないため、NAL 値は 0 に設定されます。
0 1 2 3
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| MNA-Label=bSPL | TC |S| TTL |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Opcode=2 | Data=0 |R|IHS|S|NASL=2 |U|NAL=0|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Opcode=1 | Flag-Based NAIs |S| NAIs |U|NAL=1|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|1| Additional Flag-Based NAIs |S|Flag-Based-NAIs|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
Figure 7: Network Action Flags Without AD Using LSE Format D
図 7: LSE フォーマット D を使用した AD なしのネットワーク アクション フラグ
In this example, the NAS contains a Format B LSE with a No-Operation Opcode value 2. The next LSE uses Format C, but the network action flag is not in a bit position contained within the Format C LSE, so a single Format D LSE has been added to the NAS to carry the flag.
この例では、NAS には No-Operation オペコード値 2 のフォーマット B LSE が含まれています。次の LSE はフォーマット C を使用しますが、ネットワーク アクション フラグはフォーマット C LSE 内に含まれるビット位置にないため、フラグを運ぶために 1 つのフォーマット D LSE が NAS に追加されています。
NAL is set to 1 to indicate that Flag-Based NAIs are also encoded in the next LSE.
NAL は 1 に設定され、フラグベース NAI も次の LSE でエンコードされることを示します。
NASL is set to 2 to indicate that two additional LSEs are used.
NASL は 2 に設定され、2 つの追加 LSE が使用されることを示します。
0 1 2 3
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| MNA-Label=bSPL | TC |S| TTL |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Opcode=8 | Ancillary Data |R|IHS|S|NASL=0 |U|NAL=0|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
Figure 8: Network Action Opcode with Ancillary Data
図 8: 補助データを含むネットワーク アクション オペコード
In this example, the NAS is carrying only one Network Action that requires 13 bits of AD.
この例では、NAS は 13 ビットの AD を必要とするネットワーク アクションを 1 つだけ伝送します。
Details on the second LSE:
2 番目の LSE の詳細:
Opcode=8:
オペコード=8:
A network action allocation is outside of this document.
ネットワーク アクションの割り当てについては、このドキュメントの対象外です。
Data:
データ:
The data field contains 13 bits of AD.
データフィールドには 13 ビットの AD が含まれます。
A network action may require more AD than can fit in a single LSE. In this example, a Format D LSE is added to carry additional AD.
ネットワーク アクションには、単一の LSE に収まりきらないより多くの AD が必要になる場合があります。この例では、追加の AD を伝送するためにフォーマット D LSE が追加されます。
0 1 2 3
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| MNA-Label=bSPL | TC |S| TTL |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Opcode=10 | Ancillary Data |R|IHS|S|NASL=1 |U|NAL=1|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|1| Ancillary Data |S|Ancillary Data |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
Figure 9: Network Action with Additional Ancillary Data
図 9: 追加の補助データを含むネットワーク アクション
In this example, opcode 10 is encoded in Format B, and it requires more than one LSE's worth of AD, so a Format D LSE is added.
この例では、オペコード 10 はフォーマット B でエンコードされており、複数の LSE に相当する AD が必要であるため、フォーマット D LSE が追加されます。
Details on the second LSE:
2 番目の LSE の詳細:
Opcode=10:
オペコード=10:
An opcode allocation is outside of this document.
オペコードの割り当てについては、このドキュメントの範囲外です。
Ancillary Data:
補助データ:
AD required to process the network action opcode 10.
AD はネットワーク アクション オペコード 10 を処理するために必要です。
NAL:
NAL:
Length of additional LSEs used to encode its AD.
AD をエンコードするために使用される追加の LSE の長さ。
Details on the third LSE:
3 番目の LSE の詳細:
Ancillary Data:
補助データ:
22 bits of additional AD.
22 ビットの追加 AD。
Ancillary Data:
補助データ:
8 bits of additional AD.
8 ビットの追加 AD。
A network action may require more AD than can fit in a single LSE. In this example, a Format D LSE is added to carry additional AD.
ネットワーク アクションには、単一の LSE に収まりきらないより多くの AD が必要になる場合があります。この例では、追加の AD を伝送するためにフォーマット D LSE が追加されます。
0 1 2 3
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| MNA-Label=bSPL | TC |S| TTL |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Opcode=2 | Data=0 |R|IHS|S|NASL=2 |U|NAL=0|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Opcode=9 | Ancillary Data |S| AD |U|NAL=1|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|1| Ancillary Data |S|Ancillary Data |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
Figure 10: Network Action with Additional Ancillary Data
図 10: 追加の補助データを含むネットワーク アクション
In this example, opcode 9 requires more than one LSE's worth of AD, so a Format D LSE is added.
この例では、オペコード 9 は複数の LSE に相当する AD を必要とするため、フォーマット D LSE が追加されます。
Details on the third LSE:
3 番目の LSE の詳細:
Opcode=9:
オペコード=9:
An opcode allocation is outside of this document.
オペコードの割り当てについては、このドキュメントの範囲外です。
Ancillary Data:
補助データ:
Most significant bits of AD.
AD の最上位ビット。
AD:
AD:
4 bits of additional AD.
4 ビットの追加 AD。
Details on the fourth LSE:
4 番目の LSE の詳細:
Ancillary Data:
補助データ:
22 bits of additional AD.
22 ビットの追加 AD。
Ancillary Data:
補助データ:
8 bits of additional AD.
8 ビットの追加 AD。
The semantics of a network action can vary widely and the results of processing one network action may affect the processing of a subsequent network action. See Section 5.5.
ネットワーク アクションのセマンティクスは大きく異なる可能性があり、1 つのネットワーク アクションの処理結果が後続のネットワーク アクションの処理に影響を与える可能性があります。セクション 5.5 を参照してください。
0 1 2 3
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| MNA-Label=bSPL | TC |S| TTL |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Opcode=8 | Ancillary Data |R|IHS|S|NASL=2 |U|NAL=0|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Opcode=7 | Ancillary Data7 |S| AD7 |U|NAL=0|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Opcode=1 | Flag-Based NAIs |S| NAI |U|NAL=0|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
Figure 11: In-Stack NA Processing Order
図 11: スタック内 NA の処理順序
In this example, opcode 8 is processed first, then opcode 7, and then the network action flags are processed from most significant to least significant.
この例では、オペコード 8 が最初に処理され、次にオペコード 7 が処理され、その後ネットワーク アクション フラグが最上位から最下位の順に処理されます。
In a different case, some Flag-Based NAIs may need to be processed before opcode 7, and some Flag-Based NAIs may need to be processed after opcode 7. This can be done by causing some NAIs to appear earlier in the NAS.
別のケースでは、一部のフラグベース NAI はオペコード 7 の前に処理する必要がある場合があり、一部のフラグベース NAI はオペコード 7 の後に処理する必要がある場合があります。これは、一部の NAI を NAS で以前に出現させることで実行できます。
0 1 2 3
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| MNA-Label=bSPL | TC |S| TTL |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Opcode=8 | Ancillary Data |R|IHS|S|NASL=3 |U|NAL=0|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Opcode=1 | 0x01 |S| NAI |U|NAL=0|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Opcode=7 | Ancillary Data7 |S| AD7 |U|NAL=0|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Opcode=1 | 0x02 |S| NAI |U|NAL=0|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
Figure 12: Interleaving Network Actions
図 12: インターリーブ ネットワーク アクション
In the above example, opcode 8 is processed first, then Flag-Based NAI 0x01 is processed, then opcode 7 is processed, and finally NAI 0x02 is processed.
上記の例では、オペコード 8 が最初に処理され、次にフラグベース NAI 0x01 が処理され、次にオペコード 7 が処理され、最後に NAI 0x02 が処理されます。
The authors of this document would like to thank the MPLS Working Group Open Design Team for the discussions and comments on this document. The authors would also like to thank Amanda Baber for reviewing the IANA Considerations and providing many useful suggestions. The authors would like to thank Loa Andersson, Stewart Bryant, Greg Mirsky, Joel M. Halpern, and Adrian Farrel for reviewing this document and providing many useful suggestions. The authors would like to thank Fabian Ihle and Michael Menth, both from the University of Tuebingen, for reviewing and implementing the solution defined in this document in P4 pipeline. Also, thank you to Tarek Saad for the Shepherd's review, Joe Clarke for the OpsDir review, Matthew Bocci for the Rtgdir review, Derrell Piper for the Secdir review, and James Guichard for the AD review, Mohamed Boucadair, Éric Vyncke, Deb Cooley, Ketan Talaulikar, and Mahesh Jethanandani for the IESG review, which helped improve this document.
このドキュメントの作成者は、このドキュメントに関する議論とコメントを提供してくれた MPLS ワーキング グループ オープン デザイン チームに感謝の意を表します。著者らは、IANA の考慮事項をレビューし、多くの有用な提案を提供してくれた Amanda Baber にも感謝したいと思います。著者らは、この文書をレビューし、多くの有用な提案を提供してくれた Loa Andersson、Stewart Bryant、Greg Mirsky、Joel M. Halpern、および Adrian Farrel に感謝します。著者らは、本書で定義されているソリューションを P4 パイプラインでレビューおよび実装していただいたテュービンゲン大学の Fabian Ihle 氏と Michael Menth 氏に感謝の意を表します。また、Shepherd のレビューについては Tarek Saad 氏、OpsDir のレビューについては Joe Clarke、Rtgdir のレビューについては Matthew Bocci、Secdir のレビューについては Derrell Piper、AD のレビューについては James Guichard、このドキュメントの改善に貢献した IESG のレビューについては Mohamed Boucadair、Éric Vyncke、Deb Cooley、Ketan Talaulikar、Mahesh Jethanandani に感謝します。
The following people have substantially contributed to this document:
以下の人々がこの文書に大きく貢献しました。
Jisu Bhattacharya
Cisco Systems, Inc.
Email: jisu@cisco.com
Bruno Decraene
Orange
Email: bruno.decraene@orange.com
Weiqiang Cheng
China Mobile
Email: chengweiqiang@chinamobile.com
Xiao Min
ZTE Corp.
Email: xiao.min2@zte.com.cn
Luay Jalil
Verizon
Email: luay.jalil@verizon.com
Jie Dong
Huawei Technologies
Huawei Campus, No. 156 Beiqing Rd.
Beijing
100095
China
Email: jie.dong@huawei.com
Tianran Zhou
Huawei Technologies
China
Email: zhoutianran@huawei.com
Bin Wen
Comcast
Email: Bin_Wen@cable.comcast.com
Sami Boutros
Ciena
Email: sboutros@ciena.com
Tony Li
Juniper Networks
United States of America
Email: tony.li@tony.li
John Drake
Juniper Networks
United States of America
Email: jdrake@juniper.net
Jaganbabu Rajamanickam (editor)
Cisco Systems, Inc.
Canada
Email: jrajaman@cisco.com
Rakesh Gandhi (editor)
Cisco Systems, Inc.
Canada
Email: rgandhi@cisco.com
Royi Zigler
Broadcom
Email: royi.zigler@broadcom.com
Haoyu Song
Futurewei Technologies
Email: haoyu.song@futurewei.com
Kireeti Kompella
Juniper Networks
United States of America
Email: kireeti.ietf@gmail.com