Example: nsh mix of ip and ethernet¶
r1
hostname r1
vrf def v1
rd 1:1
exit
access-list test4
sequence 10 permit all 1.1.1.1 255.255.255.255 all any all
exit
access-list test6
sequence 10 permit all 1111::1 ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff all any all
exit
int lo1
vrf for v1
ipv4 addr 1.1.1.1 255.255.255.0
ipv6 addr 1111::1 ffff:ffff::
exit
int eth1
nsh ena
exit
ipv4 pbr v1 sequence 10 test4 v1 nsh 2 255
ipv6 pbr v1 sequence 10 test6 v1 nsh 2 255
nsh 2 255 int eth1 0000.1111.2222
nsh 3 253 route v1
r2
hostname r2
int eth1
nsh ena
exit
int eth2
nsh ena
exit
nsh 3 254 int eth1 0000.1111.2222
nsh 2 254 int eth2 0000.1111.2222
r3
hostname r3
int eth1
nsh ena
exit
int eth2
nsh ena
nsh xconn 3 255
exit
nsh 3 255 int eth1 0000.1111.2222
nsh 2 253 int eth2 0000.1111.2222 rawpack keephdr
r4
hostname r4
vrf def v1
rd 1:1
exit
int eth1
vrf for v1
ipv4 addr 1.1.1.2 255.255.255.0
ipv6 addr 1111::2 ffff::
ipv4 host-static 1.1.1.1 0000.1111.2222
ipv6 host-static 1111::1 0000.1111.2222
exit
r1 tping 100 10 1.1.1.2 vrf v1
r1 tping 100 10 1111::2 vrf v1
r4 tping 100 10 1.1.1.1 vrf v1
r4 tping 100 10 1111::1 vrf v1
- Install ContainerLab as described here
- Fetch mpls-nsh13 file
- Launch ContainerLab
mpls-nsh13.yml
topology:
containerlab deploy --topo mpls-nsh13.yml
mpls-nsh13.yml
topology:
containerlab destroy --topo mpls-nsh13.yml