Example: bgp vpn with export policy¶
r1
hostname r1
vrf def v1
rd 1:1
label-mode per-prefix
exit
vrf def v3
rd 1:3
rt-both 1:3
exit
int lo0
vrf for v1
ipv4 addr 2.2.2.1 255.255.255.255
ipv6 addr 4321::1 ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff
exit
int lo2
vrf for v3
ipv4 addr 3.3.3.1 255.255.255.255
ipv6 addr 3333::1 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::
mpls enable
mpls ldp4
mpls ldp6
exit
ipv4 route v1 2.2.2.2 255.255.255.255 1.1.1.2
ipv6 route v1 4321::2 ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff 1234:1::2
ipv4 route v1 2.2.2.3 255.255.255.255 1.1.1.2
ipv6 route v1 4321::3 ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff 1234:1::2
router bgp4 1
vrf v1
address vpnuni
local-as 1
router-id 4.4.4.1
neigh 2.2.2.2 remote-as 1
neigh 2.2.2.2 update lo0
neigh 2.2.2.2 send-comm both
afi-vrf v3 ena
afi-vrf v3 red conn
exit
router bgp6 1
vrf v1
address vpnuni
local-as 1
router-id 6.6.6.1
neigh 4321::2 remote-as 1
neigh 4321::2 update lo0
neigh 4321::2 send-comm both
afi-vrf v3 ena
afi-vrf v3 red conn
exit
r2
hostname r2
vrf def v1
rd 1:1
label-mode per-prefix
exit
route-policy rp4
if network 3.3.3.0/24 ge 32 le 32
pass
enif
exit
route-policy rp6
if network 3333::/64 ge 128 le 128
pass
enif
exit
vrf def v3
rd 1:3
rt-both 1:3
export4policy rp4
export6policy rp6
exit
int lo0
vrf for v1
ipv4 addr 2.2.2.2 255.255.255.255
ipv6 addr 4321::2 ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff
exit
int lo2
vrf for v3
ipv4 addr 3.3.3.2 255.255.255.255
ipv6 addr 3333::2 ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff
exit
int lo3
vrf for v3
ipv4 addr 4.4.4.2 255.255.255.255
ipv6 addr 4444::2 ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff
exit
int eth1
vrf for v1
ipv4 addr 1.1.1.2 255.255.255.252
ipv6 addr 1234:1::2 ffff:ffff::
mpls enable
mpls ldp4
mpls ldp6
exit
int eth2
vrf for v1
ipv4 addr 1.1.1.5 255.255.255.252
ipv6 addr 1234:2::1 ffff:ffff::
mpls enable
mpls ldp4
mpls ldp6
exit
ipv4 route v1 2.2.2.3 255.255.255.255 1.1.1.6
ipv6 route v1 4321::3 ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff 1234:2::2
ipv4 route v1 2.2.2.1 255.255.255.255 1.1.1.1
ipv6 route v1 4321::1 ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff 1234:1::1
router bgp4 1
vrf v1
address vpnuni
local-as 1
router-id 4.4.4.2
neigh 2.2.2.1 remote-as 1
neigh 2.2.2.1 update lo0
neigh 2.2.2.1 send-comm both
neigh 2.2.2.1 route-reflector
neigh 2.2.2.3 remote-as 1
neigh 2.2.2.3 update lo0
neigh 2.2.2.3 send-comm both
neigh 2.2.2.3 route-reflector
afi-vrf v3 ena
afi-vrf v3 red conn
exit
router bgp6 1
vrf v1
address vpnuni
local-as 1
router-id 6.6.6.2
neigh 4321::1 remote-as 1
neigh 4321::1 update lo0
neigh 4321::1 send-comm both
neigh 4321::1 route-reflector
neigh 4321::3 remote-as 1
neigh 4321::3 update lo0
neigh 4321::3 send-comm both
neigh 4321::3 route-reflector
afi-vrf v3 ena
afi-vrf v3 red conn
exit
r3
hostname r3
vrf def v1
rd 1:1
label-mode per-prefix
exit
vrf def v3
rd 1:3
rt-both 1:3
exit
int lo0
vrf for v1
ipv4 addr 2.2.2.3 255.255.255.255
ipv6 addr 4321::3 ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff
exit
int lo2
vrf for v3
ipv4 addr 3.3.3.3 255.255.255.255
ipv6 addr 3333::3 ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff
exit
int eth1
vrf for v1
ipv4 addr 1.1.1.6 255.255.255.252
ipv6 addr 1234:2::2 ffff:ffff::
mpls enable
mpls ldp4
mpls ldp6
exit
ipv4 route v1 2.2.2.2 255.255.255.255 1.1.1.5
ipv6 route v1 4321::2 ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff 1234:2::1
ipv4 route v1 2.2.2.1 255.255.255.255 1.1.1.5
ipv6 route v1 4321::1 ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff 1234:2::1
router bgp4 1
vrf v1
address vpnuni
local-as 1
router-id 4.4.4.3
neigh 2.2.2.2 remote-as 1
neigh 2.2.2.2 update lo0
neigh 2.2.2.2 send-comm both
afi-vrf v3 ena
afi-vrf v3 red conn
exit
router bgp6 1
vrf v1
address vpnuni
local-as 1
router-id 6.6.6.3
neigh 4321::2 remote-as 1
neigh 4321::2 update lo0
neigh 4321::2 send-comm both
afi-vrf v3 ena
afi-vrf v3 red conn
exit
r1 tping 100 60 2.2.2.2 vrf v1 sou lo0
r1 tping 100 60 4321::2 vrf v1 sou lo0
r1 tping 100 60 2.2.2.3 vrf v1 sou lo0
r1 tping 100 60 4321::3 vrf v1 sou lo0
r2 tping 100 60 2.2.2.1 vrf v1 sou lo0
r2 tping 100 60 4321::1 vrf v1 sou lo0
r2 tping 100 60 2.2.2.3 vrf v1 sou lo0
r2 tping 100 60 4321::3 vrf v1 sou lo0
r3 tping 100 60 2.2.2.1 vrf v1 sou lo0
r3 tping 100 60 4321::1 vrf v1 sou lo0
r3 tping 100 60 2.2.2.2 vrf v1 sou lo0
r3 tping 100 60 4321::2 vrf v1 sou lo0
r1 tping 100 60 3.3.3.2 vrf v3 sou lo2
r1 tping 100 60 3333::2 vrf v3 sou lo2
r1 tping 100 60 3.3.3.3 vrf v3 sou lo2
r1 tping 100 60 3333::3 vrf v3 sou lo2
r2 tping 100 60 3.3.3.1 vrf v3 sou lo2
r2 tping 100 60 3333::1 vrf v3 sou lo2
r2 tping 100 60 3.3.3.3 vrf v3 sou lo2
r2 tping 100 60 3333::3 vrf v3 sou lo2
r3 tping 100 60 3.3.3.1 vrf v3 sou lo2
r3 tping 100 60 3333::1 vrf v3 sou lo2
r3 tping 100 60 3.3.3.2 vrf v3 sou lo2
r3 tping 100 60 3333::2 vrf v3 sou lo2
r2 tping 0 60 3.3.3.1 vrf v3 sou lo3
r2 tping 0 60 3333::1 vrf v3 sou lo3
r2 tping 0 60 3.3.3.3 vrf v3 sou lo3
r2 tping 0 60 3333::3 vrf v3 sou lo3
- Install ContainerLab as described here
- Fetch rout-bgp345 file
- Launch ContainerLab
rout-bgp345.yml
topology:
containerlab deploy --topo rout-bgp345.yml
rout-bgp345.yml
topology:
containerlab destroy --topo rout-bgp345.yml