Example: bgp with bier¶
r1
hostname r1
vrf def v1
rd 1:1
label-mode per-prefix
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 eth1
vrf for v1
ipv4 addr 1.1.1.1 255.255.255.252
ipv6 addr 1234:1::1 ffff:ffff::
mpls enable
exit
router bgp4 1
vrf v1
no safe-ebgp
local-as 1
bier 256 10 1 3
router-id 4.4.4.1
neigh 1.1.1.2 remote-as 2
neigh 1.1.1.2 bier
red conn
exit
router bgp6 1
vrf v1
no safe-ebgp
local-as 1
bier 256 10 1 3
router-id 6.6.6.1
neigh 1234:1::2 remote-as 2
neigh 1234:1::2 bier
red conn
exit
int tun1
tun sou lo0
tun dest 9.9.9.9
tun doma 2.2.2.4
tun vrf v1
tun key 1
tun mod bier
vrf for v1
ipv4 addr 3.3.3.1 255.255.255.252
exit
int tun2
tun sou lo0
tun dest 9999::9
tun doma 4321::4
tun vrf v1
tun key 1
tun mod bier
vrf for v1
ipv6 addr 4321::1111 ffff:ffff:ffff:ffff:ffff:ffff:ffff:fff0
exit
r2
hostname r2
vrf def v1
rd 1:1
label-mode per-prefix
exit
access-list test4
deny 1 any all any all
permit all any all any all
exit
access-list test6
deny all 4321:: ffff:: all 4321:: ffff:: all
permit all any all any all
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 eth1
vrf for v1
ipv4 addr 1.1.1.2 255.255.255.252
ipv6 addr 1234:1::2 ffff:ffff::
mpls enable
ipv4 access-group-in test4
ipv6 access-group-in test6
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
ipv4 access-group-in test4
ipv6 access-group-in test6
exit
router bgp4 1
vrf v1
no safe-ebgp
local-as 2
bier 256 10 2 3
router-id 4.4.4.2
neigh 1.1.1.1 remote-as 1
neigh 1.1.1.1 bier
neigh 1.1.1.6 remote-as 3
neigh 1.1.1.6 bier
red conn
exit
router bgp6 1
vrf v1
no safe-ebgp
local-as 2
bier 256 10 2 3
router-id 6.6.6.2
neigh 1234:1::1 remote-as 1
neigh 1234:1::1 bier
neigh 1234:2::2 remote-as 3
neigh 1234:2::2 bier
red conn
exit
r3
hostname r3
vrf def v1
rd 1:1
label-mode per-prefix
exit
access-list test4
deny 1 any all any all
permit all any all any all
exit
access-list test6
deny all 4321:: ffff:: all 4321:: ffff:: all
permit all any all any all
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 eth1
vrf for v1
ipv4 addr 1.1.1.6 255.255.255.252
ipv6 addr 1234:2::2 ffff:ffff::
mpls enable
ipv4 access-group-in test4
ipv6 access-group-in test6
exit
int eth2
vrf for v1
ipv4 addr 1.1.1.9 255.255.255.252
ipv6 addr 1234:3::1 ffff:ffff::
mpls enable
ipv4 access-group-in test4
ipv6 access-group-in test6
exit
router bgp4 1
vrf v1
no safe-ebgp
local-as 3
bier 256 10 3 3
router-id 4.4.4.3
neigh 1.1.1.5 remote-as 2
neigh 1.1.1.5 bier
neigh 1.1.1.10 remote-as 4
neigh 1.1.1.10 bier
red conn
exit
router bgp6 1
vrf v1
no safe-ebgp
local-as 3
bier 256 10 3 3
router-id 6.6.6.3
neigh 1234:2::1 remote-as 2
neigh 1234:2::1 bier
neigh 1234:3::2 remote-as 4
neigh 1234:3::2 bier
red conn
exit
r4
hostname r4
vrf def v1
rd 1:1
label-mode per-prefix
exit
int lo0
vrf for v1
ipv4 addr 2.2.2.4 255.255.255.255
ipv6 addr 4321::4 ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff
exit
int eth1
vrf for v1
ipv4 addr 1.1.1.10 255.255.255.252
ipv6 addr 1234:3::2 ffff:ffff::
mpls enable
exit
router bgp4 1
vrf v1
no safe-ebgp
local-as 4
bier 256 10 4 3
router-id 4.4.4.4
neigh 1.1.1.9 remote-as 3
neigh 1.1.1.9 bier
red conn
exit
router bgp6 1
vrf v1
no safe-ebgp
local-as 4
bier 256 10 4 3
router-id 6.6.6.4
neigh 1234:3::1 remote-as 3
neigh 1234:3::1 bier
red conn
exit
int tun1
tun sou lo0
tun dest 9.9.9.9
tun doma 2.2.2.1
tun vrf v1
tun key 3
tun mod bier
vrf for v1
ipv4 addr 3.3.3.2 255.255.255.252
exit
int tun2
tun sou lo0
tun dest 9999::9
tun doma 4321::1
tun vrf v1
tun key 3
tun mod bier
vrf for v1
ipv6 addr 4321::1112 ffff:ffff:ffff:ffff:ffff:ffff:ffff:fff0
exit
r1 tping 0 20 2.2.2.4 vrf v1 sou lo0
r4 tping 0 20 2.2.2.1 vrf v1 sou lo0
r1 tping 0 20 4321::4 vrf v1 sou lo0
r4 tping 0 20 4321::1 vrf v1 sou lo0
r1 tping 100 60 3.3.3.2 vrf v1
r1 tping 100 60 4321::1112 vrf v1
r4 tping 100 60 3.3.3.1 vrf v1
r4 tping 100 60 4321::1111 vrf v1
- Install ContainerLab as described here
- Fetch rout-bgp313 file
- Launch ContainerLab
rout-bgp313.yml
topology:
containerlab deploy --topo rout-bgp313.yml
rout-bgp313.yml
topology:
containerlab destroy --topo rout-bgp313.yml