Tunnels VPN Hub‘n Spoke routés via BGP
Voici un exemple de routage dynamique BGP dans le cadre d’un réseau VPN en étoile de type Hub and Spoke.
Configuration des tunnels
Pour le paramétrage de la politique IPsec Hub‘n Spoke, consultez le HOW TO cité ci-dessous. Dans notre cas, les différences de paramétrage par rapport à cette procédure consistent à configurer les extrémités de trafic au moyen d’interfaces virtuelles, au lieu de réseaux distants dans la politique IPsec (voir paragraphe suivant).
Rendez-vous à l’adresse http://documentation.stormshield.eu/. Reportez-vous au HOW TO : VPN IPsec - Configuration Hub and Spoke, et consulter le cas n° 1 : trafic interne via les tunnels IPsec.
Site principal
TunnelA
Réseau local : | Interface ipsec1 (172.16.0.1) |
Correspondant : |
Site_SpokeA |
Réseau distant : | Remote_tunnelA (172.16.0.2) |
TunnelB
Réseau local : | Interface ipsec2 (172.16.0.5) |
Correspondant : |
Site_SpokeB |
Réseau distant : | Remote_tunnelB (172.16.0.6) |
Spoke A
Réseau local : | Interface ipsec1 (172.16.0.2) |
Correspondant : |
Site_FW_Hub |
Réseau distant : | Remote_tunnelA (172.16.0.1) |
Spoke B
Réseau local : | Interface ipsec1 (172.16.0.6) |
Correspondant : |
Site_FW_Hub |
Réseau distant : | Remote_tunnelB (172.16.0.5) |
Configuration BGP du site principal (Hub)
protocol direct { |
||
} | ||
protocol kernel { | ||
learn; | # Learn all alien routes from the kernel | |
persist; | # Don't remove routes on bird shutdown | |
scan time 20; | # Scan kernel routing table every 20 seconds | |
import all; | # Default is import all | |
export all; | # Default is export none | |
preference 254; | # Protect existing routes | |
} | ||
# This pseudo-protocol watches all interface up/down events. | ||
protocol device { | ||
scan time 10; | # Scan interfaces every 10 seconds | |
} | ||
filter f_import { | ||
if source = RTS_BGP then |
||
accept; |
||
else | ||
reject; |
||
} | ||
filter f_export { | ||
# local shared networks and BGP routes | ||
if( (net = 192.168.0.0/24) || (source = RTS_BGP) ) then |
||
accept; |
||
else |
||
reject; |
||
} | ||
router id <ip_pub_hub>; | ||
template bgp star { | ||
local as 65000; |
||
import filter f_import; |
||
export filter f_export; |
||
hold time 5; |
||
multihop; |
||
rr client; |
||
next hop self; |
||
} | ||
protocol | bgp router_spokeA from star { | |
neighbor 172.16.0.2 as 65000; | ||
source address 172.16.0.1; |
||
} | ||
protocol bgp router_spokeB from star { | ||
neighbor 172.16.0.6 as 65000; |
||
source address 172.16.0.5; |
||
} |
Configuration BGP du site satellite Spoke A
protocol direct { |
||
} | ||
protocol kernel { | ||
learn; |
# Learn all alien routes from the kernel |
|
persist; | # Don't remove routes on bird shutdown | |
scan time 20; | # Scan kernel routing table every 20 seconds | |
import all; | # Default is import all | |
export all; | # Default is export none | |
preference 254; | # Protect existing routes | |
} | ||
protocol device { | ||
scan time 10; |
# Scan interfaces every 10 seconds |
|
} | ||
filter filter_export_net { | ||
if(net = 192.168.1.0/24) then { |
||
accept; |
||
} | ||
else reject; |
||
} |
||
router id <ip_pub_spokeA>; | ||
protocol bgp router_tunnel1 { | ||
local as 65000; |
||
neighbor 172.16.0.1 as 65000; |
||
hold time 5; |
||
multihop; |
||
import all; |
||
export filter filter_export_net; |
||
source address 172.16.0.2; |
||
} |
Configuration BGP du site satellite Spoke B
protocol direct { |
||
} |
||
protocol kernel { | ||
learn; |
# Learn all alien routes from the kernel |
|
persist; |
# Don't remove routes on bird shutdown |
|
scan time 20; |
# Scan kernel routing table every 20 seconds |
|
import all; |
# Default is import all |
|
export all; |
# Default is export none |
|
preference 254; |
# Protect existing routes |
|
} | ||
protocol device { | ||
scan time 10; |
# Scan interfaces every 10 seconds |
|
} |
||
filter |
filter_export_net { |
|
if(net = 192.168.2.0/24) then { |
||
accept; |
||
} | ||
else reject; |
||
} |
||
router id <ip_pub_spokeB>; | ||
protocol bgp router_tunnel2 { | ||
local as 65000; |
||
neighbor 172.16.0.5 as 65000; |
||
hold time 5; |
||
multihop; |
||
import all; |
||
export filter filter_export_net; |
||
source address 172.16.0.6; |
||
} |
Vérification des tables de routage
Table de routage sur le site principal (Hub) :
bird> show route |
||
0.0.0.0/0 | via 10.60.0.254 on em0 [kernel1 10:16] * (254) | |
10.60.3.127/32 | dev lo0 [kernel1 10:16] * (254) | |
192.168.0.0/24 | dev em1 [direct1 10:16] * (240) | |
192.168.1.0/24 | dev em2 [direct1 10:16] * (240) | |
192.168.1.0/24 | via 172.16.0.2 on enc1 [router_tunnelA 10:22]*(100/0)[AS65001i] | |
192.168.2.0/24 | via 172.16.0.6 on enc1 [router_tunnelB 10:21]*(100/0)[AS65002i] | |
192.168.0.254/32 | dev lo0 [kernel1 10:16] * (254) | |
192.168.1.254/32 | dev lo0 [kernel1 10:16] * (254) | |
172.16.0.0/30 | dev lo1 [direct1 10:16] * (240) | |
10.60.0.0/16 | dev em0 [direct1 10:16] * (240) | |
172.16.0.4/30 | dev lo2 [direct1 10:16] * (240) |
Table de routage sur spokeA :
bird> show route |
||
0.0.0.0/0 | via 10.60.0.254 on em0 [kernel1 13:32] * (254) | |
192.168.0.0/24 | via 172.16.0.1 on enc1 [router_tunnelA 13:32] * (100/0) [i] | |
192.168.2.0/24 |
via 172.16.0.1 on enc1 [router_tunnelA 13:32] * (100/0) [i] |
|
192.168.1.0/24 | dev em1 [direct1 13:32] * (240) | |
172.16.0.0/30 | dev lo1 [direct1 13:32] * (240) | |
10.60.3.128/32 | dev lo0 [kernel1 13:32] * (254) | |
10.60.0.0/16 | dev em0 [direct1 13:32] * (240) |