42
Configure Segment Routing over IPv6 (SRv6) Segment Routing for IPv6 (SRv6) is the implementation of Segment Routing over the IPv6 dataplane. Segment Routing over IPv6 Overview, on page 1 Configuring SRv6 IS-IS, on page 6 Configuring SRv6 IS-IS Flexible Algorithm, on page 7 Configuring SRv6 IS-IS TI-LFA, on page 10 Configuring SRv6 IS-IS Microloop Avoidance, on page 13 SRv6 Services: IPv4 L3VPN, on page 14 SRv6 Services: IPv6 L3VPN, on page 19 SRv6 Services: L3VPN VPNv4 Active-Standby Redundancy using Port-Active Mode, on page 25 SRv6 Services: L3VPN VPNv4 Active-Active Redundancy , on page 29 SRv6 Services: BGP Global IPv4, on page 30 SRv6 Services: BGP Global IPv6, on page 31 SRv6 Services: EVPN VPWS — All-Active Multi-Homing , on page 34 SRv6 Services: EVPN VPWS — IPv6 QoS Traffic-Class Marking, on page 36 SRv6 Services: SRv6 Services TLV Type 5 Support, on page 37 SRv6 SID Information in BGP-LS Reporting, on page 37 SRv6 OAM — SID Verification, on page 38 DHCPv4 Relay Agent and Proxy Support over SRv6, on page 40 DHCPv6 Relay Agent Support over SRv6, on page 41 Segment Routing over IPv6 Overview Segment Routing (SR) can be applied on both MPLS and IPv6 data planes. This feature extends Segment Routing support with IPv6 data plane. In an SR-MPLS enabled network, an MPLS label is used as the Segment Identifier (SID) and the source router chooses a path to the destination and encodes the path in the packet header as a stack of labels. However, in a Segment Routing over IPv6 (SRv6) network, an IPv6 address serves as the SID. The source router encodes the path to destination as an ordered list of segments (list of IPv6 addresses) in the IPv6 packet. To encode an ordered list of IPv6 addresses in an IPv6 packet, a new routing header which is an extension header is used. This new header for SRv6 is called Segment Routing Header (SRH). In an SRv6 enabled network, the active segment is indicated by the destination address of the packet, and the next segment is indicated by a pointer in the SRH. The following list explains the fields in SRH: • Next header—Identifies the type of header immediately following the SRH. Configure Segment Routing over IPv6 (SRv6) 1

Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

  • Upload
    others

  • View
    19

  • Download
    0

Embed Size (px)

Citation preview

Page 1: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

Configure Segment Routing over IPv6 (SRv6)

Segment Routing for IPv6 (SRv6) is the implementation of Segment Routing over the IPv6 dataplane.

• Segment Routing over IPv6 Overview, on page 1• Configuring SRv6 IS-IS, on page 6• Configuring SRv6 IS-IS Flexible Algorithm, on page 7• Configuring SRv6 IS-IS TI-LFA, on page 10• Configuring SRv6 IS-IS Microloop Avoidance, on page 13• SRv6 Services: IPv4 L3VPN, on page 14• SRv6 Services: IPv6 L3VPN, on page 19• SRv6 Services: L3VPN VPNv4 Active-Standby Redundancy using Port-Active Mode, on page 25• SRv6 Services: L3VPN VPNv4 Active-Active Redundancy , on page 29• SRv6 Services: BGP Global IPv4, on page 30• SRv6 Services: BGP Global IPv6, on page 31• SRv6 Services: EVPN VPWS— All-Active Multi-Homing , on page 34• SRv6 Services: EVPN VPWS— IPv6 QoS Traffic-Class Marking, on page 36• SRv6 Services: SRv6 Services TLV Type 5 Support, on page 37• SRv6 SID Information in BGP-LS Reporting, on page 37• SRv6 OAM— SID Verification, on page 38• DHCPv4 Relay Agent and Proxy Support over SRv6, on page 40• DHCPv6 Relay Agent Support over SRv6, on page 41

Segment Routing over IPv6 OverviewSegment Routing (SR) can be applied on both MPLS and IPv6 data planes. This feature extends SegmentRouting support with IPv6 data plane. In an SR-MPLS enabled network, anMPLS label is used as the SegmentIdentifier (SID) and the source router chooses a path to the destination and encodes the path in the packetheader as a stack of labels. However, in a Segment Routing over IPv6 (SRv6) network, an IPv6 address servesas the SID. The source router encodes the path to destination as an ordered list of segments (list of IPv6addresses) in the IPv6 packet. To encode an ordered list of IPv6 addresses in an IPv6 packet, a new routingheader which is an extension header is used. This new header for SRv6 is called Segment Routing Header(SRH). In an SRv6 enabled network, the active segment is indicated by the destination address of the packet,and the next segment is indicated by a pointer in the SRH.

The following list explains the fields in SRH:

• Next header—Identifies the type of header immediately following the SRH.

Configure Segment Routing over IPv6 (SRv6)1

Page 2: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

• Hdr Ext Len (header extension length)—The length of the SRH in 8-octet units, not including the first8 octets.

• Segments left—Specifies the number of route segments remaining. That means, the number of explicitlylisted intermediate nodes still to be visited before reaching the final destination.

• Last Entry—Contains the index (zero based) of the last element of the segment list.

• Flags— Contains 8 bits of flags.

• Tag—Tag a packet as part of a class or group of packets like packets sharing the same set of properties.

• Segment list—128-bit IPv6 addresses representing the nth segment in the segment list. The segment listencoding starts from the last segment of the SR policy (path). That means the first element of the segmentlist (Segment list [0]) contains the last segment of the SR policy, the second element contains thepenultimate segment of the SR policy and so on.

Each node along the SRv6 packet path has a different functionality:

• Source node—A node that can generate an IPv6 packet with an SRH (an SRv6 packet), or an ingressnode that can impose an SRH on an IPv6 packet.

• Transit node—A node along the path of the SRv6 packet (IPv6 packet and SRH). The transit node doesnot inspect the SRH. The destination address of the IPv6 packet does not correspond to the transit node.

• End point node—A node in the SRv6 domain where the SRv6 segment is terminated. The destinationaddress of the IPv6 packet with an SRH corresponds to the end point node. The segment endpoint nodeexecutes the function bound to the SID

Table 1: Example of a Segment Routing Header

Segments LeftRouting TypeHdr Ext LenNext Header

TagFlagsLast Entry

Segment List[0]

(128-bit IPv6 address)

. . .

Segment List[n]

(128-bit IPv6 address)

Optional Type Length Value objects (variable)

In SRv6, a SID represents a 128-bit value, consisting of the following three parts:

• Locator: This is the first part of the SID with most significant bits and represents an address of a specificSRv6 node.

• Function: This is the portion of the SID that is local to the owner node and designates a specific SRv6function (network instruction) that is executed locally on a particular node, specified by the locator bits.

• Args: This field is optional and represents optional arguments to the function.

The locator part can be further divided into two parts:

Configure Segment Routing over IPv6 (SRv6)2

Configure Segment Routing over IPv6 (SRv6)Segment Routing over IPv6 Overview

Page 3: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

• SID Block: This field is the SRv6 network designator and is a fixed or known address space for an SRv6domain. This is the most significant bit (MSB) portion of a locator subnet.

• Node Id: This field is the node designator in an SRv6 network and is the least significant bit (LSB) portionof a locator subnet.

Configuring SRv6

To enable SRv6 globally, you should first configure a locator with its prefix. The IS-IS protocol announcesthe locator prefix in IPv6 network and SRv6 applications (like ISIS, BGP) use it to allocate SIDs.

The following usage guidelines and restrictions apply while configuring SRv6.

• All routers in the SRv6 domain should have the same SID block (network designator) in their locator.

• The locator length should be 64-bits long.

• The SID block portion (MSBs) cannot exceed 40 bits. If this value is less than 40 bits, user shoulduse a pattern of zeros as a filler.

• The Node Id portion (LSBs) cannot exceed 24 bits.

• You can configure up to 8 locators to support SRv6 Flexible Algorithm. All locators prefix must sharethe same SID block (first 40-bits).

Enabling SRv6 with Locator

This example shows how to globally enable SRv6 and configure locator.Router(config)# segment-routing srv6Router(config-srv6)# locatorsRouter(config-srv6-locators)# locator myLoc1Router(config-srv6-locator)# prefix 2001:db8:0:a2::/64

(Optional) Configuring SRv6 Anycast Locator

An SRv6 Anycast locator is a type of locator that identifies a set of nodes (END SIDs). SRv6 Anycast Locatorsand their associated END SIDs may be provisioned at multiple places in a topology.

The set of nodes (Anycast group) is configured to advertise a shared Anycast locator and END SID. Anycastrouting enables the steering of traffic toward multiple advertising nodes. Packets addressed to an Anycastaddress are forwarded to the topologically nearest nodes.

One use case is to advertise Anycast END SIDs at exit points from an SRv6 network. Any of the nodes thatadvertise the common END SID could be used to forward traffic out of the SRv6 portion of the network tothe topologically nearest node.

Unlike a normal locator, IS-IS does not program or advertise END.X SIDs associated with an anycast locator.

END SIDs allocated fromAnycast locators will not be used in constructing TI-LFA backup paths orMicroloopAvoidance primary paths. TI-LFA backup and Microloop Avoidance paths for an Anycast locator prefix mayterminate on any node advertising that locator, which may be different from the node terminating the originalprimary path.

Note

Configure Segment Routing over IPv6 (SRv6)3

Configure Segment Routing over IPv6 (SRv6)Segment Routing over IPv6 Overview

Page 4: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

SRv6 anycast locators may have non-zero algorithm (Flexible Algorithm) values.Note

The following example shows how to globally enable SRv6 and configure Anycast locator.

For CiscoNCS 5500 Series Routers, youmust first use the hw-module profile segment-routing srv6 commandto enable SRv6 functionality. Then, reload the line card after enabling this command.

Note

Router(config)# hw-module profile segment-routing srv6Router(config)# segment-routing srv6Router(config-srv6)# locatorsRouter(config-srv6-locators)# locator myLoc1 anycastRouter(config-srv6-locator)# prefix 2001:db8:0:a2::/64

Optional: Configuring Encapsulation Parameters

This example shows how to configure encapsulation parameters when configuring SRv6. These optionalparameters include:

• Source Address of outer encapsulating IPv6 header: The default source address for encapsulation is oneof the loopback addresses.

• Hop Limit of outer encapsulating IPv6 header: The default value for hop-limit is 255.

Router(config)# segment-routing srv6Router(config-srv6)# encapsulation source-address 1::1Router(config-srv6)# hop-limit 60

Optional: Enabling Syslog Logging for Locator Status Changes

This example shows how to enable the logging of locator status.Router(config)# segment-routing srv6Router(config-srv6)# logging locator status

Verifying SRv6 Manager

This example shows how to verify the overall SRv6 state from SRv6 Manager point of view. The outputdisplays parameters in use, summary information, and platform specific capabilities.

Router# show segment-routing srv6 managerParameters:SRv6 Enabled: YesEncapsulation:Source Address:Configured: 1::1Default: 5::5

Hop-Limit: DefaultSummary:Number of Locators: 1 (1 operational)Number of SIDs: 4 (0 stale)Max SIDs: 64000OOR:Thresholds: Green 3200, Warning 1920Status: Resource Available (0 cleared, 0 warnings, 0 full)

Configure Segment Routing over IPv6 (SRv6)4

Configure Segment Routing over IPv6 (SRv6)Segment Routing over IPv6 Overview

Page 5: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

Platform Capabilities:SRv6: YesTILFA: YesMicroloop-Avoidance: NoEnd Functions:End (PSP)End.X (PSP)End.DX4End.DT4

Transit Functions:TT.Insert.RedT.Encaps.Red

Security rules:SEC-1SEC-2SEC-3SEC-4

Counters:CNT-1CNT-3

Signaled Parameters:Max-SL : 4Max-End-Pop-SRH : 4Max-T-Insert : 4Max-T-Encap : 5Max-End-D : 5

Max SIDs: 64000SID Holdtime: 30 mins

Verifying SRv6 Locator

This example shows how to verify the locator configuration and its operational status.

Router# show segment-routing srv6 locator myLoc1 detailName ID Prefix Status-------------------- ------- ------------------------ -------myLoc1* 5 2001:db8:0:a2::/64 Up(*): is-defaultInterface:Name: srv6-myLoc1IFH : 0x00000170IPv6 address: 2001:db8:0:a2::/64

Chkpt Obj ID: 0x2fc8Created: Apr 25 06:21:57.077 (00:03:37 ago)

Verifying SRv6 SIDs

This example shows how to verify the allocation of SRv6 local SIDs off locator(s).

Router# show segment-routing srv6 locator myLoc1 sid

SID Function Context OwnerState RW

-------------------------- ----------- ------------------------------ ----------------------- --

2001:db8:0:a2:1:: End (PSP) 'default':1 sidmgrInUse Y

2001:db8:0:a2:40:: End.DT4 'VRF1' bgp-100InUse Y

Configure Segment Routing over IPv6 (SRv6)5

Configure Segment Routing over IPv6 (SRv6)Segment Routing over IPv6 Overview

Page 6: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

2001:db8:0:a2:41:: End.X (PSP) [Hu0/1/0/1, Link-Local] isis-srv6InUse Y

