Skip to content

Example: policy routing with interface and nexthop between vrfs

Alt text

r1

hostname r1
vrf def v1
 rd 1:1
 exit
int lo0
 vrf for v1
 ipv4 addr 2.2.2.101 255.255.255.255
 ipv6 addr 4321::101 ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff
 exit
int eth1
 vrf for v1
 ipv4 addr 1.1.1.1 255.255.255.252
 ipv6 addr 1234:1::1 ffff:ffff::
 exit
access-list a2b4
 permit all 2.2.2.101 255.255.255.255 all 2.2.2.201 255.255.255.255 all
 exit
access-list a2b6
 permit all 4321::101 ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff all 4321::201 ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff all
 exit
ipv4 pbr v1 a2b4 v1 int eth1 next 1.1.1.2
ipv6 pbr v1 a2b6 v1 int eth1 next 1234:1::2

r2

hostname r2
vrf def v1
 rd 1:1
 exit
vrf def v2
 rd 1:1
 exit
int eth1
 vrf for v1
 ipv4 addr 1.1.1.2 255.255.255.252
 ipv6 addr 1234:1::2 ffff:ffff::
 exit
int eth2
 vrf for v2
 ipv4 addr 1.1.1.6 255.255.255.252
 ipv6 addr 1234:2::2 ffff:ffff::
 exit
access-list a2b4
 permit all 2.2.2.101 255.255.255.255 all 2.2.2.201 255.255.255.255 all
 exit
access-list b2a4
 permit all 2.2.2.201 255.255.255.255 all 2.2.2.101 255.255.255.255 all
 exit
access-list a2b6
 permit all 4321::101 ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff all 4321::201 ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff all
 exit
access-list b2a6
 permit all 4321::201 ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff all 4321::101 ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff all
 exit
ipv4 pbr v1 a2b4 v2 int eth2 next 1.1.1.5
ipv6 pbr v1 a2b6 v2 int eth2 next 1234:2::1
ipv4 pbr v2 b2a4 v1 int eth1 next 1.1.1.1
ipv6 pbr v2 b2a6 v1 int eth1 next 1234:1::1

r3

hostname r3
vrf def v1
 rd 1:1
 exit
int lo0
 vrf for v1
 ipv4 addr 2.2.2.201 255.255.255.255
 ipv6 addr 4321::201 ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff
 exit
int eth1
 vrf for v1
 ipv4 addr 1.1.1.5 255.255.255.252
 ipv6 addr 1234:2::1 ffff:ffff::
 exit
access-list b2a4
 permit all 2.2.2.201 255.255.255.255 all 2.2.2.101 255.255.255.255 all
 exit
access-list b2a6
 permit all 4321::201 ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff all 4321::101 ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff all
 exit
ipv4 pbr v1 b2a4 v1 int eth1 next 1.1.1.6
ipv6 pbr v1 b2a6 v1 int eth1 next 1234:2::2
r1 tping 100 5 2.2.2.201 vrf v1 sou lo0
r1 tping 100 5 4321::201 vrf v1 sou lo0
r3 tping 100 5 2.2.2.101 vrf v1 sou lo0
r3 tping 100 5 4321::101 vrf v1 sou lo0
r1 tping 0 5 2.2.2.201 vrf v1
r1 tping 0 5 4321::201 vrf v1
r3 tping 0 5 2.2.2.101 vrf v1
r3 tping 0 5 4321::101 vrf v1
  1. Install ContainerLab as described here
  2. Fetch rout-pbr02 file
  3. Launch ContainerLab rout-pbr02.yml topology:

   containerlab deploy --topo rout-pbr02.yml  
4. Destroy ContainerLab rout-pbr02.yml topology:

   containerlab destroy --topo rout-pbr02.yml  
5. Copy-paste configuration for each node in the lab topology

  1. Fetch or compile freeRtr rtr.jar file.
    You can grab it here
  2. Fetch rout-pbr02.tst file here
  3. Launch rout-pbr02.tst test:

   java -jar ../../rtr.jar test tester rout-pbr02 path ./ temp ./ wait
4. Destroy freeRtr rout-pbr02.tst test:

   Ctrl-C (In freeRtr test window)