Example: nsh over gre¶
r1
hostname r1
vrf def v1
 rd 1:1
 exit
int eth1
 vrf for v1
 ipv4 addr 1.1.1.1 255.255.255.0
 ipv6 addr 1111::1 ffff::
 exit
r2
hostname r2
vrf def v1
 rd 1:1
 exit
int eth1
 nsh ena
 nsh xconn 2 255
 exit
int eth2
 vrf for v1
 ipv6 addr 1111::1 ffff::
 exit
int tun1
 tunnel vrf v1
 tunnel mode gre
 tunnel source eth2
 tunnel destination 1111::2
 nsh ena
 exit
nsh 2 255 int tun1 0000.1111.2222
nsh 3 254 int eth1 0000.1111.2222 rawpack keephdr
r3
hostname r3
vrf def v1
 rd 1:1
 exit
int eth1
 vrf for v1
 ipv6 addr 1111::2 ffff::
 exit
int tun1
 tunnel vrf v1
 tunnel mode gre
 tunnel source eth1
 tunnel destination 1111::1
 nsh ena
 exit
int eth2
 nsh ena
 nsh xconn 3 255
 exit
nsh 3 255 int tun1 0000.1111.2222
nsh 2 254 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::
 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-nsh08 file
 - Launch ContainerLab 
mpls-nsh08.ymltopology: 
   containerlab deploy --topo mpls-nsh08.yml  
mpls-nsh08.yml topology:  
   containerlab destroy --topo mpls-nsh08.yml