Example: ebgp vpn client¶
r1
hostname r1
vrf def v1
rd 1:1
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::
exit
route-map rm1
sequence 10 act deny
match aspath .*3.*
sequence 20 act permit
exit
router bgp4 1
vrf v1
no safe-ebgp
address uni
local-as 1
router-id 4.4.4.1
neigh 1.1.1.2 remote-as 2
neigh 1.1.1.2 route-map-in rm1
red conn
exit
router bgp6 1
vrf v1
no safe-ebgp
address uni
local-as 1
router-id 6.6.6.1
neigh 1234:1::2 remote-as 2
neigh 1234:1::2 route-map-in rm1
red conn
exit
r2
hostname r2
vrf def v1
rd 1:1
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::
exit
int eth2
vrf for v1
ipv4 addr 1.1.1.5 255.255.255.252
ipv6 addr 1234:2::1 ffff:ffff::
exit
router bgp4 1
vrf v1
no safe-ebgp
address uni
local-as 2
router-id 4.4.4.2
neigh 1.1.1.1 remote-as 1
neigh 1.1.1.1 internal-vpn
neigh 1.1.1.6 remote-as 3
neigh 1.1.1.6 attribset
red conn
exit
router bgp6 1
vrf v1
no safe-ebgp
address uni
local-as 2
router-id 6.6.6.2
neigh 1234:1::1 remote-as 1
neigh 1234:1::1 internal-vpn
neigh 1234:2::2 remote-as 3
neigh 1234:2::2 attribset
red conn
exit
r3
hostname r3
vrf def v1
rd 1:1
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::
exit
int eth2
vrf for v1
ipv4 addr 1.1.1.9 255.255.255.252
ipv6 addr 1234:3::1 ffff:ffff::
exit
router bgp4 1
vrf v1
no safe-ebgp
address uni
local-as 3
router-id 4.4.4.3
neigh 1.1.1.5 remote-as 2
neigh 1.1.1.5 attribset
neigh 1.1.1.10 remote-as 4
neigh 1.1.1.10 attribset
red conn
exit
router bgp6 1
vrf v1
no safe-ebgp
address uni
local-as 3
router-id 6.6.6.3
neigh 1234:2::1 remote-as 2
neigh 1234:2::1 attribset
neigh 1234:3::2 remote-as 4
neigh 1234:3::2 attribset
red conn
exit
r4
hostname r4
vrf def v1
rd 1:1
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::
exit
int eth2
vrf for v1
ipv4 addr 1.1.1.13 255.255.255.252
ipv6 addr 1234:4::1 ffff:ffff::
exit
router bgp4 1
vrf v1
no safe-ebgp
address uni
local-as 4
router-id 4.4.4.4
neigh 1.1.1.9 remote-as 3
neigh 1.1.1.9 attribset
neigh 1.1.1.14 remote-as 5
neigh 1.1.1.14 internal-vpn
red conn
exit
router bgp6 1
vrf v1
no safe-ebgp
address uni
local-as 4
router-id 6.6.6.4
neigh 1234:3::1 remote-as 3
neigh 1234:3::1 attribset
neigh 1234:4::2 remote-as 5
neigh 1234:4::2 internal-vpn
red conn
exit
r5
hostname r5
vrf def v1
rd 1:1
exit
int lo0
vrf for v1
ipv4 addr 2.2.2.5 255.255.255.255
ipv6 addr 4321::5 ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff
exit
int eth1
vrf for v1
ipv4 addr 1.1.1.14 255.255.255.252
ipv6 addr 1234:4::2 ffff:ffff::
exit
route-map rm1
sequence 10 act deny
match aspath .*3.*
sequence 20 act permit
exit
router bgp4 1
vrf v1
no safe-ebgp
address uni
local-as 5
router-id 4.4.4.5
neigh 1.1.1.13 remote-as 4
neigh 1.1.1.13 route-map-in rm1
red conn
exit
router bgp6 1
vrf v1
no safe-ebgp
address uni
local-as 5
router-id 6.6.6.5
neigh 1234:4::1 remote-as 4
neigh 1234:4::1 route-map-in rm1
red conn
exit
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
r2 tping 100 60 2.2.2.4 vrf v1 sou lo0
r2 tping 100 60 4321::4 vrf v1 sou lo0
r2 tping 0 60 2.2.2.5 vrf v1 sou lo0
r2 tping 0 60 4321::5 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
r3 tping 100 60 2.2.2.4 vrf v1 sou lo0
r3 tping 100 60 4321::4 vrf v1 sou lo0
r3 tping 0 60 2.2.2.1 vrf v1 sou lo0
r3 tping 0 60 4321::1 vrf v1 sou lo0
r3 tping 0 60 2.2.2.5 vrf v1 sou lo0
r3 tping 0 60 4321::5 vrf v1 sou lo0
r4 tping 100 60 2.2.2.2 vrf v1 sou lo0
r4 tping 100 60 4321::2 vrf v1 sou lo0
r4 tping 100 60 2.2.2.3 vrf v1 sou lo0
r4 tping 100 60 4321::3 vrf v1 sou lo0
r4 tping 100 60 2.2.2.5 vrf v1 sou lo0
r4 tping 100 60 4321::5 vrf v1 sou lo0
r4 tping 0 60 2.2.2.1 vrf v1 sou lo0
r4 tping 0 60 4321::1 vrf v1 sou lo0
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.5 vrf v1 sou lo0
r1 tping 100 60 4321::5 vrf v1 sou lo0
r1 tping 0 60 2.2.2.3 vrf v1 sou lo0
r1 tping 0 60 4321::3 vrf v1 sou lo0
r1 tping 0 60 2.2.2.4 vrf v1 sou lo0
r1 tping 0 60 4321::4 vrf v1 sou lo0
r5 tping 100 60 2.2.2.1 vrf v1 sou lo0
r5 tping 100 60 4321::1 vrf v1 sou lo0
r5 tping 100 60 2.2.2.4 vrf v1 sou lo0
r5 tping 100 60 4321::4 vrf v1 sou lo0
r5 tping 0 60 2.2.2.2 vrf v1 sou lo0
r5 tping 0 60 4321::2 vrf v1 sou lo0
r5 tping 0 60 2.2.2.3 vrf v1 sou lo0
r5 tping 0 60 4321::3 vrf v1 sou lo0
- Install ContainerLab as described here
- Fetch rout-bgp303 file
- Launch ContainerLab
rout-bgp303.yml
topology:
containerlab deploy --topo rout-bgp303.yml
rout-bgp303.yml
topology:
containerlab destroy --topo rout-bgp303.yml