The following example shows how to display detail information regarding an allocated SRv6 local SID.

Router# show segment-routing srv6 locator myLoc1 sid 2001:db8:0:a2:40:: detail

SID Function Context OwnerState RW

-------------------------- ----------- ------------------------------ ----------------------- --

2001:db8:0:a2:40:: End.DT4 'VRF1' bgp-100InUse Y

SID context: { table-id=0xe0000011 ('VRF1':IPv4/Unicast) }Locator: myLoc1'Allocation type: DynamicCreated: Feb 1 14:04:02.901 (3d00h ago)

Similarly, you can display SID information across locators by using the show segment-routing sid command.

show Commands

You can use the following show commands to verify the SRv6 global and locator configuration:

DescriptionCommand

Displays the summary information from SRv6manager, including platform capabilities.

show segment-routing srv6 manager

Displays the SRv6 locator information on the router.show segment-routing srv6 locator locator-name[detail]

Displays the information regarding SRv6 local SID(s)allocated from a given locator.

show segment-routing srv6 locator locator-namesid [[sid-ipv6-address [detail]

Displays SID information across locators. By default,only “active” (i.e. non-stale) SIDs are displayed.

show segment-routing srv6 sid [sid-ipv6-address |all | stale] [detail]

Displays all SRv6 local-SID prefixes in IPv6 RIB.show route ipv6 local-srv6

Configuring SRv6 IS-ISIntermediate System-to-Intermediate System (IS-IS) protocol already supports segment routing with MPLSdataplane (SR-MPLS). This feature enables extensions in IS-IS to support Segment Routing with IPv6 dataplane (SRv6). The extensions include advertising the SRv6 capabilities of nodes and node and adjacencysegments as SRv6 SIDs.

SRv6 IS-IS performs the following functionalities:

1. Interacts with SID Manager to learn local locator prefixes and announces the locator prefixes in the IGPdomain.

2. Learns remote locator prefixes from other IS-IS neighbor routers and installs the learned remote locatorIPv6 prefix in RIB or FIB.

Configure Segment Routing over IPv6 (SRv6)6

Configure Segment Routing over IPv6 (SRv6)Configuring SRv6 IS-IS

Page 7: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

3. Allocate or learn prefix SID and adjacency SIDs, create local SID entries, and advertise them in the IGPdomain.

SRv6 leverages longest-prefix-match IP forwarding.Massive-scale reachability can be achieved by summarizinglocators at ABRs and ASBRs. Use the summary-prefix locator [explicit] command in IS-IS address-familyconfiguration mode to specify that only locators from the specified algorithm contribute to the summary. Theexplicit keyword limits the contributing prefixes to only those belonging to the same algorithm.

Usage Guidelines and Restrictions

The following usage guidelines and restrictions apply for SRv6 IS-IS:

• An IS-IS address-family can support either SR-MPLS or SRv6, but both at the same time is not supported.

Configuring SRv6 IS-IS

To configure SRv6 IS-IS, enable SRv6 under the IS-IS IPv6 address-family. The following example showshow to configure SRv6 IS-IS.

Router(config)# router isis coreRouter(config-isis)# address-family ipv6 unicastRouter(config-isis-af)# summary-prefix 2001:0:1::/48Router(config-isis-af)# segment-routing srv6Router(config-isis-srv6)# locator myLoc1Router(config-isis-srv6-loc)# exit

Configuring SRv6 IS-IS Flexible AlgorithmThis feature introduces support for implementing Flexible Algorithm using IS-IS SRv6.

SRv6 Flexible Algorithm allows operators to customize IGP shortest path computation according to their ownneeds. An operator can assign custom SR prefix-SIDs to realize forwarding beyond link-cost-based SPF. Asa result, Flexible Algorithm provides a traffic engineered path automatically computed by the IGP to anydestination reachable by the IGP.

Restrictions and Usage Guidelines

The following restrictions and usage guidelines apply:

• You can configure up to 8 locators to support SRv6 Flexible Algorithm:

• All locators prefix must share the same SID block (first 40-bits).

• The Locator Algorithm value range is 128 to 255.

Configuring SRv6 IS-IS Flexible Algorithm

The following example shows how to configure SRv6 IS-IS Flexible Algorithm.

Configure Segment Routing over IPv6 (SRv6)7

Configure Segment Routing over IPv6 (SRv6)Configuring SRv6 IS-IS Flexible Algorithm

Page 8: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

Complete the Configuring SRv6 before performing these steps.Note

For CiscoNCS5500 Series Routers, youmust first use the hw-module profile segment-routing srv6 commandto enable SRv6 functionality. Then, reload the line card after enabling this command.

Note

Router(config)# hw-module profile segment-routing srv6

Router(config)# segment-routing srv6Router(config-srv6)# locatorsRouter(config-srv6-locators)# locator Loc1-BE // best-effortRouter(config-srv6-locator)# prefix 2001:db8:0:a2::/64Router(config-srv6-locator)# exitRouter(config-srv6-locators)# locator Loc1-LL // low latencyRouter(config-srv6-locator)# prefix 2001:db8:1:a2::/64Router(config-srv6-locator)# algorithm 128Router(config-srv6-locator)# exitRouter(config-srv6)# exit

Configuring SRv6 IS-IS

The following example shows how to configure SRv6 IS-IS.

Router(config)# router isis test-igpRouter(config-isis)# flex-algo 128Router(config-isis-flex-algo)# exitRouter(config-isis)# address-family ipv6 unicastRouter(config-isis-af)# summary-prefix 2001:db8:0::/48Router(config-isis-af)# summary-prefix 2001:db8:1::/48 algorithm 128 explicitRouter(config-isis-af)# segment-routing srv6Router(config-isis-srv6)# locator Loc1-BERouter(config-isis-srv6-loc)# exitRouter(config-isis-srv6)# locator Loc1-LLRouter(config-isis-srv6-loc)# exit

Configuring SRv6 IS-IS Prefix Summarization

SRv6 leverages longest-prefix-match IP forwarding.Massive-scale reachability can be achieved by summarizinglocators at ABRs and ASBRs. Use the summary-prefix locator [algorithm algo] [explicit] command inIS-IS address-family configuration mode to specify that only locators from the specified algorithm contributeto the summary. The explicit keyword limits the contributing prefixes to only those belonging to the samealgorithm.

The following example shows how to configure SRv6 IS-IS Algorithm Summarization for regular algorithmand Flexible Algorithm (128).

Router(config)# router isis test-igpRouter(config-isis)# flex-algo 128Router(config-isis-flex-algo)# exitRouter(config-isis)# address-family ipv6 unicastRouter(config-isis-af)# summary-prefix 2001:db8:0::/48Router(config-isis-af)# summary-prefix 2001:db8:1::/48 algorithm 128 explicit

Configure Segment Routing over IPv6 (SRv6)8

Configure Segment Routing over IPv6 (SRv6)Configuring SRv6 IS-IS Flexible Algorithm

Page 9: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

Router(config-isis-af)# segment-routing srv6Router(config-isis-srv6)# locator Loc1-BERouter(config-isis-srv6-loc)# exitRouter(config-isis-srv6)# locator Loc1-LLRouter(config-isis-srv6-loc)# exit

Enable Flexible Algorithm for Low Latency

The following example shows how to enable Flexible Algorithm for low-latency:

• IS-IS: Configure Flexible Algorithm definition with delay objective

• Performance-measurement: Configure static delay per interface

Router(config)# router isis test-igpRouter(config-isis)# flex-algo 128Router(config-isis-flex-algo)# metric-type delayRouter(config-isis-flex-algo)# exitRouter(config-isis)# interface GigabitEthernet0/0/0/0Router(config-isis-if)# address-family ipv6 unicastRouter(config-isis-if-af)# root

Router(config)# performance-measurementRouter(config-perf-meas)# interface GigabitEthernet0/0/0/0Router(config-pm-intf)# delay-measurementRouter(config-pm-intf-dm)# advertise-delay 100Router(config-pm-intf-dm)# commit

Verification

SRv6-LF1# show segment-routing srv6 locatorMon Aug 12 20:54:15.414 EDTName ID Algo Prefix Status-------------------- ------- ---- ------------------------ -------Loc1-BE 17 0 2001:db8:0:a2::/64 UpLoc1-LL 18 128 2001:db8:1:a2::/64 Up

SRv6-LF1# show isis flex-algo 128Mon Aug 12 21:00:54.282 EDT

IS-IS test-igp Flex-Algo Database

Flex-Algo 128:

Level-2:Definition Priority: 128Definition Source: SRv6-LF1.00, (Local)Definition Equal to Local: YesDisabled: No

Level-1:Definition Priority: 128Definition Source: SRv6-LF1.00, (Local)Definition Equal to Local: YesDisabled: No

Configure Segment Routing over IPv6 (SRv6)9

Configure Segment Routing over IPv6 (SRv6)Configuring SRv6 IS-IS Flexible Algorithm

Page 10: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

Local Priority: 128FRR Disabled: NoMicroloop Avoidance Disabled: No

Configuring SRv6 IS-IS TI-LFAThis feature introduces support for implementing Topology-Independent Loop-Free Alternate (TI-LFA) usingIS-IS SRv6.

TI-LFA provides link protection in topologies where other fast reroute techniques cannot provide protection.The goal of TI-LFA is to reduce the packet loss that results while routers converge after a topology changedue to a link failure. TI-LFA leverages the post-convergence path which is planned to carry the traffic andensures link and node protection within 50 milliseconds. TI-LFA with IS-IS SR-MPLS is already supported.

TI-LFA provides link, node, and Shared Risk Link Groups (SRLG) protection in any topology.

Usage Guidelines and Restrictions

The following usage guidelines and restrictions apply:

• TI-LFA provides link protection by default. Additional tiebreaker configuration is required to enablenode or SRLG protection.

• Usage guidelines for node and SRLG protection:

• TI-LFA node protection functionality provides protection from node failures. The neighbor nodeis excluded during the post convergence backup path calculation.

• Shared Risk Link Groups (SRLG) refer to situations in which links in a network share a commonfiber (or a common physical attribute). These links have a shared risk: when one link fails, otherlinks in the group might also fail. TI-LFA SRLG protection attempts to find the post-convergencebackup path that excludes the SRLG of the protected link. All local links that share any SRLG withthe protecting link are excluded.

• When you enable link protection, you can also enable node protection, SRLG protection, or both,and specify a tiebreaker priority in case there are multiple LFAs.

• Valid priority values are from 1 to 255. The lower the priority value, the higher the priority of therule. Link protection always has a lower priority than node or SRLG protection.

Configuring SRv6 IS-IS TI-LFA

The following example shows how to configure SRv6 IS-IS TI-LFA.

Complete the Configuring SRv6 before performing these steps.Note

Router(config)# router isis coreRouter(config-isis)# address-family ipv6 unicastRouter(config-isis-af)# segment-routing srv6Router(config-isis-srv6)# locator locator1Router(config-isis-srv6-loc)# exit

Configure Segment Routing over IPv6 (SRv6)10

Configure Segment Routing over IPv6 (SRv6)Configuring SRv6 IS-IS TI-LFA

Page 11: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

Router(config-isis)# interface loopback 0Router(config-isis-if)# passiveRouter(config-isis-if)# address-family ipv6 unicastRouter(config-isis-if-af)# exitRouter(config-isis)# interface bundle-ether 1201Router(config-isis-if)# address-family ipv6 unicastRouter(config-isis-if-af)# fast-reroute per-prefixRouter(config-isis-if-af)# fast-reroute per-prefix ti-lfaRouter(config-isis-if-af)# exitRouter(config-isis)# interface bundle-ether 1301Router(config-isis-if)# address-family ipv6 unicastRouter(config-isis-if-af)# fast-reroute per-prefixRouter(config-isis-if-af)# fast-reroute per-prefix ti-lfaRouter(config-isis-if-af)# fast-reroute per-prefix tiebreaker node-protecting index 100Router(config-isis-if-af)# fast-reroute per-prefix tiebreaker srlg-disjoint index 200Router(config-isis-if-af)# exit

Configuring SRv6 IS-IS TI-LFA with Flexible Algorithm

TI-LFA backup paths for particular Flexible Algorithm are computed using the same constraints as thecalculation of the primary paths for such Flexible Algorithm. These paths use Prefix-SIDs advertised specificallyfor such Flexible Algorithm in order to enforce a backup path.

The following example shows how to configure SRv6 IS-IS TI-LFA with Flexible Algorithm.

Router(config)# router isis coreRouter(config-isis)# flex-algo 128Router(config-isis-flex-algo)# exitRouter(config-isis)# address-family ipv6 unicastRouter(config-isis-af)# segment-routing srv6Router(config-isis-srv6)# locator locator1Router(config-isis-srv6-loc)# exitRouter(config-isis)# interface bundle-ether 1201Router(config-isis-if)# address-family ipv6 unicastRouter(config-isis-if-af)# fast-reroute per-prefixRouter(config-isis-if-af)# fast-reroute per-prefix ti-lfaRouter(config-isis-if-af)# exit

Use the fast-reroute disable command to disable the LFA calculation on a per-algorithm basis:Router(config)# router isis coreRouter(config-isis)# flex-algo 128Router(config-isis-flex-algo)# fast-reroute disable

Verification

This example shows how to verify the SRv6 IS-IS TI-LFA configuration using the show isis ipv6 fast-rerouteipv6-prefix detail command.

Router# show isis ipv6 fast-reroute cafe:0:0:66::/64 detailThu Nov 22 16:12:51.983 EST

L1 cafe:0:0:66::/64 [11/115] low priorityvia fe80::2, TenGigE0/0/0/6, SRv6-HUB6, Weight: 0Backup path: TI-LFA (link), via fe80::1, Bundle-Ether1201 SRv6-LF1, Weight: 0, Metric:

51P node: SRv6-TP8.00 [8::8], SRv6 SID: cafe:0:0:88:1:: End (PSP)Backup-src: SRv6-HUB6.00

P: No, TM: 51, LC: No, NP: No, D: No, SRLG: Yes

Configure Segment Routing over IPv6 (SRv6)11

Configure Segment Routing over IPv6 (SRv6)Configuring SRv6 IS-IS TI-LFA

Page 12: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

src SRv6-HUB6.00-00, 6::6

This example shows how to verify the SRv6 IS-IS TI-LFA configuration using the show route ipv6 ipv6-prefixdetail command.

Router# show route ipv6 cafe:0:0:66::/64 detailThu Nov 22 16:14:07.385 EST

Routing entry for cafe:0:0:66::/64Known via "isis srv6", distance 115, metric 11, type level-1Installed Nov 22 09:24:05.160 for 06:50:02Routing Descriptor Blocksfe80::2, from 6::6, via TenGigE0/0/0/6, ProtectedRoute metric is 11Label: NoneTunnel ID: NoneBinding Label: NoneExtended communities count: 0Path id:1 Path ref count:0NHID:0x2000a(Ref:11)NHID eid:0xffffffffffffffffBackup path id:65

fe80::1, from 6::6, via Bundle-Ether1201, Backup (TI-LFA)Repair Node(s): 8::8Route metric is 51Label: NoneTunnel ID: NoneBinding Label: NoneExtended communities count: 0Path id:65 Path ref count:1NHID:0x2000d(Ref:11)NHID eid:0xffffffffffffffffSRv6 Transit Type: T.Insert.RedSRv6 SID-list { cafe:0:0:88:1:: }MPLS eid:0x1380800000001

This example shows how to verify the SRv6 IS-IS TI-LFA configuration using the show cef ipv6 ipv6-prefixdetail location location command.

Router# show cef ipv6 cafe:0:0:66::/64 detail location 0/0/cpu0Thu Nov 22 17:01:58.536 ESTcafe:0:0:66::/64, version 1356, SRv6 Transit, internal 0x1000001 0x2 (ptr 0x8a4a45cc) [1],0x0 (0x8a46ae20), 0x0 (0x8c8f31b0)Updated Nov 22 09:24:05.166local adjacency fe80::2Prefix Len 64, traffic index 0, precedence n/a, priority 2gateway array (0x8a2dfaf0) reference count 4, flags 0x500000, source rib (7), 0 backups

[5 type 3 flags 0x8401 (0x8a395d58) ext 0x0 (0x0)]LW-LDI[type=3, refc=1, ptr=0x8a46ae20, sh-ldi=0x8a395d58]gateway array update type-time 1 Nov 22 09:24:05.163LDI Update time Nov 22 09:24:05.163LW-LDI-TS Nov 22 09:24:05.166via fe80::2/128, TenGigE0/0/0/6, 8 dependencies, weight 0, class 0, protected [flags

0x400]path-idx 0 bkup-idx 1 NHID 0x2000a [0x8a2c2fd0 0x0]next hop fe80::2/128via fe80::1/128, Bundle-Ether1201, 8 dependencies, weight 0, class 0, backup (TI-LFA)

[flags 0xb00]path-idx 1 NHID 0x2000d [0x8c2670b0 0x0]next hop fe80::1/128, Repair Node(s): 8::8local adjacency

Configure Segment Routing over IPv6 (SRv6)12

Configure Segment Routing over IPv6 (SRv6)Configuring SRv6 IS-IS TI-LFA

Page 13: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

SRv6 T.Insert.Red SID-list {cafe:0:0:88:1::}

Load distribution: 0 (refcount 5)

Hash OK Interface Address0 Y TenGigE0/0/0/6 fe80::2

This example shows how to verify the SRv6 IS-IS TI-LFA configuration using the show cef ipv6fast-reroute-db command.

Router# show cef ipv6 fast-reroute-dbSun Dec 9 20:23:08.111 EST

PROTECT-FRR: per-prefix [1, 0x0, 0x0, 0x98c83270]protect-interface: Te0/0/0/6 (0x208)protect-next-hop: fe80::2/128ipv6 nhinfo [0x977397d0]Update Time Dec 9 17:29:42.427

BACKUP-FRR: per-prefix [5, 0x0, 0x2, 0x98c83350]backup-interface: BE1201 (0x800002c)backup-next-hop: fe80::1/128ipv6 nhinfo [0x977396a0 protect-frr: 0x98c83270]

Update Time Dec 9 17:29:42.428

PROTECT-FRR: per-prefix [1, 0x0, 0x0, 0x98c830b0]protect-interface: BE1201 (0x800002c)protect-next-hop: fe80::1/128ipv6 nhinfo [0x977396a0]Update Time Dec 9 17:29:42.429

BACKUP-FRR: per-prefix [5, 0x0, 0x1, 0x98c83190]backup-interface: Te0/0/0/6 (0x208)backup-next-hop: fe80::2/128ipv6 nhinfo [0x977397d0 protect-frr: 0x98c830b0]

Update Time Dec 9 17:29:42.429

Configuring SRv6 IS-IS Microloop AvoidanceThis feature introduces support for implementing microloop avoidance using IS-IS SRv6.

Microloops are brief packet loops that occur in the network following a topology change (link down, link up,or metric change events). Microloops are caused by the non-simultaneous convergence of different nodes inthe network. If nodes converge and send traffic to a neighbor node that has not converged yet, traffic may belooped between these two nodes, resulting in packet loss, jitter, and out-of-order packets.

The SRv6 Microloop Avoidance feature detects if microloops are possible following a topology change. If anode computes that a microloop could occur on the new topology, the node creates a loop-free SR-TE policypath to the destination using a list of segments. After the RIB update delay timer expires, the SR-TE policyis replaced with regular forwarding paths.

Restrictions and Usage Guidelines

The following restrictions and usage guidelines apply:

Configure Segment Routing over IPv6 (SRv6)13

Configure Segment Routing over IPv6 (SRv6)Configuring SRv6 IS-IS Microloop Avoidance

Page 14: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

• The Routing Information Base (RIB) update delay value specifies the amount of time the node uses themicroloop avoidance policy before updating its forwarding table. The delay-time range is from 1 to 60000milliseconds; the default value is 5000.

Configuring SRv6 IS-IS Microloop Avoidance

The following example shows how to configure SRv6 IS-IS Microloop Avoidance and set the RoutingInformation Base (RIB) update delay value.

Complete the Configuring SRv6 before performing these steps.Note

Router(config)# router isis test-igpRouter(config-isis)# address-family ipv6 unicastRouter(config-isis-af)# microloop avoidance segment-routingRouter(config-isis-af)# microloop avoidance rib-update-delay 2000Router(config-isis-af)# commit

Configuring SRv6 IS-IS Microloop Avoidance with Flexible Algorithm

Microloop Avoidance paths for particular Flexible Algorithm are computed using the same constraints as thecalculation of the primary paths for such Flexible Algorithm. These paths use Prefix-SIDs advertised specificallyfor such Flexible Algorithm in order to enforce a microloop avoidance path.

The following example shows how to configure SRv6 IS-IS Microloop Avoidance with Flexible Algorithm.Router(config)# segment-routing srv6Router(config-srv6)# locatorsRouter(config-srv6-locators)# locator myLoc1Router(config-srv6-locator)# prefix 2001:db8:1:a2::/64Router(config-srv6-locator)# algorithm 128Router(config-srv6-locator)# root

Router(config)# router isis test-uloopRouter(config-isis)# flex-algo 128Router(config-isis-flex-algo)# exitRouter(config-isis)# address-family ipv6 unicastRouter(config-isis-af)# microloop avoidance segment-routingRouter(config-isis-af)# segment-routing srv6Router(config-isis-srv6)# locator myLoc1Router(config-isis-srv6-loc)# commit

Use the microloop avoidance disable command to disable the microloop calculation on a per-algorithmbasis:Router(config)# router isis test-tilfaRouter(config-isis)# flex-algo 128Router(config-isis-flex-algo)# microloop avoidance disable

SRv6 Services: IPv4 L3VPNThe SRv6-based IPv4 L3VPN feature enables deployment of IPv4 L3VPN over a SRv6 data plane.Traditionally, it was done over an MPLS-based system. SRv6-based L3VPN uses SRv6 Segment IDs (SIDs)

Configure Segment Routing over IPv6 (SRv6)14

Configure Segment Routing over IPv6 (SRv6)SRv6 Services: IPv4 L3VPN

Page 15: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

for service segments instead of labels. SRv6-based L3VPN functionality interconnects multiple sites toresemble a private network service over public infrastructure. To use this feature, youmust configure SRv6-base.

For this feature, BGP allocates an SRv6 SID from the locator space, configured under SRv6-base and VPNv4address family. For more information on this, refer Segment Routing over IPv6 Overview, on page 1. TheBGP SID can be allocated in the following ways:

• Per-VRF mode that provides End.DT4 support. End.DT4 represents the Endpoint with decapsulationand IPv4 table lookup.

• Per-CE mode that provides End.DX4 cross connect support. End.DX4 represents the Endpoint withdecapsulation and IPv4 cross-connect.

BGP encodes the SRv6 SID in the prefix-SID attribute of the IPv4 L3VPN Network Layer ReachabilityInformation (NLRI) and advertises it to IPv6 peering over an SRv6 network. The Ingress PE (provider edge)router encapsulates the VRF IPv4 traffic with the SRv6 VPN SID and sends it over the SRv6 network.

Restrictions and Usage Guidelines

• MPLS L3VPN and SRv6 L3VPN interworking is not supported.

• Equal-Cost Multi-path (ECMP) and Unequal Cost Multipath (UCMP) are supported.

• BGP, OSPF, Static are supported as PE-CE protocol.

Configuring SRv6 based IPv4 L3VPN

To enable SRv6-based L3VPN, you need to configure SRv6 under BGP and SID allocation mode. Thefollowing example shows how to configure SRv6-based L3VPN:

/*Configure SRv6 locator name under BGP Global*/RP/0/0/CPU0:Router(config)# router bgp 100RP/0/0/CPU0:Router(config-bgp)# bgp router-id 10.6.6.6RP/0/0/CPU0:Router(config-bgp)# segment-routing srv6RP/0/0/CPU0:Router(config-bgp-srv6)# locator my_locatorRP/0/0/CPU0:Router(config-bgp-srv6)# exit

/*Configure SRv6 locator under VRF All under VPNv4 AFI*/RP/0/0/CPU0:Router(config)# router bgp 100RP/0/0/CPU0:Router(config-bgp)# bgp router-id 10.6.6.6RP/0/0/CPU0:Router(config-bgp)# address-family vpnv4 unicastRP/0/0/CPU0:Router(config-bgp-af)# vrf allRP/0/0/CPU0:Router(config-bgp-af-vrfall)# segment-routing srv6RP/0/0/CPU0:Router(config-bgp-af-vrfall-srv6)# locator my_locatorRP/0/0/CPU0:Router(config-bgp-af-vrfall-srv6)# exit

/*Configure a VRF with per-vrf label allocation mode*/RP/0/0/CPU0:Router(config-bgp-af)# vrf vrf1RP/0/0/CPU0:Router(config-bgp-vrf)# rd 106:1RP/0/0/CPU0:Router(config-bgp-vrf)# address-family ipv4 unicastRP/0/0/CPU0:Router(config-bgp-vrf-af)# segment-routing srv6RP/0/0/CPU0:Router(config-bgp-vrf-af-srv6)# alloc mode per-vrfRP/0/0/CPU0:Router(config-bgp-vrf-af-srv6)# exitRP/0/0/CPU0:Router(config-bgp-vrf-af)# exitRP/0/0/CPU0:Router(config-bgp-vrf)# neighbor 10.1.2.2RP/0/0/CPU0:Router(config-bgp-vrf-nbr)# remote-as 100RP/0/0/CPU0:Router(config-bgp-vrf-nbr)# address-family ipv4 unicast

Configure Segment Routing over IPv6 (SRv6)15

Configure Segment Routing over IPv6 (SRv6)SRv6 Services: IPv4 L3VPN

Page 16: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

/*Configure a VRF with per-ce label allocation mode*/RP/0/0/CPU0:Router(config-bgp-af)# vrf vrf2RP/0/0/CPU0:Router(config-bgp-vrf)# rd 106:2RP/0/0/CPU0:Router(config-bgp-vrf)# address-family ipv4 unicastRP/0/0/CPU0:Router(config-bgp-vrf-af)# segment-routing srv6RP/0/0/CPU0:Router(config-bgp-vrf-af-srv6)# alloc mode per-ceRP/0/0/CPU0:Router(config-bgp-vrf-af-srv6)# exitRP/0/0/CPU0:Router(config-bgp-vrf-af)# exitRP/0/0/CPU0:Router(config-bgp-vrf)# neighbor 10.1.2.2RP/0/0/CPU0:Router(config-bgp-vrf-nbr)# remote-as 100RP/0/0/CPU0:Router(config-bgp-vrf-nbr)# address-family ipv4 unicast

Verification

The following example shows how to verify the SRv6 based L3VPN configuration using the showsegment-routing srv6 sid command.

In this example, End.X represents Endpoint function with Layer-3 cross-connect, End.DT4 represents Endpointwith decapsulation and IPv4 table lookup, and End.DX4 represents Endpoint with decapsulation and IPv4cross-connect.RP/0/0/CPU0:SRv6-Hub6# show segment-routing srv6 sid*** Locator: 'my_locator' ***SID Function Context Owner

State RW-------------------------- ----------- ------------------------------ ----------------------- --

cafe:0:0:66:1:: End (PSP) 'my_locator':1 sidmgrInUse Y

cafe:0:0:66:40:: End.X (PSP) [Te0/0/0/2, Link-Local] isis-srv6InUse Y

cafe:0:0:66:41:: End.X (PSP) [BE6801, Link-Local] isis-srv6InUse Y

cafe:0:0:66:42:: End.X (PSP) [BE5601, Link-Local] isis-srv6InUse Y

cafe:0:0:66:43:: End.X (PSP) [BE5602, Link-Local] isis-srv6InUse Y

cafe:0:0:66:44:: End.DT4 'VRF1' bgp-100InUse Y

cafe:0:0:66:45:: End.DT4 'VRF2' bgp-100InUse Y

cafe:0:0:66:46:: End.DX4 'VRF2’:3 bgp-100InUse Y

cafe:0:0:66:47:: End.DX4 'VRF2’:4 bgp-100InUse Y

The following example shows how to verify the SRv6 based L3VPN configuration using the showsegment-routing srv6SID-prefixdetail command.

RP/0/RP0/CPU0:SRv6-Hub6# show segment-routing srv6 sid cafe:0:0:66:44:: detailSun Dec 9 16:52:54.015 EST*** Locator: ‘my_locator' ***SID Function Context Owner

State RW-------------------------- ----------- ------------------------------ ----------------------- --

cafe:0:0:66:44:: End.DT4 'VRF1' bgp-100InUse Y

SID context: { table-id=0xe0000001 ('VRF1':IPv4/Unicast) }Locator: ‘my_locator'Allocation type: Dynamic

Configure Segment Routing over IPv6 (SRv6)16

Configure Segment Routing over IPv6 (SRv6)SRv6 Services: IPv4 L3VPN

Page 17: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

Created: Dec 8 16:34:32.506 (1d00h ago)

RP/0/RP0/CPU0:SRv6-Hub6# show segment-routing srv6 sid cafe:0:0:66:47:: detailSun Dec 9 16:54:26.073 EST*** Locator: 'my_locator' ***SID Function Context Owner

State RW-------------------------- ----------- ------------------------------ ----------------------- --

cafe:0:0:66:47:: End.DX4 'VRF2’:4 bgp-100InUse Y

SID context: { table-id=0xe0000002 ('VRF2':IPv4/Unicast), nh-set-id=4 }Locator: ‘my_locator'Allocation type: DynamicCreated: Dec 9 16:49:44.714 (00:04:41 ago)

The following example shows how to verify the SRv6 based L3VPN configuration using the show bgp vpnv4unicast rdroute-distinguisher/prefix command on Egress PE.

RP/0/RP0/CPU0:SRv6-Hub6# sh bgp vpnv4 unicast rd 106:1 10.15.0.0/30Wed Nov 21 16:08:44.765 ESTBGP routing table entry for 10.15.0.0/30, Route Distinguisher: 106:1Versions:Process bRIB/RIB SendTblVerSpeaker 2282449 2282449SRv6-VPN SID: cafe:0:0:66:44::/128

Last Modified: Nov 21 15:50:34.235 for 00:18:10Paths: (2 available, best #1)Advertised to peers (in unique update groups):2::2

Path #1: Received by speaker 0Advertised to peers (in unique update groups):2::2

20010.1.2.2 from 10.1.2.2 (10.7.0.1)Origin IGP, localpref 200, valid, internal, best, group-best, import-candidateReceived Path ID 0, Local Path ID 1, version 2276228Extended community: RT:201:1

Path #2: Received by speaker 0Not advertised to any peer20010.2.2.2 from 10.2.2.2 (10.20.1.2)Origin IGP, localpref 100, valid, internalReceived Path ID 0, Local Path ID 0, version 0Extended community: RT:201:1

The following example shows how to verify the SRv6 based L3VPN configuration using the show bgp vpnv4unicast rdroute-distinguisher prefix command on Ingress PE.

RP/0/RP0/CPU0:SRv6-LF1# show bgp vpnv4 unicast rd 106:1 10.15.0.0/30Wed Nov 21 16:11:45.538 ESTBGP routing table entry for 10.15.0.0/30, Route Distinguisher: 106:1Versions:Process bRIB/RIB SendTblVerSpeaker 2286222 2286222

Last Modified: Nov 21 15:47:26.288 for 00:24:19Paths: (1 available, best #1)Not advertised to any peerPath #1: Received by speaker 0Not advertised to any peer200, (received & used)6::6 (metric 24) from 2::2 (6.6.6.6)Received Label 3

Configure Segment Routing over IPv6 (SRv6)17

Configure Segment Routing over IPv6 (SRv6)SRv6 Services: IPv4 L3VPN

Page 18: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

Origin IGP, localpref 200, valid, internal, best, group-best, import-candidate,not-in-vrf

Received Path ID 1, Local Path ID 1, version 2286222Extended community: RT:201:1Originator: 6.6.6.6, Cluster list: 2.2.2.2SRv6-VPN-SID: T1-cafe:0:0:66:44:: [total 1]

The following example shows how to verify the SRv6 based L3VPN configuration using the show routevrfvrf-name/prefixdetail command.

RP/0/RP0/CPU0:SRv6-LF1# show route vrf VRF1 10.15.0.0/30 detailWed Nov 21 16:35:17.775 ESTRouting entry for 10.15.0.0/30Known via "bgp 100", distance 200, metric 0Tag 200, type internalInstalled Nov 21 16:35:14.107 for 00:00:03Routing Descriptor Blocks6::6, from 2::2Nexthop in Vrf: "default", Table: "default", IPv6 Unicast, Table Id: 0xe0800000Route metric is 0Label: NoneTunnel ID: NoneBinding Label: NoneExtended communities count: 0Source RD attributes: 0x0000:106:1NHID:0x0(Ref:0)SRv6 Transit Type: T.Encaps.RedSRv6 SID-list { cafe:0:0:66:44:: }MPLS eid:0x1380600000001

Route version is 0xd (13)No local labelIP Precedence: Not SetQoS Group ID: Not SetFlow-tag: Not SetFwd-class: Not SetRoute Priority: RIB_PRIORITY_RECURSIVE (12) SVD Type RIB_SVD_TYPE_REMOTEDownload Priority 3, Download Version 3038384No advertising protos.

The following example shows how to verify the SRv6 based L3VPN configuration for per-ce allocation modeusing the show bgp vrfvrf-namenexthop-set command.

RP/0/RP0/CPU0:SRv6-Hub6# show bgp vrf VRF2 nexthop-setWed Nov 21 15:52:17.464 ESTResilient per-CE nexthop set, ID 3Number of nexthops 1, Label 0, Flags 0x2200SRv6-VPN SID: cafe:0:0:66:46::/128Nexthops:10.1.2.2Reference count 1,Resilient per-CE nexthop set, ID 4Number of nexthops 2, Label 0, Flags 0x2100SRv6-VPN SID: cafe:0:0:66:47::/128Nexthops:10.1.2.210.2.2.2Reference count 2,

The following example shows how to verify the SRv6 based L3VPN configuration using the show cefvrfvrf-name prefix detail locationline-card command.

RP/0/RP0/CPU0:SRv6-LF1# show cef vrf VRF1 10.15.0.0/30 detail location 0/0/cpu0

Configure Segment Routing over IPv6 (SRv6)18

Configure Segment Routing over IPv6 (SRv6)SRv6 Services: IPv4 L3VPN

Page 19: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

Wed Nov 21 16:37:06.894 EST151.1.0.0/30, version 3038384, SRv6 Transit, internal 0x5000001 0x0 (ptr 0x9ae6474c) [1],0x0 (0x0), 0x0 (0x8c11b238)Updated Nov 21 16:35:14.109Prefix Len 30, traffic index 0, precedence n/a, priority 3gateway array (0x8cd85190) reference count 1014, flags 0x2010, source rib (7), 0 backups

[1 type 3 flags 0x40441 (0x8a529798) ext 0x0 (0x0)]LW-LDI[type=0, refc=0, ptr=0x0, sh-ldi=0x0]gateway array update type-time 1 Nov 21 14:47:26.816LDI Update time Nov 21 14:52:53.073Level 1 - Load distribution: 0[0] via cafe:0:0:66::/128, recursivevia cafe:0:0:66::/128, 7 dependencies, recursive [flags 0x6000]path-idx 0 NHID 0x0 [0x8acb53cc 0x0]next hop VRF - 'default', table - 0xe0800000next hop cafe:0:0:66::/128 via cafe:0:0:66::/64SRv6 T.Encaps.Red SID-list {cafe:0:0:66:44::}Load distribution: 0 (refcount 1)Hash OK Interface Address0 Y Bundle-Ether1201 fe80::2

SRv6 Services: IPv6 L3VPNTable 2: Feature History Table

Feature DescriptionRelease InformationFeature Name

With this feature, the egress PE cansignal an SRv6 Service SID withthe BGP overlay service route. Theingress PE encapsulates theIPv4/IPv6 payload in an outer IPv6header where the destinationaddress is the SRv6 Service SIDprovided by the egress PE. BGPmessages between PEs carry SRv6Service SIDs as a means tointerconnect PEs and form VPNs.

Release 7.2.2SRv6 Services: IPv6 L3VPN

Building on RFC4364 "BGP/MPLS IP Virtual Private Networks (VPNs)", this feature provides IPv6 L3VPNs(VPNv6) over an SRv6 network.

In SRv6-based L3VPNs, the egress PE signals an SRv6 Service SID with the BGP overlay service route. Theingress PE encapsulates the IPv4/IPv6 payload in an outer IPv6 header where the destination address is theSRv6 Service SID provided by the egress PE. BGP messages between PEs carry SRv6 Service SIDs as ameans to interconnect PEs and form VPNs.

SRv6 Service SID refers to a segment identifier associated with one of the SRv6 service-specific behaviorson the advertising VPNv6 PE router, such as END.DT6 (Endpoint with decapsulation and IPv6 table lookup)or END.DX6 (cross-connect to a nexthop) behaviors.

Based on the messages and procedures defined in "SRv6 BGP based Overlay services", BGP encodes theSRv6 Service SID in the prefix-SID attribute of the IPv6 L3VPN Network Layer Reachability Information(NLRI) and advertises it to its IPv6 BGP peers.

Configure Segment Routing over IPv6 (SRv6)19

Configure Segment Routing over IPv6 (SRv6)SRv6 Services: IPv6 L3VPN

Page 20: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

BGP allocates an SRv6 Service SID from the locator space, configured under SRv6 and VPNv6 addressfamily. For more information on this, refer Segment Routing over IPv6 Overview. The SRv6 Service SIDcan be allocated in the following ways:

• Per-VRF mode that provides End.DT6 support. End.DT6 represents the Endpoint with decapsulationand IPv6 table lookup.

Restrictions and Usage Guidelines

• MPLS L3VPN and SRv6 L3VPN interworking is not supported.

• Equal-Cost Multi-path (ECMP) and Unequal Cost Multipath (UCMP) are supported.

• BGP, OSPF, Static are supported as PE-CE protocol.

Configuring SRv6-based IPv6 L3VPN

To enable SRv6-based L3VPN, you need to configure SRv6 under BGP, and configure the SID allocationmode.

The following examples show how to configure SRv6-based L3VPN.

You can specify the SRv6 locator globally, for all VRFs, or for an individual VRF.Note

This example shows how to configure the SRv6 locator name under BGP Global:RP/0/0/CPU0:Router(config)# router bgp 100RP/0/0/CPU0:Router(config-bgp)# bgp router-id 1.1.1.1RP/0/0/CPU0:Router(config-bgp)# segment-routing srv6RP/0/0/CPU0:Router(config-bgp-srv6)# locator Node1

This example shows how to configure the SRv6 locator for all VRFs under VPNv6 Address Family, withper-VRF label allocation mode:RP/0/0/CPU0:Router(config)# router bgp 100RP/0/0/CPU0:Router(config-bgp)# bgp router-id 1.1.1.1RP/0/0/CPU0:Router(config-bgp)# address-family vpnv6 unicastRP/0/0/CPU0:Router(config-bgp-af)# vrf allRP/0/0/CPU0:Router(config-bgp-af-vrfall)# segment-routing srv6RP/0/0/CPU0:Router(config-bgp-af-vrfall-srv6)# alloc mode per-vrfRP/0/0/CPU0:Router(config-bgp-af-vrfall-srv6)# locator Node1RP/0/0/CPU0:Router(config-bgp-af-vrfall-srv6)# exitRP/0/0/CPU0:Router(config-bgp-af-vrfall)# redistribute connected

This example shows how to configure the SRv6 locator for an Individual VRF, with per-VRF label allocationmode:RP/0/0/CPU0:Router(config)# router bgp 100RP/0/0/CPU0:Router(config-bgp)# bgp router-id 1.1.1.1RP/0/0/CPU0:Router(config-bgp)# address-family vpnv6 unicastRP/0/0/CPU0:Router(config-bgp-af)# vrf vrf_cust6RP/0/0/CPU0:Router(config-bgp-vrf)# rd 100:6RP/0/0/CPU0:Router(config-bgp-vrf)# address-family ipv6 unicastRP/0/0/CPU0:Router(config-bgp-vrf-af)# segment-routing srv6RP/0/0/CPU0:Router(config-bgp-vrf-af-srv6)# alloc mode per-vrf

Configure Segment Routing over IPv6 (SRv6)20

Configure Segment Routing over IPv6 (SRv6)SRv6 Services: IPv6 L3VPN

Page 21: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

RP/0/0/CPU0:Router(config-bgp-vrf-af-srv6)# locator Node1RP/0/0/CPU0:Router(config-bgp-vrf-af-srv6)# exitRP/0/0/CPU0:Router(config-bgp-vrf-af)# redistribute connectedRP/0/0/CPU0:Router(config-bgp-vrf-af)# exitRP/0/0/CPU0:Router(config-bgp-vrf)# exitRP/0/0/CPU0:Router(config-bgp)# neighbor 3001::1:1:1:4RP/0/0/CPU0:Router(config-bgp-nbr)# address-family vpnv4 unicastRP/0/0/CPU0:Router(config-bgp-nbr-af)# commit

Verification

The following examples shows how to verify the SRv6 based L3VPN configurations for an Individual VRFwith per VRF label allocation mode.

In this example, End.X represents Endpoint function with Layer-3 cross-connect, and End.DT6 representsEndpoint with decapsulation and IPv6 table lookup.RP/0/RSP0/CPU0:Node1# show segment-routing srv6 sidFri Jan 15 18:58:04.911 UTC

*** Locator: 'Node1' ***

SID Behavior Context OwnerState RW

-------------------------- ---------------- ------------------------------------------------ ----- --cafe:0:0:1:1:: End (PSP) 'default':1 sidmgr

InUse Ycafe:0:0:1:11:: End.OP 'default' sidmgr

InUse Ycafe:0:0:1:40:: End.X (PSP) [Hu0/0/0/0, Link-Local] isis-1

InUse Ycafe:0:0:1:41:: End.X (PSP) [Hu0/0/0/1, Link-Local] isis-1

InUse Ycafe:0:0:1:47:: End.X (PSP) [Hu0/0/0/0, Link-Local]:P isis-1

InUse Ycafe:0:0:1:48:: End.X (PSP) [Hu0/0/0/1, Link-Local]:P isis-1

InUse Ycafe:0:0:1:49:: End.DT6 'default' bgp-100

InUse Ycafe:0:0:1:4a:: End.DT6 'vrf_cust6' bgp-100

InUse Y

The following examples show how to verify the SRv6 based L3VPN configuration using the show bgp vpnv6unicast commands on the Ingress PE.RP/0/RSP0/CPU0:Node1# show bgp vpnv6 unicast summaryFri Jan 15 18:37:04.791 UTCBGP router identifier 1.1.1.1, local AS number 100BGP generic scan interval 60 secsNon-stop routing is enabledBGP table state: ActiveTable ID: 0x0 RD version: 0BGP main routing table version 21BGP NSR Initial initsync version 4 (Reached)BGP NSR/ISSU Sync-Group versions 0/0BGP scan interval 60 secs

BGP is operating in STANDALONE mode.

Process RcvTblVer bRIB/RIB LabelVer ImportVer SendTblVer StandbyVer

Configure Segment Routing over IPv6 (SRv6)21

Configure Segment Routing over IPv6 (SRv6)SRv6 Services: IPv6 L3VPN

Page 22: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

Speaker 21 21 21 21 21 0

Neighbor Spk AS MsgRcvd MsgSent TblVer InQ OutQ Up/Down St/PfxRcd3001::1:1:1:4 0 100 1352 1352 21 0 0 01:46:26 13001::1:1:1:5 0 100 1351 1351 21 0 0 01:44:47 1

RP/0/RSP0/CPU0:Node1# show bgp vpnv6 unicast rd 100:6Fri Jan 15 18:38:02.919 UTCBGP router identifier 1.1.1.1, local AS number 100BGP generic scan interval 60 secsNon-stop routing is enabledBGP table state: ActiveTable ID: 0x0 RD version: 0BGP main routing table version 21BGP NSR Initial initsync version 4 (Reached)BGP NSR/ISSU Sync-Group versions 0/0BGP scan interval 60 secs

Status codes: s suppressed, d damped, h history, * valid, > besti - internal, r RIB-failure, S stale, N Nexthop-discard

Origin codes: i - IGP, e - EGP, ? - incompleteNetwork Next Hop Metric LocPrf Weight Path

Route Distinguisher: 100:6 (default for vrf vrf_cust6)*> 3001::12:1:1:1/128 :: 0 32768 ?*>i3001::12:1:1:4/128 3001::1:1:1:4 0 100 0 ?*>i3001::12:1:1:5/128 3001::1:1:1:5 0 100 0 ?

Processed 3 prefixes, 3 paths

RP/0/RSP0/CPU0:Node1# show bgp vpnv6 unicast rd 100:6 3001::12:1:1:4/128Fri Jan 15 18:38:26.492 UTCBGP routing table entry for 3001::12:1:1:4/128, Route Distinguisher: 100:6Versions:Process bRIB/RIB SendTblVerSpeaker 17 17

Last Modified: Jan 15 16:50:44.032 for 01:47:43Paths: (1 available, best #1)Not advertised to any peerPath #1: Received by speaker 0Not advertised to any peerLocal, (received & used)3001::1:1:1:4 (metric 30) from 3001::1:1:1:4 (1.1.1.4)Received Label 0x4900Origin incomplete, metric 0, localpref 100, valid, internal, best, group-best,

import-candidate, importedReceived Path ID 0, Local Path ID 1, version 17Extended community: RT:100:6PSID-Type:L3, SubTLV Count:1SubTLV:T:1(Sid information), Sid:cafe:0:0:4::, Behavior:18, SS-TLV Count:1SubSubTLV:T:1(Sid structure):

Source AFI: VPNv6 Unicast, Source VRF: vrf_cust6, Source Route Distinguisher: 100:6

The following examples show how to verify the BGP prefix information for VRF instances:RP/0/RSP0/CPU0:Node1# show bgp vrf vrf_cust6 ipv6 unicastFri Jan 15 18:38:49.705 UTCBGP VRF vrf_cust6, state: ActiveBGP Route Distinguisher: 100:6VRF ID: 0x60000008BGP router identifier 1.1.1.1, local AS number 100Non-stop routing is enabledBGP table state: Active

Configure Segment Routing over IPv6 (SRv6)22

Configure Segment Routing over IPv6 (SRv6)SRv6 Services: IPv6 L3VPN

Page 23: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

Table ID: 0xe0800017 RD version: 21BGP main routing table version 21BGP NSR Initial initsync version 4 (Reached)BGP NSR/ISSU Sync-Group versions 0/0

Status codes: s suppressed, d damped, h history, * valid, > besti - internal, r RIB-failure, S stale, N Nexthop-discard

Origin codes: i - IGP, e - EGP, ? - incompleteNetwork Next Hop Metric LocPrf Weight Path

Route Distinguisher: 100:6 (default for vrf vrf_cust6)*> 3001::12:1:1:1/128 :: 0 32768 ?*>i3001::12:1:1:4/128 3001::1:1:1:4 0 100 0 ?*>i3001::12:1:1:5/128 3001::1:1:1:5 0 100 0 ?

Processed 3 prefixes, 3 paths

RP/0/RSP0/CPU0:Node1# show bgp vrf vrf_cust6 ipv6 unicast 3001::12:1:1:4/128Fri Jan 15 18:39:05.115 UTCBGP routing table entry for 3001::12:1:1:4/128, Route Distinguisher: 100:6Versions:Process bRIB/RIB SendTblVerSpeaker 17 17

Last Modified: Jan 15 16:50:44.032 for 01:48:21Paths: (1 available, best #1)Not advertised to any peerPath #1: Received by speaker 0Not advertised to any peerLocal, (received & used)3001::1:1:1:4 (metric 30) from 3001::1:1:1:4 (1.1.1.4)Received Label 0x4900Origin incomplete, metric 0, localpref 100, valid, internal, best, group-best,

import-candidate, importedReceived Path ID 0, Local Path ID 1, version 17Extended community: RT:100:6PSID-Type:L3, SubTLV Count:1SubTLV:T:1(Sid information), Sid:cafe:0:0:4::, Behavior:18, SS-TLV Count:1SubSubTLV:T:1(Sid structure):

Source AFI: VPNv6 Unicast, Source VRF: vrf_cust6, Source Route Distinguisher: 100:6

The following examples show how to verify the current routes in the Routing Information Base (RIB):RP/0/RSP0/CPU0:Node1# show route vrf vrf_cust6 ipv6 unicastFri Jan 15 18:39:20.619 UTC

Codes: C - connected, S - static, R - RIP, B - BGP, (>) - Diversion pathD - EIGRP, EX - EIGRP external, O - OSPF, IA - OSPF inter areaN1 - OSPF NSSA external type 1, N2 - OSPF NSSA external type 2E1 - OSPF external type 1, E2 - OSPF external type 2, E - EGPi - ISIS, L1 - IS-IS level-1, L2 - IS-IS level-2ia - IS-IS inter area, su - IS-IS summary null, * - candidate defaultU - per-user static route, o - ODR, L - local, G - DAGR, l - LISPA - access/subscriber, a - Application routeM - mobile route, r - RPL, t - Traffic Engineering, (!) - FRR Backup path

Gateway of last resort is not set

L 3001::12:1:1:1/128 is directly connected,21:14:10, Loopback105

B 3001::12:1:1:4/128[200/0] via 3001::1:1:1:4 (nexthop in vrf default), 01:48:36

B 3001::12:1:1:5/128[200/0] via 3001::1:1:1:5 (nexthop in vrf default), 01:46:56

Configure Segment Routing over IPv6 (SRv6)23

Configure Segment Routing over IPv6 (SRv6)SRv6 Services: IPv6 L3VPN

Page 24: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

RP/0/RSP0/CPU0:Node1# show route vrf vrf_cust6 ipv6 unicast 3001::12:1:1:4/128Fri Jan 15 18:39:39.689 UTC

Routing entry for 3001::12:1:1:4/128Known via "bgp 100", distance 200, metric 0, type internalInstalled Jan 15 16:50:44.381 for 01:48:55Routing Descriptor Blocks3001::1:1:1:4, from 3001::1:1:1:4Nexthop in Vrf: "default", Table: "default", IPv6 Unicast, Table Id: 0xe0800000Route metric is 0

No advertising protos.

RP/0/RSP0/CPU0:Node1# show route vrf vrf_cust6 ipv6 unicast 3001::12:1:1:4/128 detailFri Jan 15 18:39:51.573 UTC

Routing entry for 3001::12:1:1:4/128Known via "bgp 100", distance 200, metric 0, type internalInstalled Jan 15 16:50:44.381 for 01:49:07Routing Descriptor Blocks3001::1:1:1:4, from 3001::1:1:1:4Nexthop in Vrf: "default", Table: "default", IPv6 Unicast, Table Id: 0xe0800000Route metric is 0Label: NoneTunnel ID: NoneBinding Label: NoneExtended communities count: 0Source RD attributes: 0x0000:100:6NHID:0x0(Ref:0)SRv6 Headend: H.Encaps.Red [base], SID-list {cafe:0:0:4:49::}

Route version is 0x1 (1)No local labelIP Precedence: Not SetQoS Group ID: Not SetFlow-tag: Not SetFwd-class: Not SetRoute Priority: RIB_PRIORITY_RECURSIVE (12) SVD Type RIB_SVD_TYPE_REMOTEDownload Priority 3, Download Version 3No advertising protos.

The following examples show how to verify the current IPv6 Cisco Express Forwarding (CEF) table:RP/0/RSP0/CPU0:Node1# show cef vrf vrf_cust6 ipv6Fri Jan 15 18:40:15.833 UTC

::/0drop default handler

3001::12:1:1:1/128receive Loopback105

3001::12:1:1:4/128recursive cafe:0:0:4::/128

3001::12:1:1:5/128recursive cafe:0:0:5::/128

fe80::/10receive

ff02::/16receive

ff02::2/128receive

ff02::1:ff00:0/104receive

ff05::/16receive

ff12::/16

Configure Segment Routing over IPv6 (SRv6)24

Configure Segment Routing over IPv6 (SRv6)SRv6 Services: IPv6 L3VPN

Page 25: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

receive

RP/0/RSP0/CPU0:Node1# show cef vrf vrf_cust6 ipv6 3001::12:1:1:4/128Fri Jan 15 18:40:28.853 UTC3001::12:1:1:4/128, version 3, SRv6 Headend, internal 0x5000001 0x30 (ptr 0x78f2e0e0) [1],0x0 (0x0), 0x0 (0x8886b768)Updated Jan 15 16:50:44.385Prefix Len 128, traffic index 0, precedence n/a, priority 3via cafe:0:0:4::/128, 9 dependencies, recursive [flags 0x6000]path-idx 0 NHID 0x0 [0x78a0f504 0x0]next hop VRF - 'default', table - 0xe0800000next hop cafe:0:0:4::/128 via cafe:0:0:4::/64SRv6 H.Encaps.Red SID-list {cafe:0:0:4:49::}

RP/0/RSP0/CPU0:Node1# show cef vrf vrf_cust6 ipv6 3001::12:1:1:4/128 detailFri Jan 15 18:40:55.327 UTC3001::12:1:1:4/128, version 3, SRv6 Headend, internal 0x5000001 0x30 (ptr 0x78f2e0e0) [1],0x0 (0x0), 0x0 (0x8886b768)Updated Jan 15 16:50:44.385Prefix Len 128, traffic index 0, precedence n/a, priority 3gateway array (0x7883b320) reference count 1, flags 0x2010, source rib (7), 0 backups

[1 type 3 flags 0x48441 (0x788e6ad8) ext 0x0 (0x0)]LW-LDI[type=0, refc=0, ptr=0x0, sh-ldi=0x0]gateway array update type-time 1 Jan 15 16:50:44.385LDI Update time Jan 15 16:50:44.385

Level 1 - Load distribution: 0[0] via cafe:0:0:4::/128, recursive

via cafe:0:0:4::/128, 9 dependencies, recursive [flags 0x6000]path-idx 0 NHID 0x0 [0x78a0f504 0x0]next hop VRF - 'default', table - 0xe0800000next hop cafe:0:0:4::/128 via cafe:0:0:4::/64SRv6 H.Encaps.Red SID-list {cafe:0:0:4:49::}

Load distribution: 0 1 (refcount 1)

Hash OK Interface Address0 Y HundredGigE0/0/0/0 remote1 Y HundredGigE0/0/0/1 remote

SRv6Services:L3VPNVPNv4Active-StandbyRedundancyusingPort-Active Mode

The Segment Routing IPv6 (SRv6) Services: L3VPN VPNv4 Active-Standby Redundancy using Port-ActiveMode feature provides all-active per-port load balancing for multihoming. The forwarding of traffic isdetermined based on a specific interface rather than per-flow across multiple Provider Edge routers. Thisfeature enables efficient load-balancing and provides faster convergence. In an active-standby scenario, theactive PE router is detected using designated forwarder (DF) election by modulo calculation and the interfaceof the standby PE router brought down. For Modulo calculation, byte 10 of the Ethernet Segment Identifier(ESI) is used.

Restrictions

• This feature can only be configured for bundle interfaces.

Configure Segment Routing over IPv6 (SRv6)25

Configure Segment Routing over IPv6 (SRv6)SRv6 Services: L3VPN VPNv4 Active-Standby Redundancy using Port-Active Mode

Page 26: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

• When an EVPN Ethernet Segment (ES) is configured with port-active load-balancing mode, you cannotconfigure ACs of that bundle on bridge-domains with a configured EVPN instance (EVI). EVPN Layer2 bridging service is not compatible with port-active load-balancing.

SRv6 Services for L3VPN Active-Standby Redundancy using Port-Active Mode:Operation

Under port-active operational mode, EVPN Ethernet Segment (ES) routes are exchanged across BGP for therouters servicing the multihomed ES. Each PE router then builds an ordered list of the IP addresses of all PEsconnected to the ES, including itself, and assigns itself an ordinal for its position in the list. The ordinals areused with the modulo calculation to determine which PE will be the Designated Forwarder (DF) for a givenES. All non-DF PEs will take the respective bundles out of service.

In the case of link or port failure, the active DF PE withdraws its ES route. This re-triggers DF election forall PEs that service the ES and a new PE is elected as DF.

ConfigureSRv6ServicesL3VPNActive-StandbyRedundancyusingPort-ActiveMode

This section describes how you can configure SRv6 services L3VPN active-standby redundancy usingport-active mode under an Ethernet Segment (ES).

Configuration Example

/* Configure Ethernet Link Bundles */Router# configureRouter(config)# interface Bundle-Ether10Router(config-if)# ipv4 address 10.0.0.2 255.255.255.0Router(config-if)# ipv6 address 2001:DB8::1Router(config-if)# lacp period shortRouter(config-if)# mac-address 1.2.3Router(config-if)# bundle wait-while 0Router(config-if)# exitRouter(config)# interface GigabitEthernet 0/2/0/5Router(config-if)# bundle id 14 mode activeRouter(config-if)# commit

/* Configure load balancing. */Router# configureRouter(config)# evpnRouter(config-evpn)# interface Bundle-Ether10Router(config-evpn-ac)# ethernet-segmentRouter(config-evpn-ac-es)# identifier type 0 11.11.11.11.11.11.11.11.14Router(config-evpn-ac-es)# load-balancing-mode port-activeRouter(config-evpn-ac-es)# commit!/* Configure address family session in BGP. */Router# configureRouter(config)# router bgp 100Router(config-bgp)# bgp router-id 192.168.0.2Router(config-bgp)# address-family l2vpn evpnRouter(config-bgp)# neighbor 192.168.0.3Router(config-bgp-nbr)# remote-as 200

Configure Segment Routing over IPv6 (SRv6)26

Configure Segment Routing over IPv6 (SRv6)SRv6 Services for L3VPN Active-Standby Redundancy using Port-Active Mode: Operation

Page 27: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

Router(config-bgp-nbr)# update-source Loopback 0Router(config-bgp-nbr)# address-family l2vpn evpnRouter(config-bgp-nbr)# commit

Running Configuration

interface Bundle-Ether14ipv4 address 14.0.0.2 255.255.255.0ipv6 address 14::2/64lacp period shortmac-address 1.2.3bundle wait-while 0!interface GigabitEthernet0/2/0/5bundle id 14 mode active!evpninterface Bundle-Ether14ethernet-segmentidentifier type 0 11.11.11.11.11.11.11.11.14load-balancing-mode port-active!!!router bgp 100bgp router-id 192.168.0.2address-family l2vpn evpn!neighbor 192.168.0.3remote-as 100update-source Loopback0address-family l2vpn evpn!!!

VerificationVerify the SRv6 services L3VPN active-standby redundancy using port-active mode configuration.

/* Verify ethernet-segment details on active DF router */Router# show evpn ethernet-segment interface Bundle-Ether14 detailEthernet Segment Id Interface Nexthops------------------------ ---------------------------------- --------------------0011.1111.1111.1111.1114 BE14 192.168.0.2

192.168.0.3ES to BGP Gates : Ready

ES to L2FIB Gates : ReadyMain port :

Interface name : Bundle-Ether14Interface MAC : 0001.0002.0003IfHandle : 0x000041d0State : UpRedundancy : Not Defined

ESI type : 0Value : 11.1111.1111.1111.1114

ES Import RT : 1111.1111.1111 (from ESI)Source MAC : 0000.0000.0000 (N/A)Topology :

Operational : MHConfigured : Port-Active

Configure Segment Routing over IPv6 (SRv6)27

Configure Segment Routing over IPv6 (SRv6)Running Configuration

Page 28: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

Service Carving : Auto-selectionMulticast : Disabled

Peering Details :192.168.0.2 [MOD:P:00]192.168.0.3 [MOD:P:00]

Service Carving Results:Forwarders : 0Permanent : 0Elected : 0Not Elected : 0

MAC Flushing mode : STP-TCNPeering timer : 3 sec [not running]Recovery timer : 30 sec [not running]Carving timer : 0 sec [not running]Local SHG label : NoneRemote SHG labels : 0

/* Verify bundle Ethernet configuration on active DF router */Router# show bundle bundle-ether 14Bundle-Ether14Status: UpLocal links <active/standby/configured>: 1 / 0 / 1Local bandwidth <effective/available>: 1000000 (1000000) kbpsMAC address (source): 0001.0002.0003 (Configured)Inter-chassis link: NoMinimum active links / bandwidth: 1 / 1 kbpsMaximum active links: 64Wait while timer: OffLoad balancing:Link order signaling: Not configuredHash type: DefaultLocality threshold: None

LACP: OperationalFlap suppression timer: OffCisco extensions: DisabledNon-revertive: Disabled

mLACP: Not configuredIPv4 BFD: Not configuredIPv6 BFD: Not configured

Port Device State Port ID B/W, kbps-------------------- --------------- ----------- -------------- ----------Gi0/2/0/5 Local Active 0x8000, 0x0003 1000000

Link is Active

/* Verify ethernet-segment details on standby DF router */Router# show evpn ethernet-segment interface bundle-ether 10 detail

Router# show evpn ethernet-segment interface Bundle-Ether24 detailEthernet Segment Id Interface Nexthops------------------------ ---------------------------------- --------------------0011.1111.1111.1111.1114 BE24 192.168.0.2

192.168.0.3ES to BGP Gates : ReadyES to L2FIB Gates : ReadyMain port :

Interface name : Bundle-Ether24Interface MAC : 0001.0002.0003IfHandle : 0x000041b0State : Standby

Configure Segment Routing over IPv6 (SRv6)28

Configure Segment Routing over IPv6 (SRv6)Verification

Page 29: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

Redundancy : Not DefinedESI type : 0

Value : 11.1111.1111.1111.1114ES Import RT : 1111.1111.1111 (from ESI)Source MAC : 0000.0000.0000 (N/A)Topology :

Operational : MHConfigured : Port-Active

Service Carving : Auto-selectionMulticast : Disabled

Peering Details :192.168.0.2 [MOD:P:00]192.168.0.3 [MOD:P:00]

Service Carving Results:Forwarders : 0Permanent : 0Elected : 0Not Elected : 0

MAC Flushing mode : STP-TCNPeering timer : 3 sec [not running]Recovery timer : 30 sec [not running]Carving timer : 0 sec [not running]Local SHG label : NoneRemote SHG labels : 0

/* Verify bundle configuration on standby DF router */Router# show bundle bundle-ether 24

Bundle-Ether24Status: LACP OOS (out of service)Local links <active/standby/configured>: 0 / 1 / 1Local bandwidth <effective/available>: 0 (0) kbpsMAC address (source): 0001.0002.0003 (Configured)Inter-chassis link: NoMinimum active links / bandwidth: 1 / 1 kbpsMaximum active links: 64Wait while timer: OffLoad balancing:Link order signaling: Not configuredHash type: DefaultLocality threshold: None

LACP: OperationalFlap suppression timer: OffCisco extensions: DisabledNon-revertive: Disabled

mLACP: Not configuredIPv4 BFD: Not configuredIPv6 BFD: Not configured

Port Device State Port ID B/W, kbps-------------------- --------------- ----------- -------------- ----------Gi0/0/0/4 Local Standby 0x8000, 0x0002 1000000

Link is in standby due to bundle out of service state

SRv6 Services: L3VPN VPNv4 Active-Active RedundancyThis feature provides active-active connectivity to a CE device in a L3VPN deployment. The CE device canbe Layer-2 or Layer-3 device connecting to the redundant PEs over a single LACP LAG port.

Configure Segment Routing over IPv6 (SRv6)29

Configure Segment Routing over IPv6 (SRv6)SRv6 Services: L3VPN VPNv4 Active-Active Redundancy

Page 30: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

Depending on the bundle hashing, an ARP or IPv6 Network Discovery (ND) packet can be sent to any of theredundant routers. As a result, not all entries will exist on a given PE. In order to provide complete awareness,Layer-3 local route learning is augmented with remote route-synchronization programming.

Route synchronization between service PEs is required in order to provide minimum interruption to unicastand multicast services after failure on a redundant service PE. The following EVPN route-types are used forLayer-3 route synchronization:

• EVPN route-type 2 for synchronizing ARP tables

• EVPN route-type 7/8 for synchronizing IGMP JOINS/LEAVES

In a Layer-3 CE scenario, the router that connects to the redundant PEs may establish an IGP adjacency onthe bundle port. In this case, the adjacency will be formed to one of the redundant PEs, and IGP customerroutes will only be present on that PE. To synchronize Layer-3 customer subnet routes (IP Prefixes), the EVPNroute-type 5 is used to carry the ESI and ETAG as well as the gateway address (prefix next-hop address).

Gratuitous ARP (GARP) or IPv6 Network Advertisement (NA) replay is not needed for CEs connected tothe redundant PEs over a single LAG port.

Note

The below configuration enables Layer-3 route synchronization for routes learned on the Ethernet-segmentmain-port or any of its sub-interfaces.evpnroute-sync vrf default!vrf REDevi route-sync 10!vrf BLUEevi route-sync 20!

SRv6 Services: BGP Global IPv4This feature extends support of SRv6-based BGP services to include Internet (IPv4) services by implementingEnd.DT4 SRv6 functions at the PE node (draft-ietf-bess-srv6-services).

BGP Global IPv4 Over SRv6 with Per-VRF SID Allocation Mode (End.DT4)

The following example shows how to configure BGP global IPv4 over SRv6 with per-VRF SID allocation.router bgp 1bgp router-id 10.1.0.1address-family ipv4 unicastsegment-routing srv6alloc mode per-vrf!!neighbor 60::2remote-as 1update-source Loopback1address-family ipv4 unicastroute-policy passall in

Configure Segment Routing over IPv6 (SRv6)30

Configure Segment Routing over IPv6 (SRv6)SRv6 Services: BGP Global IPv4

Page 31: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

encapsulation-type srv6route-policy passall out!!neighbor 52.52.52.1remote-as 3address-family ipv4 unicastroute-policy passall inroute-policy passall out!!!

SRv6 Services: BGP Global IPv6Table 3: Feature History Table

Feature DescriptionRelease InformationFeature Name

With this feature, the egress PE cansignal an SRv6 Service SID withthe BGP overlay service route. Theingress PE encapsulates theIPv4/IPv6 payload in an outer IPv6header where the destinationaddress is the SRv6 Service SIDprovided by the egress PE. BGPmessages between PEs carry SRv6Service SIDs as a means tointerconnect PEs.

Release 7.2.2SRv6 Services: BGP Global IPv6

This feature extends support of SRv6-based BGP services to include Internet (IPv6) services by implementingEnd.DT6 SRv6 functions at the PE node (draft-ietf-bess-srv6-services).

BGP Global IPv6 Over SRv6 with Per-VRF SID Allocation Mode (End.DT6)

The following example shows how to configure BGP global IPv6 over SRv6 with per-VRF SID allocation.router bgp 100bgp router-id 1.1.1.1segment-routing srv6locator Node1!address-family ipv6 unicastsegment-routing srv6locator Node1alloc mode per-vrf!!neighbor 3001::1:1:1:4address-family ipv6 unicastencapsulation-type srv6!!neighbor 3001::1:1:1:5address-family ipv6 unicast

Configure Segment Routing over IPv6 (SRv6)31

Configure Segment Routing over IPv6 (SRv6)SRv6 Services: BGP Global IPv6

Page 32: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

encapsulation-type srv6

Verification

The following examples show how to verify the BGP global IPv6 configuration using the show bgp ipv6unicast commands.RP/0/RSP0/CPU0:Node1# show bgp ipv6 unicast summaryFri Jan 15 21:07:04.681 UTCBGP router identifier 1.1.1.1, local AS number 100BGP generic scan interval 60 secsNon-stop routing is enabledBGP table state: ActiveTable ID: 0xe0800000 RD version: 4BGP main routing table version 4BGP NSR Initial initsync version 1 (Reached)BGP NSR/ISSU Sync-Group versions 0/0BGP scan interval 60 secs

BGP is operating in STANDALONE mode.

Process RcvTblVer bRIB/RIB LabelVer ImportVer SendTblVer StandbyVerSpeaker 4 4 4 4 4 0

Neighbor Spk AS MsgRcvd MsgSent TblVer InQ OutQ Up/Down St/PfxRcd3001::1:1:1:4 0 100 1502 1502 4 0 0 04:16:26 13001::1:1:1:5 0 100 1501 1501 4 0 0 04:14:47 1

RP/0/RSP0/CPU0:Node1# show bgp ipv6 unicastFri Jan 15 21:07:26.818 UTCBGP router identifier 1.1.1.1, local AS number 100BGP generic scan interval 60 secsNon-stop routing is enabledBGP table state: ActiveTable ID: 0xe0800000 RD version: 4BGP main routing table version 4BGP NSR Initial initsync version 1 (Reached)BGP NSR/ISSU Sync-Group versions 0/0BGP scan interval 60 secs

Status codes: s suppressed, d damped, h history, * valid, > besti - internal, r RIB-failure, S stale, N Nexthop-discard

Origin codes: i - IGP, e - EGP, ? - incompleteNetwork Next Hop Metric LocPrf Weight Path

*> 3001::13:1:1:1/128 :: 0 32768 i*>i3001::13:1:1:4/128 3001::1:1:1:4 0 100 0 i*>i3001::13:1:1:5/128 3001::1:1:1:5 0 100 0 i

Processed 3 prefixes, 3 paths

RP/0/RSP0/CPU0:Node1# show bgp ipv6 unicast 3001::13:1:1:4/128Fri Jan 15 21:07:50.309 UTCBGP routing table entry for 3001::13:1:1:4/128Versions:Process bRIB/RIB SendTblVerSpeaker 4 4

Last Modified: Jan 15 17:13:50.032 for 03:54:01Paths: (1 available, best #1)Not advertised to any peerPath #1: Received by speaker 0Not advertised to any peerLocal

Configure Segment Routing over IPv6 (SRv6)32

Configure Segment Routing over IPv6 (SRv6)SRv6 Services: BGP Global IPv6

Page 33: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

3001::1:1:1:4 (metric 30) from 3001::1:1:1:4 (1.1.1.4)Origin IGP, metric 0, localpref 100, valid, internal, best, group-bestReceived Path ID 0, Local Path ID 1, version 4PSID-Type:L3, SubTLV Count:1SubTLV:T:1(Sid information), Sid:cafe:0:0:4:4b::, Behavior:18, SS-TLV Count:1SubSubTLV:T:1(Sid structure):

The following examples show how to verify the current routes in the Routing Information Base (RIB):RP/0/RSP0/CPU0:Node1# show route ipv6 3001::13:1:1:4/128Fri Jan 15 21:08:05.499 UTC

Routing entry for 3001::13:1:1:4/128Known via "bgp 100", distance 200, metric 0, type internalInstalled Jan 15 17:13:50.431 for 03:54:15Routing Descriptor Blocks3001::1:1:1:4, from 3001::1:1:1:4Route metric is 0

No advertising protos.

RP/0/RSP0/CPU0:Node1# show route ipv6 3001::13:1:1:4/128 detailFri Jan 15 21:08:22.628 UTC

Routing entry for 3001::13:1:1:4/128Known via "bgp 100", distance 200, metric 0, type internalInstalled Jan 15 17:13:50.431 for 03:54:32Routing Descriptor Blocks3001::1:1:1:4, from 3001::1:1:1:4Route metric is 0Label: NoneTunnel ID: NoneBinding Label: NoneExtended communities count: 0NHID:0x0(Ref:0)SRv6 Headend: H.Encaps.Red [base], SID-list {cafe:0:0:4:4b::}

Route version is 0x1 (1)No local labelIP Precedence: Not SetQoS Group ID: Not SetFlow-tag: Not SetFwd-class: Not SetRoute Priority: RIB_PRIORITY_RECURSIVE (12) SVD Type RIB_SVD_TYPE_LOCALDownload Priority 4, Download Version 93No advertising protos.

The following examples show how to verify the current IPv6 Cisco Express Forwarding (CEF) table:RP/0/RSP0/CPU0:Node1# show cef ipv6 3001::13:1:1:4/128Fri Jan 15 21:08:41.483 UTC3001::13:1:1:4/128, version 93, SRv6 Headend, internal 0x5000001 0x40 (ptr 0x78a100d4) [1],0x0 (0x0), 0x0 (0x8886b840)Updated Jan 15 17:13:50.433Prefix Len 128, traffic index 0, precedence n/a, priority 4via cafe:0:0:4::/128, 9 dependencies, recursive [flags 0x6000]path-idx 0 NHID 0x0 [0x78a0f504 0x0]next hop cafe:0:0:4::/128 via cafe:0:0:4::/64SRv6 H.Encaps.Red SID-list {cafe:0:0:4:4b::}

RP/0/RSP0/CPU0:Node1# show cef ipv6 3001::13:1:1:4/128 detailFri Jan 15 21:08:59.789 UTC3001::13:1:1:4/128, version 93, SRv6 Headend, internal 0x5000001 0x40 (ptr 0x78a100d4) [1],

Configure Segment Routing over IPv6 (SRv6)33

Configure Segment Routing over IPv6 (SRv6)SRv6 Services: BGP Global IPv6

Page 34: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

0x0 (0x0), 0x0 (0x8886b840)Updated Jan 15 17:13:50.433Prefix Len 128, traffic index 0, precedence n/a, priority 4gateway array (0x7883b5d8) reference count 1, flags 0x2010, source rib (7), 0 backups

[1 type 3 flags 0x48441 (0x788e6c40) ext 0x0 (0x0)]LW-LDI[type=0, refc=0, ptr=0x0, sh-ldi=0x0]gateway array update type-time 1 Jan 15 17:13:50.433LDI Update time Jan 15 17:13:50.433

Level 1 - Load distribution: 0[0] via cafe:0:0:4::/128, recursive

via cafe:0:0:4::/128, 9 dependencies, recursive [flags 0x6000]path-idx 0 NHID 0x0 [0x78a0f504 0x0]next hop cafe:0:0:4::/128 via cafe:0:0:4::/64SRv6 H.Encaps.Red SID-list {cafe:0:0:4:4b::}

Load distribution: 0 1 (refcount 1)

Hash OK Interface Address0 Y HundredGigE0/0/0/0 remote1 Y HundredGigE0/0/0/1 remote

SRv6 Services: EVPN VPWS — All-Active Multi-HomingEVPN VPWS All-Active Multi-Homing over SRv6 provides an ELINE (P2P) service with all-activemultihoming capability over an SRv6 network.

All-ActiveMulti-Homing enables an operator to connect a customer edge (CE) device to two or more provideredge (PE) devices to provide load balancing and redundant connectivity. With All-Active Multi-Homing, allthe PEs can forward traffic to and from the multi-homed device.

For information about EVPN VPWS, refer to the "EVPN Virtual Private Wire Service (VPWS)" chapter inthe L2VPN and Ethernet Services Configuration Guide for Cisco NCS 5500 Series Routers.

Note

Configuring EVPN VPWS over SRv6

An SRv6 Locator for an EVPN VPWS service can be configured at 3 different levels independently:

• global_locator is the default locator for all EVPN-VPWS services

• evi_locator is applied to all EVPN-VPWS services for the specific EVI

• evi_service_locator is applied to an individual EVI service

When locators are configured at different levels at the same time, the following priority is implemented:

1. evi_service_locator

2. evi_locator

3. global_locator

This example shows how to configure an EVPN VPWS over SRv6 using a global locator for EVPN:

Configure Segment Routing over IPv6 (SRv6)34

Configure Segment Routing over IPv6 (SRv6)SRv6 Services: EVPN VPWS — All-Active Multi-Homing

Page 35: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

evpnsegment-routing srv6locator sample_global_loc

l2vpnxconnect group sample_xcgp2p sample-vpws-12001-2002interface Bundle-Ether12001.2002neighbor evpn evi 12001 service 2002 segment-routing srv6

This example shows how to configure EVPN VPWS over SRv6 using specific EVI locator:evpnevi 11001 segment-routing srv6locator sample_evi_loc

l2vpnxconnect group sample_xcgp2p sample-vpws-11001-2002interface Bundle-Ether11001.2002neighbor evpn evi 11001 service 2002 segment-routing srv6

This example shows how to configure an EVPN VPWS over SRv6 using a locator for an individual EVIservice:l2vpnxconnect group sample_xcgp2p sample-vpws-11001-2001interface Bundle-Ether11001.2001neighbor evpn evi 11001 service 2001 segment-routing srv6locator sample_evi_service_loc

Verification

Router# show segment-routing srv6 locator sample_evi_loc sidMon Aug 12 20:57:07.759 EDTSID Behavior Context Owner

State RW-------------------------- ----------- ------------------------------ ----------------------- --

cafe:0:8:1:1:: End (PSP) 'default':1 sidmgrInUse Y

cafe:0:8:1:11:: End.OP 'default' sidmgrInUse Y

cafe:0:8:1:40:: End.DX2 11001:1 l2vpn_srv6InUse Y

cafe:0:8:1:41:: End.DX2 11001:2 l2vpn_srv6InUse Y

cafe:0:8:1:42:: End.DX2 11001:3 l2vpn_srv6InUse Y

cafe:0:8:1:44:: End.DX2 11001:2002 l2vpn_srv6InUse Y

Router# show evpn segment-routing srv6 detailTue Aug 13 10:30:46.020 EDT

Configured default locator: sample_global_locEVIs with unknown locator config: 0VPWS with unknown locator config: 0

Locator name Prefix OOR Service count SID count------------ ------ --- ------------- ---------

Configure Segment Routing over IPv6 (SRv6)35

Configure Segment Routing over IPv6 (SRv6)SRv6 Services: EVPN VPWS — All-Active Multi-Homing

Page 36: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

sample_global_loc cafe:0:0:1::/64 False 1 1Default locator

sample_evi_loc cafe:0:8:1::/64 False 4 4Configured on EVIs <evi>: 11001

SRv6 Services: EVPN VPWS — IPv6 QoS Traffic-Class MarkingThis feature allows the ingress EVPN VPWS PE to copy the CoS value from the top-most VLAN header tothe traffic-class (TC) field of the outer-most IPv6 header. This functionality enables prioritization of trafficin the IPv6 network.

The following configuration shows how to enable this feature:

This command requires you to reload the router for the configuration to take effect.Note

Router# configureRouter(config)# hw-module profile segment-routing srv6 encapsulation traffic-class propagate

The functionality covers the following scenarios:

• Use case 1: Without additional QoS configuration, the CoS in the outer VLAN tag of incoming Ethernetframes is propagated to the traffic-class field in the encapsulated IPv6 header.

• Use case 2: With additional QoS configuration, DSCP in the IPv4/IPv6 header of incoming IP packetsis propagated to the traffic-class field in the encapsulated IPv6 header.

The following configuration shows how to define specific classification criteria:class-map match-any prec-0match precedence ipv4 0match precedence ipv6 0end-class-map…class-map match-any prec-7match precedence ipv4 7match precedence ipv6 7end-class-map

The following configuration shows how to define a QoS policy map:policy-map prec-to-tcclass prec-0set qos-group 0

…class prec-7set qos-group 7

The following configuration shows how to apply a QoS policy-map to an attachment-circuit (AC)interface:interface Bundle-Ether1.1 l2transportencapsulation untaggedservice-policy input prec-to-tc

Configure Segment Routing over IPv6 (SRv6)36

Configure Segment Routing over IPv6 (SRv6)SRv6 Services: EVPN VPWS — IPv6 QoS Traffic-Class Marking

Page 37: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

SRv6 Services: SRv6 Services TLV Type 5 SupportIOS XR 6.6.1 supports IETF draft draft-dawra-idr-srv6-vpn-04, in which the SRv6-VPN SID TLV (TLVType 4) carries the SRv6 Service SID information. This SID TLV is inconsistent with the SRv6 SID Structure.

In IOS XR 7.0.2 and later releases, the implementation is compliant with draft-ietf-bess-srv6-services-00,which defines a new SRv6 Services TLV (TLV Type 5/6) and SRv6 SID Structure Sub-Sub-TLV to addressthis inconsistency.

SRv6 SID Structure Sub-Sub-TLV describes mechanisms for signaling of the SRv6 Service SID by transposinga variable part of the SRv6 SID value (function and/or the argument parts) and carrying them in existing labelfields to achieve more efficient packing of VPN and EVPN service prefix NLRIs in BGP update messages.

In order to allow backward compatibility between the newer software and the older software, use thesegment-routing srv6 prefix-sid-type4 command in Router BGP Neighbor VPNv4 Address-Familyconfiguration mode to advertise BGP VPNv4 NLRIs in TLV Type 4 format. The newer software can receiveeither TLV Type 4 or TLV Type 5 formats.

The following configuration shows how to enable the advertisement of BGP VPNv4 NLRIs in TLV Type 4format:RP/0/RSP0/CPU0:Rtr-a(config)# router bgp 65000RP/0/RSP0/CPU0:Rtr-a(config-bgp)# neighbor 6::6RP/0/RSP0/CPU0:Rtr-a(config-bgp-nbr)# address-family vpnv4 unicastRP/0/RSP0/CPU0:Rtr-a(config-bgp-nbr-af)# segment-routing srv6 prefix-sid-type4RP/0/RSP0/CPU0:Rtr-a(config-bgp-nbr-af)#

SRv6 SID Information in BGP-LS ReportingBGP Link-State (BGP-LS) is used to report the topology of the domain using nodes, links, and prefixes. Thisfeature adds the capability to report SRv6 Segment Identifier (SID) Network Layer Reachability Information(NLRI).

The following NLRI has been added to the BGP-LS protocol to support SRv6:

• Node NLRI: SRv6 Capabilities, SRv6 MSD types

• Link NLRI: End.X, LAN End.X, and SRv6 MSD types

• Prefix NLRI: SRv6 Locator

• SRv6 SID NLRI (for SIDs associated with the node): Endpoint Function, BGP-EPE Peer Node/Set

This example shows how to distribute IS-IS SRv6 link-state data using BGP-LS:Router(config)# router isis 200Router(config-isis)# distribute link-state instance-id 200

When you distribute IS-IS SRv6 link-state data, SRv6 ping or traceroute operations using the use-srv6-op-sidkeyword can retrieve and use the corresponding END.OP SID automatically. See SRv6 OAM— SIDVerification, on page 38 for details about SRv6 ping and traceroute.

Note

Configure Segment Routing over IPv6 (SRv6)37

Configure Segment Routing over IPv6 (SRv6)SRv6 Services: SRv6 Services TLV Type 5 Support

Page 38: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

SRv6 OAM — SID VerificationThis feature provides enhanced Operations, Administration, and Maintenance (OAM) in Segment RoutingNetworks with IPv6 Data plane (SRv6).

Existing OAM mechanisms to ping and trace a remote IPv6 prefix, along the shortest path, continue to workwithout any modification in an SRv6 network.

However, classic IPv6 OAMcannot be used to ping or trace a remote SRv6 SID function. This feature augmentsping and traceroute operations to target remote SRv6 SIDs. An SRv6-enabled router now allocates a newSRv6 OAM SID known as END.OP (OAM Endpoint with Punt).

Use the following commands to performs SRv6 ping and traceroute:

ping B:k:F:: [use-srv6-op-sid [ end.op-sid-value]]

traceroute B:k:F:: [use-srv6-op-sid [ end.op-sid-value]]

Where B:k:F:: is the target SID at node k with locator block B and function F.

Ping/Traceroute to SID Without OAM SID

The user can issue ping or traceroute to an SRv6 SID using the classic CLI. A ping or traceroute to an SRv6SID does not require the user to enter the “use-end-op” keyword when pinging or tracing a SID function. Inthis case, and as usual, the packet is pre-routed as an ICMP echo request or UDP packet.

Ping/Traceroute to SID With OAM SID

When ping or traceroute operations include the use-srv6-op-sid keyword, the packet is pre-routed withEND.OP SID as Destination Address (DA) and the target SID in the SRH.

The END.OP SID value is an optional 128 bit value in IPv6 address format. See END.OP SID Derivationbelow for details on this value.

Note

At the target node, the END.OP SID forces the punt of the packet to the OAM process, which verifies thatthe next SID is local and valid. If the next SID received by the target node is a local valid address that is nota SID, the target node still replies to indicate ping success. The ping reply contains a subtype to indicate thetarget was a SID or a local address.

A target remote SID include the following:

• END

• END.DT4/END.DX4 (used by L3 Services over SRv6)

• END.DX2 (used by L2 Services over SRv6)

END.OP SID Derivation

The ingress node can automatically derive the END.OP SID associatedwith a specified target SID by leveragingthe IGP topology database in that node. The database will contain END.OP SIDs from remote nodes.

An END.OP SID associated with a locator will be advertised by IS-IS within an IGP domain in an area/level,which is added to the topology database. However, END.OP SIDs are not redistributed by IS-IS across IGP

Configure Segment Routing over IPv6 (SRv6)38

Configure Segment Routing over IPv6 (SRv6)SRv6 OAM — SID Verification

Page 39: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

domains or across different area/level within an IGP domain. In this case, the topology database in a nodecontains END.OP SIDs only from the nodes within the same IGP domain in an area/level. An END.OP SIDcannot be determine automatically if the specified target SID is external to the domain. For target SIDs acrossIGP domains or across different area/level within an IGP domain, the end.op-sid-value must be explicitlyprovided.

If end.op-sid-value is not provided and the END.OP SID cannot be automatically derived, an error is displayedprompting the user to provide the end.op-sid-value.

Configuration Examples

The following example shows using ping to a SID without OAM SID.Router# ping cafe:0:0:a3:40::Wed Jul 24 19:24:50.812 UTCType escape sequence to abort.Sending 5, 100-byte ICMP Echos to cafe:0:0:a3:40::, timeout is 2 seconds:!!!!!Success rate is 100 percent (5/5), round-trip min/avg/max = 1/1/2 ms

The following example shows using ping to a SID with an OAM SID. Note that the output shows "S" toindicate that this is a response from a SID target.Router# ping cafe:0:0:a3:40:: use-srv6-op-sidWed Jul 24 19:24:50.812 UTCType escape sequence to abort.Sending 5, 100-byte ICMP Echos to cafe:0:0:a3:40::, timeout is 2 seconds:SSSSSSuccess rate is 100 percent (5/5), round-trip min/avg/max = 1/1/2 ms

The following example shows using ping to a SID with an explicit OAM SID. Note that the output shows "S"to indicate that this is a response from a SID target.Router# ping cafe:0:0:a3:40:: use-srv6-op-sid cafe:0:0:a3:11::Wed Jul 24 19:24:50.812 UTCType escape sequence to abort.Sending 5, 100-byte ICMP Echos to cafe:0:0:a3:40::, timeout is 2 seconds:SSSSSSuccess rate is 100 percent (5/5), round-trip min/avg/max = 1/1/2 ms

The following example shows using traceroute to a SID without OAM SID.Router# traceroute cafe:0:0:a3:1::Wed Jul 24 19:40:19.192 UTC

Type escape sequence to abort.Tracing the route to cafe:0:0:a3:1::

1 2001::1:1:1:1 2 msec 2 msec 2 msec2 2001:10:10:13::2 2 msec 2 msec 2 msec

The following example shows using traceroute to a SID with OAM SID.Router# traceroute cafe:0:0:a3:40:: use-srv6-op-sid

Type escape sequence to abort.Tracing the route to cafe:0:0:a3:40::

1 2001::1:1:1:1[IP tunnel: DA=cafe:0:0:a3:11:: SRH Stack 0 =(cafe:0:0:a3:40:: ,SL=1) ] 2

Configure Segment Routing over IPv6 (SRv6)39

Configure Segment Routing over IPv6 (SRv6)SRv6 OAM — SID Verification

Page 40: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

msec2 2001::33:33:33:33

[IP tunnel: DA=cafe:0:0:a3:11:: SRH Stack 0 =(cafe:0:0:a3:40:: ,SL=1) ] 3msec

The following example shows using traceroute to a SID with an explicit OAM SID.Router# traceroute cafe:0:0:a3:40:: use-srv6-op-sid cafe:0:0:a3:11::

Type escape sequence to abort.Tracing the route to cafe:0:0:a3:40::

1 2001::1:1:1:1[IP tunnel: DA=cafe:0:0:a3:11:: SRH Stack 0 =(cafe:0:0:a3:40:: ,SL=1) ] 2

msec2 2001::33:33:33:33

[IP tunnel: DA=cafe:0:0:a3:11:: SRH Stack 0 =(cafe:0:0:a3:40:: ,SL=1) ] 3msec

DHCPv4 Relay Agent and Proxy Support over SRv6This feature introduces support for DHCPv4 Relay Agent and Proxy over SRv6.

An IOS XR router can act as a DHCPv4 relay agent/proxy with a DHCPv4 server connected over an SRv6network.

The following functionality is supported:

• DHCPv4 relay agent/proxy over SRv6 with DHCPv4 server (helper-address) located in default VRF(global)

• DHCPv4 relay agent/proxy over SRv6with DHCPv4 server (helper-address) located in non-default VRF

• DHCPv4 relay agent/proxy on interfaces associated with a default VRF (global)

• DHCPv4 relay agent/proxy on interfaces associated with a non-default VRF

• DHCPv4 relay agent/proxy on Ethernet physical interfaces

• DHCPv4 relay agent/proxy on Ethernet bundle interfaces

• DHCPv4 relay agent/proxy for VPNv4 PE active-active redundancy scenarios

For information on configuring DHCPv4 relay agent and proxy, refer to the “Implementing the Dynamic HostConfiguration Protocol” chapter in the IP Addresses and Services Configuration Guide for Cisco NCS 5500Series Routers.

Configure Segment Routing over IPv6 (SRv6)40

Configure Segment Routing over IPv6 (SRv6)DHCPv4 Relay Agent and Proxy Support over SRv6

Page 41: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

DHCPv6 Relay Agent Support over SRv6Table 4: Feature History Table

Feature DescriptionRelease InformationFeature Name

An IOS XR router can act as aDHCPv6 relay agent with aDHCPv6 server connected over anSRv6 network.

A DHCP relay agent is a host thatforwards DHCP packets betweenclients and servers that do notreside on a shared physical subnet.

Release 7.2.2DHCPv6 Relay Agent Support onSRv6

This feature introduces support for DHCPv6 Relay Agent over SRv6.

An IOS XR router can act as a DHCPv6 relay agent with a DHCPv6 server connected over an SRv6 network.

The following functionality is supported:

• DHCPv6 relay agent over SRv6 with DHCPv6 server (helper-address) located in default VRF (global)

• DHCPv6 relay agent over SRv6 with DHCPv6 server (helper-address) located in non-default VRF

• DHCPv6 relay agent on interfaces associated with a default VRF (global)

• DHCPv6 relay agent on interfaces associated with a non-default VRF

• DHCPv6 relay agent on Ethernet physical interfaces

• DHCPv6 relay agent on Ethernet bundle interfaces

For information on configuring DHCPv6 relay agent, refer to the “Implementing the Dynamic HostConfiguration Protocol” chapter in the IP Addresses and Services Configuration Guide for Cisco NCS 5500Series Routers.

Configure Segment Routing over IPv6 (SRv6)41

Configure Segment Routing over IPv6 (SRv6)DHCPv6 Relay Agent Support over SRv6

Page 42: Configure Segment Routing over IPv6 (SRv6) · ThefollowingexampleshowshowtogloballyenableSRv6andconfigureAnycastlocator. ForCiscoNCS5500SeriesRouters,youmustfirstusethehw-moduleprofilesegment-routingsrv6command

Configure Segment Routing over IPv6 (SRv6)42

Configure Segment Routing over IPv6 (SRv6)DHCPv6 Relay Agent Support over SRv6