summaryrefslogtreecommitdiff
path: root/docs/configexamples/dual-hub-dmvpn.rst
diff options
context:
space:
mode:
authorekhudiyev <88712424+ekhudiyev@users.noreply.github.com>2021-12-13 13:57:47 +0400
committerGitHub <noreply@github.com>2021-12-13 13:57:47 +0400
commit89decd0d67ac78a0f874aed22aa364409c75b80e (patch)
treea1589bc90d301d81aff0c38ae46c76ec40c88434 /docs/configexamples/dual-hub-dmvpn.rst
parente81786f258dd91ecd5fa6094c356752bc9183ccf (diff)
downloadvyos-documentation-89decd0d67ac78a0f874aed22aa364409c75b80e.tar.gz
vyos-documentation-89decd0d67ac78a0f874aed22aa364409c75b80e.zip
Updated document with the main information.
Diffstat (limited to 'docs/configexamples/dual-hub-dmvpn.rst')
-rw-r--r--docs/configexamples/dual-hub-dmvpn.rst1043
1 files changed, 1043 insertions, 0 deletions
diff --git a/docs/configexamples/dual-hub-dmvpn.rst b/docs/configexamples/dual-hub-dmvpn.rst
index f103972e..ea4d69f7 100644
--- a/docs/configexamples/dual-hub-dmvpn.rst
+++ b/docs/configexamples/dual-hub-dmvpn.rst
@@ -198,3 +198,1046 @@ ___________________________________
set high-availability vrrp group HQ rfc3768-compatibility
set high-availability vrrp group HQ virtual-address '192.168.0.254/24'
set high-availability vrrp group HQ vrid '1'
+
+
+
+Step-3: DMVPN configuration between Hub and Spoke devices
+=========================================================
+
+This section provides an example configuration of the DMVPN enabled devices.
+Hub devices are configured with static IPv4 addresses on the uplink interfaces
+while Spoke devices receive addresses dynamically from a pre-defined DHCP
+pool configured on ISP router. For redundancy purposes, we use 1 tunnel
+interface on each Hub device and 2 tunnel interfaces on Spoke devices
+destined to each of the Hubs. For the optimal tunnel operation timers are
+significantly decreased and set to the following values:
+
+**NHRP** tunnel holding time - 30 seconds
+
+**IKE DPD** enabled with "restart" action set, interval 3 and timeout
+30 seconds
+
+**Note**: these values are used only for the lab demonstration and may not
+suit exclusive production networks.
+
+- Hub-1:
+
+.. code-block:: none
+
+ set interfaces tunnel tun100 address '172.16.253.134/29'
+ set interfaces tunnel tun100 encapsulation 'gre'
+ set interfaces tunnel tun100 multicast 'enable'
+ set interfaces tunnel tun100 parameters ip key '1'
+ set interfaces tunnel tun100 source-address '10.11.0.1'
+
+ set protocols nhrp tunnel tun100 cisco-authentication 'secret'
+ set protocols nhrp tunnel tun100 holding-time '30'
+ set protocols nhrp tunnel tun100 multicast 'dynamic'
+ set protocols nhrp tunnel tun100 redirect
+ set protocols nhrp tunnel tun100 shortcut
+
+ set vpn ipsec esp-group ESP-HUB compression 'disable'
+ set vpn ipsec esp-group ESP-HUB lifetime '1800'
+ set vpn ipsec esp-group ESP-HUB mode 'transport'
+ set vpn ipsec esp-group ESP-HUB pfs 'dh-group2'
+ set vpn ipsec esp-group ESP-HUB proposal 1 encryption 'aes256'
+ set vpn ipsec esp-group ESP-HUB proposal 1 hash 'sha1'
+ set vpn ipsec esp-group ESP-HUB proposal 2 encryption '3des'
+ set vpn ipsec esp-group ESP-HUB proposal 2 hash 'md5'
+ set vpn ipsec ike-group IKE-HUB close-action 'none'
+ set vpn ipsec ike-group IKE-HUB dead-peer-detection action 'restart'
+ set vpn ipsec ike-group IKE-HUB dead-peer-detection interval '3'
+ set vpn ipsec ike-group IKE-HUB dead-peer-detection timeout '30'
+ set vpn ipsec ike-group IKE-HUB ikev2-reauth 'no'
+ set vpn ipsec ike-group IKE-HUB key-exchange 'ikev2'
+ set vpn ipsec ike-group IKE-HUB lifetime '3600'
+ set vpn ipsec ike-group IKE-HUB proposal 1 dh-group '2'
+ set vpn ipsec ike-group IKE-HUB proposal 1 encryption 'aes256'
+ set vpn ipsec ike-group IKE-HUB proposal 1 hash 'sha1'
+ set vpn ipsec ike-group IKE-HUB proposal 2 dh-group '2'
+ set vpn ipsec ike-group IKE-HUB proposal 2 encryption 'aes128'
+ set vpn ipsec ike-group IKE-HUB proposal 2 hash 'sha1'
+ set vpn ipsec ipsec-interfaces interface 'eth0'
+ set vpn ipsec profile NHRPVPN authentication mode 'pre-shared-secret'
+ set vpn ipsec profile NHRPVPN authentication pre-shared-secret 'secret'
+ set vpn ipsec profile NHRPVPN bind tunnel 'tun100'
+ set vpn ipsec profile NHRPVPN esp-group 'ESP-HUB'
+ set vpn ipsec profile NHRPVPN ike-group 'IKE-HUB'
+
+- Hub-2:
+
+.. code-block:: none
+
+ set interfaces tunnel tun100 address '172.16.254.134/29'
+ set interfaces tunnel tun100 encapsulation 'gre'
+ set interfaces tunnel tun100 multicast 'enable'
+ set interfaces tunnel tun100 parameters ip key '2'
+ set interfaces tunnel tun100 source-address '10.21.0.1'
+
+ set protocols nhrp tunnel tun100 cisco-authentication 'secret'
+ set protocols nhrp tunnel tun100 holding-time '30'
+ set protocols nhrp tunnel tun100 multicast 'dynamic'
+ set protocols nhrp tunnel tun100 redirect
+ set protocols nhrp tunnel tun100 shortcut
+
+ set vpn ipsec esp-group ESP-HUB compression 'disable'
+ set vpn ipsec esp-group ESP-HUB lifetime '1800'
+ set vpn ipsec esp-group ESP-HUB mode 'transport'
+ set vpn ipsec esp-group ESP-HUB pfs 'dh-group2'
+ set vpn ipsec esp-group ESP-HUB proposal 1 encryption 'aes256'
+ set vpn ipsec esp-group ESP-HUB proposal 1 hash 'sha1'
+ set vpn ipsec esp-group ESP-HUB proposal 2 encryption '3des'
+ set vpn ipsec esp-group ESP-HUB proposal 2 hash 'md5'
+ set vpn ipsec ike-group IKE-HUB close-action 'none'
+ set vpn ipsec ike-group IKE-HUB dead-peer-detection action 'restart'
+ set vpn ipsec ike-group IKE-HUB dead-peer-detection interval '3'
+ set vpn ipsec ike-group IKE-HUB dead-peer-detection timeout '30'
+ set vpn ipsec ike-group IKE-HUB ikev2-reauth 'no'
+ set vpn ipsec ike-group IKE-HUB key-exchange 'ikev2'
+ set vpn ipsec ike-group IKE-HUB lifetime '3600'
+ set vpn ipsec ike-group IKE-HUB proposal 1 dh-group '2'
+ set vpn ipsec ike-group IKE-HUB proposal 1 encryption 'aes256'
+ set vpn ipsec ike-group IKE-HUB proposal 1 hash 'sha1'
+ set vpn ipsec ike-group IKE-HUB proposal 2 dh-group '2'
+ set vpn ipsec ike-group IKE-HUB proposal 2 encryption 'aes128'
+ set vpn ipsec ike-group IKE-HUB proposal 2 hash 'sha1'
+ set vpn ipsec ipsec-interfaces interface 'eth0'
+ set vpn ipsec profile NHRPVPN authentication mode 'pre-shared-secret'
+ set vpn ipsec profile NHRPVPN authentication pre-shared-secret 'secret'
+ set vpn ipsec profile NHRPVPN bind tunnel 'tun100'
+ set vpn ipsec profile NHRPVPN esp-group 'ESP-HUB'
+ set vpn ipsec profile NHRPVPN ike-group 'IKE-HUB'
+
+- Spoke-1:
+
+.. code-block:: none
+
+ set interfaces tunnel tun100 address '172.16.253.131/29'
+ set interfaces tunnel tun100 encapsulation 'gre'
+ set interfaces tunnel tun100 multicast 'enable'
+ set interfaces tunnel tun100 parameters ip key '1'
+ set interfaces tunnel tun100 source-address '0.0.0.0'
+ set interfaces tunnel tun200 address '172.16.254.131/29'
+ set interfaces tunnel tun200 encapsulation 'gre'
+ set interfaces tunnel tun200 multicast 'enable'
+ set interfaces tunnel tun200 parameters ip key '2'
+ set interfaces tunnel tun200 source-address '0.0.0.0'
+
+ set protocols nhrp tunnel tun100 cisco-authentication 'secret'
+ set protocols nhrp tunnel tun100 holding-time '30'
+ set protocols nhrp tunnel tun100 map 172.16.253.134/29 nbma-address '10.11.0.1'
+ set protocols nhrp tunnel tun100 map 172.16.253.134/29 register
+ set protocols nhrp tunnel tun100 multicast 'nhs'
+ set protocols nhrp tunnel tun100 redirect
+ set protocols nhrp tunnel tun100 shortcut
+ set protocols nhrp tunnel tun200 cisco-authentication 'secret'
+ set protocols nhrp tunnel tun200 holding-time '30'
+ set protocols nhrp tunnel tun200 map 172.16.254.134/29 nbma-address '10.21.0.1'
+ set protocols nhrp tunnel tun200 map 172.16.254.134/29 register
+ set protocols nhrp tunnel tun200 multicast 'nhs'
+ set protocols nhrp tunnel tun200 redirect
+ set protocols nhrp tunnel tun200 shortcut
+
+ set vpn ipsec esp-group ESP-HUB compression 'disable'
+ set vpn ipsec esp-group ESP-HUB lifetime '1800'
+ set vpn ipsec esp-group ESP-HUB mode 'transport'
+ set vpn ipsec esp-group ESP-HUB pfs 'dh-group2'
+ set vpn ipsec esp-group ESP-HUB proposal 1 encryption 'aes256'
+ set vpn ipsec esp-group ESP-HUB proposal 1 hash 'sha1'
+ set vpn ipsec esp-group ESP-HUB proposal 2 encryption '3des'
+ set vpn ipsec esp-group ESP-HUB proposal 2 hash 'md5'
+ set vpn ipsec ike-group IKE-HUB close-action 'none'
+ set vpn ipsec ike-group IKE-HUB dead-peer-detection action 'restart'
+ set vpn ipsec ike-group IKE-HUB dead-peer-detection interval '3'
+ set vpn ipsec ike-group IKE-HUB dead-peer-detection timeout '30'
+ set vpn ipsec ike-group IKE-HUB ikev2-reauth 'no'
+ set vpn ipsec ike-group IKE-HUB key-exchange 'ikev2'
+ set vpn ipsec ike-group IKE-HUB lifetime '3600'
+ set vpn ipsec ike-group IKE-HUB proposal 1 dh-group '2'
+ set vpn ipsec ike-group IKE-HUB proposal 1 encryption 'aes256'
+ set vpn ipsec ike-group IKE-HUB proposal 1 hash 'sha1'
+ set vpn ipsec ike-group IKE-HUB proposal 2 dh-group '2'
+ set vpn ipsec ike-group IKE-HUB proposal 2 encryption 'aes128'
+ set vpn ipsec ike-group IKE-HUB proposal 2 hash 'sha1'
+ set vpn ipsec ipsec-interfaces interface 'eth0'
+ set vpn ipsec profile NHRPVPN authentication mode 'pre-shared-secret'
+ set vpn ipsec profile NHRPVPN authentication pre-shared-secret 'secret'
+ set vpn ipsec profile NHRPVPN bind tunnel 'tun100'
+ set vpn ipsec profile NHRPVPN bind tunnel 'tun200'
+ set vpn ipsec profile NHRPVPN esp-group 'ESP-HUB'
+ set vpn ipsec profile NHRPVPN ike-group 'IKE-HUB'
+
+- Spoke-2:
+
+.. code-block:: none
+
+ set interfaces tunnel tun100 address '172.16.253.132/29'
+ set interfaces tunnel tun100 encapsulation 'gre'
+ set interfaces tunnel tun100 multicast 'enable'
+ set interfaces tunnel tun100 parameters ip key '1'
+ set interfaces tunnel tun100 source-address '0.0.0.0'
+ set interfaces tunnel tun200 address '172.16.254.132/29'
+ set interfaces tunnel tun200 encapsulation 'gre'
+ set interfaces tunnel tun200 multicast 'enable'
+ set interfaces tunnel tun200 parameters ip key '2'
+ set interfaces tunnel tun200 source-address '0.0.0.0'
+
+ set protocols nhrp tunnel tun100 cisco-authentication 'secret'
+ set protocols nhrp tunnel tun100 holding-time '30'
+ set protocols nhrp tunnel tun100 map 172.16.253.134/29 nbma-address '10.11.0.1'
+ set protocols nhrp tunnel tun100 map 172.16.253.134/29 register
+ set protocols nhrp tunnel tun100 multicast 'nhs'
+ set protocols nhrp tunnel tun100 redirect
+ set protocols nhrp tunnel tun100 shortcut
+ set protocols nhrp tunnel tun200 cisco-authentication 'secret'
+ set protocols nhrp tunnel tun200 holding-time '30'
+ set protocols nhrp tunnel tun200 map 172.16.254.134/29 nbma-address '10.21.0.1'
+ set protocols nhrp tunnel tun200 map 172.16.254.134/29 register
+ set protocols nhrp tunnel tun200 multicast 'nhs'
+ set protocols nhrp tunnel tun200 redirect
+ set protocols nhrp tunnel tun200 shortcut
+
+ set vpn ipsec esp-group ESP-HUB compression 'disable'
+ set vpn ipsec esp-group ESP-HUB lifetime '1800'
+ set vpn ipsec esp-group ESP-HUB mode 'transport'
+ set vpn ipsec esp-group ESP-HUB pfs 'dh-group2'
+ set vpn ipsec esp-group ESP-HUB proposal 1 encryption 'aes256'
+ set vpn ipsec esp-group ESP-HUB proposal 1 hash 'sha1'
+ set vpn ipsec esp-group ESP-HUB proposal 2 encryption '3des'
+ set vpn ipsec esp-group ESP-HUB proposal 2 hash 'md5'
+ set vpn ipsec ike-group IKE-HUB close-action 'none'
+ set vpn ipsec ike-group IKE-HUB dead-peer-detection action 'restart'
+ set vpn ipsec ike-group IKE-HUB dead-peer-detection interval '3'
+ set vpn ipsec ike-group IKE-HUB dead-peer-detection timeout '30'
+ set vpn ipsec ike-group IKE-HUB ikev2-reauth 'no'
+ set vpn ipsec ike-group IKE-HUB key-exchange 'ikev2'
+ set vpn ipsec ike-group IKE-HUB lifetime '3600'
+ set vpn ipsec ike-group IKE-HUB proposal 1 dh-group '2'
+ set vpn ipsec ike-group IKE-HUB proposal 1 encryption 'aes256'
+ set vpn ipsec ike-group IKE-HUB proposal 1 hash 'sha1'
+ set vpn ipsec ike-group IKE-HUB proposal 2 dh-group '2'
+ set vpn ipsec ike-group IKE-HUB proposal 2 encryption 'aes128'
+ set vpn ipsec ike-group IKE-HUB proposal 2 hash 'sha1'
+ set vpn ipsec ipsec-interfaces interface 'eth0'
+ set vpn ipsec profile NHRPVPN authentication mode 'pre-shared-secret'
+ set vpn ipsec profile NHRPVPN authentication pre-shared-secret 'secret'
+ set vpn ipsec profile NHRPVPN bind tunnel 'tun100'
+ set vpn ipsec profile NHRPVPN bind tunnel 'tun200'
+ set vpn ipsec profile NHRPVPN esp-group 'ESP-HUB'
+ set vpn ipsec profile NHRPVPN ike-group 'IKE-HUB'
+
+- Spoke-3:
+
+.. code-block:: none
+
+ set interfaces tunnel tun100 address '172.16.253.133/29'
+ set interfaces tunnel tun100 encapsulation 'gre'
+ set interfaces tunnel tun100 multicast 'enable'
+ set interfaces tunnel tun100 parameters ip key '1'
+ set interfaces tunnel tun100 source-address '0.0.0.0'
+ set interfaces tunnel tun200 address '172.16.254.133/29'
+ set interfaces tunnel tun200 encapsulation 'gre'
+ set interfaces tunnel tun200 multicast 'enable'
+ set interfaces tunnel tun200 parameters ip key '2'
+ set interfaces tunnel tun200 source-address '0.0.0.0'
+
+ set protocols nhrp tunnel tun100 cisco-authentication 'secret'
+ set protocols nhrp tunnel tun100 holding-time '30'
+ set protocols nhrp tunnel tun100 map 172.16.253.134/29 nbma-address '10.11.0.1'
+ set protocols nhrp tunnel tun100 map 172.16.253.134/29 register
+ set protocols nhrp tunnel tun100 multicast 'nhs'
+ set protocols nhrp tunnel tun100 redirect
+ set protocols nhrp tunnel tun100 shortcut
+ set protocols nhrp tunnel tun200 cisco-authentication 'secret'
+ set protocols nhrp tunnel tun200 holding-time '30'
+ set protocols nhrp tunnel tun200 map 172.16.254.134/29 nbma-address '10.21.0.1'
+ set protocols nhrp tunnel tun200 map 172.16.254.134/29 register
+ set protocols nhrp tunnel tun200 multicast 'nhs'
+ set protocols nhrp tunnel tun200 redirect
+ set protocols nhrp tunnel tun200 shortcut
+
+ set vpn ipsec esp-group ESP-HUB compression 'disable'
+ set vpn ipsec esp-group ESP-HUB lifetime '1800'
+ set vpn ipsec esp-group ESP-HUB mode 'transport'
+ set vpn ipsec esp-group ESP-HUB pfs 'dh-group2'
+ set vpn ipsec esp-group ESP-HUB proposal 1 encryption 'aes256'
+ set vpn ipsec esp-group ESP-HUB proposal 1 hash 'sha1'
+ set vpn ipsec esp-group ESP-HUB proposal 2 encryption '3des'
+ set vpn ipsec esp-group ESP-HUB proposal 2 hash 'md5'
+ set vpn ipsec ike-group IKE-HUB close-action 'none'
+ set vpn ipsec ike-group IKE-HUB dead-peer-detection action 'restart'
+ set vpn ipsec ike-group IKE-HUB dead-peer-detection interval '3'
+ set vpn ipsec ike-group IKE-HUB dead-peer-detection timeout '30'
+ set vpn ipsec ike-group IKE-HUB ikev2-reauth 'no'
+ set vpn ipsec ike-group IKE-HUB key-exchange 'ikev2'
+ set vpn ipsec ike-group IKE-HUB lifetime '3600'
+ set vpn ipsec ike-group IKE-HUB proposal 1 dh-group '2'
+ set vpn ipsec ike-group IKE-HUB proposal 1 encryption 'aes256'
+ set vpn ipsec ike-group IKE-HUB proposal 1 hash 'sha1'
+ set vpn ipsec ike-group IKE-HUB proposal 2 dh-group '2'
+ set vpn ipsec ike-group IKE-HUB proposal 2 encryption 'aes128'
+ set vpn ipsec ike-group IKE-HUB proposal 2 hash 'sha1'
+ set vpn ipsec ipsec-interfaces interface 'eth0'
+ set vpn ipsec profile NHRPVPN authentication mode 'pre-shared-secret'
+ set vpn ipsec profile NHRPVPN authentication pre-shared-secret 'secret'
+ set vpn ipsec profile NHRPVPN bind tunnel 'tun100'
+ set vpn ipsec profile NHRPVPN bind tunnel 'tun200'
+ set vpn ipsec profile NHRPVPN esp-group 'ESP-HUB'
+ set vpn ipsec profile NHRPVPN ike-group 'IKE-HUB'
+
+
+
+Step-4: Enabling eBGP as a Dynamic Routing Protocol between Hubs and Spokes
+===========================================================================
+
+For the simplified and better network management we're using eBGP for routing
+information exchange between devices. As we're using Active-Standby mode in
+this example, Hub-2 is configured with AS-prepand as an export route-policy
+and VRRP transition scripts are used for switching mastership based on the
+current link/device state. Also, we use multihop BFD for faster eBGP failure
+detection.
+
+Hub-1 and Hub-2 VRRP transition scripts:
+________________________________________
+
+* /config/scripts/vrrp-master.sh
+
+.. code-block:: none
+
+ #!/bin/vbash
+
+ if [ $(id -gn) != vyattacfg ]; then
+ exec sg vyattacfg "$0 $*"
+ fi
+
+ source /opt/vyatta/etc/functions/script-template
+
+ configure
+ delete protocols bgp 65000 peer-group DMVPN address-family ipv4-unicast route-map export AS65000-PREP
+ commit
+
+ exit
+
+
+* /config/scripts/vrrp-fail.sh
+
+.. code-block:: none
+
+ #!/bin/vbash
+
+ if [ $(id -gn) != vyattacfg ]; then
+ exec sg vyattacfg "$0 $*"
+ fi
+
+ source /opt/vyatta/etc/functions/script-template
+
+ configure
+ set protocols bgp 65000 peer-group DMVPN address-family ipv4-unicast route-map export AS65000-PREP
+ commit
+
+ exit
+
+
+**Note**: some parts of the script might be dependent on your network topology
+and connectivity. Be careful before using it on your own devices.
+
+
+Hub devices configuration:
+__________________________
+
+- Hub-1:
+
+.. code-block:: none
+
+ set high-availability vrrp group HQ transition-script backup '/config/scripts/vrrp-fail.sh'
+ set high-availability vrrp group HQ transition-script fault '/config/scripts/vrrp-fail.sh'
+ set high-availability vrrp group HQ transition-script master '/config/scripts/vrrp-master.sh'
+ set high-availability vrrp group HQ transition-script stop '/config/scripts/vrrp-fail.sh'
+
+ set policy route-map AS65000-PREP rule 1 action 'permit'
+ set policy route-map AS65000-PREP rule 1 set as-path-prepend '65000 65000 65000'
+
+ set protocols bfd peer 172.16.253.131 interval multiplier '3'
+ set protocols bfd peer 172.16.253.131 interval receive '300'
+ set protocols bfd peer 172.16.253.131 interval transmit '300'
+ set protocols bfd peer 172.16.253.131 multihop
+ set protocols bfd peer 172.16.253.131 source address '172.16.253.134'
+ set protocols bfd peer 172.16.253.132 interval multiplier '3'
+ set protocols bfd peer 172.16.253.132 interval receive '300'
+ set protocols bfd peer 172.16.253.132 interval transmit '300'
+ set protocols bfd peer 172.16.253.132 multihop
+ set protocols bfd peer 172.16.253.132 source address '172.16.253.134'
+ set protocols bfd peer 172.16.253.133 interval multiplier '3'
+ set protocols bfd peer 172.16.253.133 interval receive '300'
+ set protocols bfd peer 172.16.253.133 interval transmit '300'
+ set protocols bfd peer 172.16.253.133 multihop
+ set protocols bfd peer 172.16.253.133 source address '172.16.253.134'
+
+ set protocols bgp 65000 address-family ipv4-unicast network 192.168.0.0/24
+ set protocols bgp 65000 neighbor 172.16.253.131 peer-group 'DMVPN'
+ set protocols bgp 65000 neighbor 172.16.253.131 remote-as '65001'
+ set protocols bgp 65000 neighbor 172.16.253.132 peer-group 'DMVPN'
+ set protocols bgp 65000 neighbor 172.16.253.132 remote-as '65002'
+ set protocols bgp 65000 neighbor 172.16.253.133 peer-group 'DMVPN'
+ set protocols bgp 65000 neighbor 172.16.253.133 remote-as '65003'
+ set protocols bgp 65000 parameters log-neighbor-changes
+ set protocols bgp 65000 parameters network-import-check
+ set protocols bgp 65000 peer-group DMVPN bfd
+
+- Hub-2:
+
+.. code-block:: none
+
+ set high-availability vrrp group HQ transition-script backup '/config/scripts/vrrp-fail.sh'
+ set high-availability vrrp group HQ transition-script fault '/config/scripts/vrrp-fail.sh'
+ set high-availability vrrp group HQ transition-script master '/config/scripts/vrrp-master.sh'
+ set high-availability vrrp group HQ transition-script stop '/config/scripts/vrrp-fail.sh'
+
+ set policy route-map AS65000-PREP rule 1 action 'permit'
+ set policy route-map AS65000-PREP rule 1 set as-path-prepend '65000 65000 65000'
+
+ set protocols bfd peer 172.16.254.131 interval multiplier '3'
+ set protocols bfd peer 172.16.254.131 interval receive '300'
+ set protocols bfd peer 172.16.254.131 interval transmit '300'
+ set protocols bfd peer 172.16.254.131 multihop
+ set protocols bfd peer 172.16.254.131 source address '172.16.254.134'
+ set protocols bfd peer 172.16.254.132 interval multiplier '3'
+ set protocols bfd peer 172.16.254.132 interval receive '300'
+ set protocols bfd peer 172.16.254.132 interval transmit '300'
+ set protocols bfd peer 172.16.254.132 multihop
+ set protocols bfd peer 172.16.254.132 source address '172.16.254.134'
+ set protocols bfd peer 172.16.254.133 interval multiplier '3'
+ set protocols bfd peer 172.16.254.133 interval receive '300'
+ set protocols bfd peer 172.16.254.133 interval transmit '300'
+ set protocols bfd peer 172.16.254.133 multihop
+ set protocols bfd peer 172.16.254.133 source address '172.16.254.134'
+
+ set protocols bgp 65000 address-family ipv4-unicast network 192.168.0.0/24
+ set protocols bgp 65000 neighbor 172.16.254.131 peer-group 'DMVPN'
+ set protocols bgp 65000 neighbor 172.16.254.131 remote-as '65001'
+ set protocols bgp 65000 neighbor 172.16.254.132 peer-group 'DMVPN'
+ set protocols bgp 65000 neighbor 172.16.254.132 remote-as '65002'
+ set protocols bgp 65000 neighbor 172.16.254.133 peer-group 'DMVPN'
+ set protocols bgp 65000 neighbor 172.16.254.133 remote-as '65003'
+ set protocols bgp 65000 parameters log-neighbor-changes
+ set protocols bgp 65000 parameters network-import-check
+ set protocols bgp 65000 peer-group DMVPN address-family ipv4-unicast route-map export 'AS65000-PREP'
+ set protocols bgp 65000 peer-group DMVPN bfd
+
+Spoke devices configuration:
+____________________________
+
+- Spoke-1:
+
+.. code-block:: none
+
+ set protocols bfd peer 172.16.253.134 interval multiplier '3'
+ set protocols bfd peer 172.16.253.134 interval receive '300'
+ set protocols bfd peer 172.16.253.134 interval transmit '300'
+ set protocols bfd peer 172.16.253.134 multihop
+ set protocols bfd peer 172.16.253.134 source address '172.16.253.131'
+ set protocols bfd peer 172.16.254.134 interval multiplier '3'
+ set protocols bfd peer 172.16.254.134 interval receive '300'
+ set protocols bfd peer 172.16.254.134 interval transmit '300'
+ set protocols bfd peer 172.16.254.134 multihop
+ set protocols bfd peer 172.16.254.134 source address '172.16.254.131'
+
+ set protocols bgp 65001 address-family ipv4-unicast network 192.168.1.0/24
+ set protocols bgp 65001 neighbor 172.16.253.134 address-family ipv4-unicast
+ set protocols bgp 65001 neighbor 172.16.253.134 bfd
+ set protocols bgp 65001 neighbor 172.16.253.134 remote-as '65000'
+ set protocols bgp 65001 neighbor 172.16.254.134 address-family ipv4-unicast
+ set protocols bgp 65001 neighbor 172.16.254.134 bfd
+ set protocols bgp 65001 neighbor 172.16.254.134 remote-as '65000'
+ set protocols bgp 65001 parameters log-neighbor-changes
+
+- Spoke-2:
+
+.. code-block:: none
+
+ set protocols bfd peer 172.16.253.134 interval multiplier '3'
+ set protocols bfd peer 172.16.253.134 interval receive '300'
+ set protocols bfd peer 172.16.253.134 interval transmit '300'
+ set protocols bfd peer 172.16.253.134 multihop
+ set protocols bfd peer 172.16.253.134 source address '172.16.253.132'
+ set protocols bfd peer 172.16.254.134 interval multiplier '3'
+ set protocols bfd peer 172.16.254.134 interval receive '300'
+ set protocols bfd peer 172.16.254.134 interval transmit '300'
+ set protocols bfd peer 172.16.254.134 multihop
+ set protocols bfd peer 172.16.254.134 source address '172.16.254.132'
+
+ set protocols bgp 65002 address-family ipv4-unicast network 192.168.2.0/24
+ set protocols bgp 65002 neighbor 172.16.253.134 address-family ipv4-unicast
+ set protocols bgp 65002 neighbor 172.16.253.134 bfd
+ set protocols bgp 65002 neighbor 172.16.253.134 remote-as '65000'
+ set protocols bgp 65002 neighbor 172.16.254.134 address-family ipv4-unicast
+ set protocols bgp 65002 neighbor 172.16.254.134 bfd
+ set protocols bgp 65002 neighbor 172.16.254.134 remote-as '65000'
+ set protocols bgp 65002 parameters log-neighbor-changes
+
+- Spoke-3:
+
+.. code-block:: none
+
+ set protocols bfd peer 172.16.253.134 interval multiplier '3'
+ set protocols bfd peer 172.16.253.134 interval receive '300'
+ set protocols bfd peer 172.16.253.134 interval transmit '300'
+ set protocols bfd peer 172.16.253.134 multihop
+ set protocols bfd peer 172.16.253.134 source address '172.16.253.133'
+ set protocols bfd peer 172.16.254.134 interval multiplier '3'
+ set protocols bfd peer 172.16.254.134 interval receive '300'
+ set protocols bfd peer 172.16.254.134 interval transmit '300'
+ set protocols bfd peer 172.16.254.134 multihop
+ set protocols bfd peer 172.16.254.134 source address '172.16.254.133'
+
+ set protocols bgp 65003 address-family ipv4-unicast network 192.168.3.0/24
+ set protocols bgp 65003 neighbor 172.16.253.134 address-family ipv4-unicast
+ set protocols bgp 65003 neighbor 172.16.253.134 bfd
+ set protocols bgp 65003 neighbor 172.16.253.134 remote-as '65000'
+ set protocols bgp 65003 neighbor 172.16.254.134 address-family ipv4-unicast
+ set protocols bgp 65003 neighbor 172.16.254.134 bfd
+ set protocols bgp 65003 neighbor 172.16.254.134 remote-as '65000'
+ set protocols bgp 65003 parameters log-neighbor-changes
+
+**Note**: In case if you're using VyOS version that has a VRRP transition
+scripts issues after a device reboot, as a temporary solution you may add
+postconfig-bootup script that reloads **keepalived** process additionally after
+the device booted.
+
+- Hub devices /config/scripts/vyos-postconfig-bootup.script:
+
+.. code-block:: none
+
+ #!/bin/sh
+ # This script is executed at boot time after VyOS configuration is fully applied.
+ # Any modifications required to work around unfixed bugs
+ # or use services not available through the VyOS CLI system can be placed here.
+
+ echo "Reloading VRRP process"
+ sudo systemctl restart keepalived.service
+ echo "VRRP process reload completed"
+
+
+
+Step-5: Verification
+====================
+
+Now, it's time to check that all protocols are working as expected and mastership
+during the failover switches correctly between Hub devices.
+
+- Checking VRRP state between Hub-1 and Hub-2:
+
+.. code-block:: none
+
+ vyos@Hub-1:~$ show vrrp
+ Name Interface VRID State Priority Last Transition
+ ------ ----------- ------ ------- ---------- -----------------
+ HQ eth1v1 1 MASTER 200 14s
+
+ vyos@Hub-2:~$ show vrrp
+ Name Interface VRID State Priority Last Transition
+ ------ ----------- ------ ------- ---------- -----------------
+ HQ eth1v1 1 BACKUP 100 29s
+
+- Checking NHRP and eBGP sessions between Hub and Spoke devices:
+
+.. code-block:: none
+
+ vyos@Hub-1:~$ show nhrp tunnel
+ Status: ok
+
+ Interface: tun100
+ Type: local
+ Protocol-Address: 172.16.253.135/32
+ Alias-Address: 172.16.253.134
+ Flags: up
+
+ Interface: tun100
+ Type: local
+ Protocol-Address: 172.16.253.134/32
+ Flags: up
+
+ Interface: tun100
+ Type: dynamic
+ Protocol-Address: 172.16.253.131/32
+ NBMA-Address: 10.11.1.11
+ Flags: up
+ Expires-In: 0:23
+
+ Interface: tun100
+ Type: dynamic
+ Protocol-Address: 172.16.253.133/32
+ NBMA-Address: 10.31.1.11
+ Flags: up
+ Expires-In: 0:22
+
+ Interface: tun100
+ Type: dynamic
+ Protocol-Address: 172.16.253.132/32
+ NBMA-Address: 10.21.1.11
+ Flags: up
+ Expires-In: 0:21
+
+ vyos@Hub-1:~$ show bgp summary
+
+ IPv4 Unicast Summary:
+ BGP router identifier 192.168.0.1, local AS number 65000 vrf-id 0
+ BGP table version 20
+ RIB entries 7, using 1344 bytes of memory
+ Peers 3, using 64 KiB of memory
+ Peer groups 1, using 64 bytes of memory
+
+ Neighbor V AS MsgRcvd MsgSent TblVer InQ OutQ Up/Down State/PfxRcd PfxSnt
+ 172.16.253.131 4 65001 26519 26526 0 0 0 00:43:38 1 4
+ 172.16.253.132 4 65002 26545 26540 0 0 0 00:46:36 1 4
+ 172.16.253.133 4 65003 26528 26520 0 0 0 00:41:59 1 4
+
+ Total number of neighbors 3
+
+
+ vyos@Hub-2:~$ show nhrp tunnel
+ Status: ok
+
+ Interface: tun100
+ Type: local
+ Protocol-Address: 172.16.254.135/32
+ Alias-Address: 172.16.254.134
+ Flags: up
+
+ Interface: tun100
+ Type: local
+ Protocol-Address: 172.16.254.134/32
+ Flags: up
+
+ Interface: tun100
+ Type: dynamic
+ Protocol-Address: 172.16.254.132/32
+ NBMA-Address: 10.21.1.11
+ Flags: up
+ Expires-In: 0:28
+
+ Interface: tun100
+ Type: dynamic
+ Protocol-Address: 172.16.254.131/32
+ NBMA-Address: 10.11.1.11
+ Flags: up
+ Expires-In: 0:21
+
+ Interface: tun100
+ Type: dynamic
+ Protocol-Address: 172.16.254.133/32
+ NBMA-Address: 10.31.1.11
+ Flags: up
+ Expires-In: 0:20
+
+ vyos@Hub-2:~$ show bgp summary
+
+ IPv4 Unicast Summary:
+ BGP router identifier 192.168.0.2, local AS number 65000 vrf-id 0
+ BGP table version 14
+ RIB entries 7, using 1344 bytes of memory
+ Peers 3, using 64 KiB of memory
+ Peer groups 1, using 64 bytes of memory
+
+ Neighbor V AS MsgRcvd MsgSent TblVer InQ OutQ Up/Down State/PfxRcd PfxSnt
+ 172.16.254.131 4 65001 26516 26516 0 0 0 00:43:03 1 4
+ 172.16.254.132 4 65002 26563 26562 0 0 0 00:48:27 1 4
+ 172.16.254.133 4 65003 26518 26516 0 0 0 00:42:20 1 4
+
+ Total number of neighbors 3
+
+- Checking BFD sessions between Hub and Spoke devices:
+
+.. code-block:: none
+
+ vyos@Hub-1:~$ show protocols bfd peers
+ Session count: 6
+ SessionId LocalAddress PeerAddress Status
+ ========= ============ =========== ======
+ 3600626867 172.16.253.134 172.16.253.133 up
+ 1123939978 172.16.253.134 172.16.253.131 up
+ 374394280 172.16.253.134 172.16.253.132 up
+ 1786735466 172.16.253.134 172.16.253.132 up
+ 1440522544 172.16.253.134 172.16.253.131 up
+ 1106910911 172.16.253.134 172.16.253.133 up
+
+
+ vyos@Hub-2:~$ show protocols bfd peers
+ Session count: 6
+ SessionId LocalAddress PeerAddress Status
+ ========= ============ =========== ======
+ 2442966178 172.16.254.134 172.16.254.133 up
+ 393258775 172.16.254.134 172.16.254.131 up
+ 2990308682 172.16.254.134 172.16.254.133 up
+ 2267910949 172.16.254.134 172.16.254.132 up
+ 3542474595 172.16.254.134 172.16.254.131 up
+ 4239538185 172.16.254.134 172.16.254.132 up
+
+- Checking routing information and connectivity between Hub and Spoke devices:
+
+.. code-block:: none
+
+ vyos@Hub-1:~$ show ip bgp
+ BGP table version is 20, local router ID is 192.168.0.1, vrf id 0
+ Default local pref 100, local AS 65000
+ Status codes: s suppressed, d damped, h history, * valid, > best, = multipath,
+ i internal, r RIB-failure, S Stale, R Removed
+ Nexthop codes: @NNN nexthop's vrf id, < announce-nh-self
+ Origin codes: i - IGP, e - EGP, ? - incomplete
+
+ Network Next Hop Metric LocPrf Weight Path
+ *> 192.168.0.0/24 0.0.0.0 0 32768 i
+ *> 192.168.1.0/24 172.16.253.131 0 0 65001 i
+ *> 192.168.2.0/24 172.16.253.132 0 0 65002 i
+ *> 192.168.3.0/24 172.16.253.133 0 0 65003 i
+
+ Displayed 4 routes and 4 total paths
+
+
+ vyos@Hub-2:~$ show ip bgp
+ BGP table version is 14, local router ID is 192.168.0.2, vrf id 0
+ Default local pref 100, local AS 65000
+ Status codes: s suppressed, d damped, h history, * valid, > best, = multipath,
+ i internal, r RIB-failure, S Stale, R Removed
+ Nexthop codes: @NNN nexthop's vrf id, < announce-nh-self
+ Origin codes: i - IGP, e - EGP, ? - incomplete
+
+ Network Next Hop Metric LocPrf Weight Path
+ *> 192.168.0.0/24 0.0.0.0 0 32768 i
+ *> 192.168.1.0/24 172.16.254.131 0 0 65001 i
+ *> 192.168.2.0/24 172.16.254.132 0 0 65002 i
+ *> 192.168.3.0/24 172.16.254.133 0 0 65003 i
+
+ Displayed 4 routes and 4 total paths
+
+
+ vyos@Spoke-1:~$ show ip bgp
+ BGP table version is 19, local router ID is 192.168.1.1, vrf id 0
+ Default local pref 100, local AS 65001
+ Status codes: s suppressed, d damped, h history, * valid, > best, = multipath,
+ i internal, r RIB-failure, S Stale, R Removed
+ Nexthop codes: @NNN nexthop's vrf id, < announce-nh-self
+ Origin codes: i - IGP, e - EGP, ? - incomplete
+
+ Network Next Hop Metric LocPrf Weight Path
+ * 192.168.0.0/24 172.16.254.134 0 0 65000 65000 65000 65000 i
+ *> 172.16.253.134 0 0 65000 i
+ *> 192.168.1.0/24 0.0.0.0 0 32768 i
+ * 192.168.2.0/24 172.16.254.132 0 65000 65000 65000 65000 65002 i
+ *> 172.16.253.132 0 65000 65002 i
+ * 192.168.3.0/24 172.16.254.133 0 65000 65000 65000 65000 65003 i
+ *> 172.16.253.133 0 65000 65003 i
+
+ Displayed 4 routes and 7 total paths
+
+As you can see, Hub-2 announces routes with longer(prepended) AS path as
+we've configured it previously, those, traffic towards HQ subnet will be
+forwarded over Hub-1 which is operating as an Active VRRP router. Let's
+check connectivity and the path from Spoke-1 to the HQ local network:
+
+.. code-block:: none
+
+ vyos@Spoke-1:~$ ping 192.168.0.10 count 5 interface 192.168.1.1
+ PING 192.168.0.10 (192.168.0.10) from 192.168.1.1 : 56(84) bytes of data.
+ 64 bytes from 192.168.0.10: icmp_seq=1 ttl=63 time=3.50 ms
+ 64 bytes from 192.168.0.10: icmp_seq=2 ttl=63 time=2.45 ms
+ 64 bytes from 192.168.0.10: icmp_seq=3 ttl=63 time=2.34 ms
+ 64 bytes from 192.168.0.10: icmp_seq=4 ttl=63 time=2.20 ms
+ 64 bytes from 192.168.0.10: icmp_seq=5 ttl=63 time=2.44 ms
+
+ --- 192.168.0.10 ping statistics ---
+ 5 packets transmitted, 5 received, 0% packet loss, time 11ms
+ rtt min/avg/max/mdev = 2.195/2.583/3.496/0.465 ms
+
+ vyos@Spoke-1:~$ traceroute 192.168.0.10
+ traceroute to 192.168.0.10 (192.168.0.10), 30 hops max, 60 byte packets
+ 1 172.16.253.134 (172.16.253.134) 0.913 ms 0.884 ms 0.819 ms
+ 2 192.168.0.10 (192.168.0.10) 1.352 ms 1.446 ms 1.391 ms
+
+From the output, we can confirm successful connectivity between Spoke-1 and HQ
+local networks. From the traceroute we see that the traffic pass through the
+Hub-1.
+
+Now, let's check traffic between Spoke sites. Based on our configuration, Spoke
+sites are using shourtcut for direct reachability between each other. First, let's
+check NHRP tunnels before passing the traffic between Spoke-1 and Spoke-2:
+
+.. code-block:: none
+
+ vyos@Spoke-1:~$ show nhrp tunnel
+ Status: ok
+
+ Interface: tun200
+ Type: local
+ Protocol-Address: 172.16.254.135/32
+ Alias-Address: 172.16.254.131
+ Flags: up
+
+ Interface: tun200
+ Type: local
+ Protocol-Address: 172.16.254.131/32
+ Flags: up
+
+ Interface: tun100
+ Type: local
+ Protocol-Address: 172.16.253.135/32
+ Alias-Address: 172.16.253.131
+ Flags: up
+
+ Interface: tun100
+ Type: local
+ Protocol-Address: 172.16.253.131/32
+ Flags: up
+
+ Interface: tun200
+ Type: static
+ Protocol-Address: 172.16.254.134/29
+ NBMA-Address: 10.21.0.1
+ Flags: used up
+
+ Interface: tun100
+ Type: static
+ Protocol-Address: 172.16.253.134/29
+ NBMA-Address: 10.11.0.1
+ Flags: used up
+
+ vyos@Spoke-2:~$ show nhrp tunnel
+ Status: ok
+
+ Interface: tun100
+ Type: local
+ Protocol-Address: 172.16.253.135/32
+ Alias-Address: 172.16.253.132
+ Flags: up
+
+ Interface: tun100
+ Type: local
+ Protocol-Address: 172.16.253.132/32
+ Flags: up
+
+ Interface: tun200
+ Type: local
+ Protocol-Address: 172.16.254.135/32
+ Alias-Address: 172.16.254.132
+ Flags: up
+
+ Interface: tun200
+ Type: local
+ Protocol-Address: 172.16.254.132/32
+ Flags: up
+
+ Interface: tun100
+ Type: static
+ Protocol-Address: 172.16.253.134/29
+ NBMA-Address: 10.11.0.1
+ Flags: used up
+
+ Interface: tun200
+ Type: static
+ Protocol-Address: 172.16.254.134/29
+ NBMA-Address: 10.21.0.1
+
+
+After passing traffic we could see that there is additional shourtcut tunnel
+created between Spoke-1 and Spoke-2 for the direct communication:
+
+.. code-block:: none
+
+ vyos@Spoke-1:~$ ping 192.168.2.1 count 5 interface 192.168.1.1
+ PING 192.168.2.1 (192.168.2.1) from 192.168.1.1 : 56(84) bytes of data.
+ 64 bytes from 192.168.2.1: icmp_seq=1 ttl=64 time=1.03 ms
+ 64 bytes from 192.168.2.1: icmp_seq=2 ttl=64 time=0.820 ms
+ 64 bytes from 192.168.2.1: icmp_seq=3 ttl=64 time=1.13 ms
+ 64 bytes from 192.168.2.1: icmp_seq=4 ttl=63 time=1.41 ms
+ 64 bytes from 192.168.2.1: icmp_seq=5 ttl=64 time=0.988 ms
+
+ --- 192.168.2.1 ping statistics ---
+ 5 packets transmitted, 5 received, 0% packet loss, time 10ms
+ rtt min/avg/max/mdev = 0.820/1.075/1.412/0.197 ms
+
+ vyos@Spoke-1:~$ traceroute 192.168.2.1
+ traceroute to 192.168.2.1 (192.168.2.1), 30 hops max, 60 byte packets
+ 1 192.168.2.1 (192.168.2.1) 1.172 ms 1.109 ms 1.151 ms
+
+ vyos@Spoke-1:~$ show nhrp tunnel
+ Status: ok
+
+ Interface: tun200
+ Type: local
+ Protocol-Address: 172.16.254.135/32
+ Alias-Address: 172.16.254.131
+ Flags: up
+
+ Interface: tun200
+ Type: local
+ Protocol-Address: 172.16.254.131/32
+ Flags: up
+
+ Interface: tun100
+ Type: local
+ Protocol-Address: 172.16.253.135/32
+ Alias-Address: 172.16.253.131
+ Flags: up
+
+ Interface: tun100
+ Type: local
+ Protocol-Address: 172.16.253.131/32
+ Flags: up
+
+ Interface: tun200
+ Type: static
+ Protocol-Address: 172.16.254.134/29
+ NBMA-Address: 10.21.0.1
+ Flags: used up
+
+ ____________________________________
+ Interface: tun100
+ Type: cached
+ Protocol-Address: 172.16.253.132/32
+ NBMA-Address: 10.21.1.11
+ Flags: used up
+ Expires-In: 0:24
+ ____________________________________
+
+ Interface: tun100
+ Type: static
+ Protocol-Address: 172.16.253.134/29
+ NBMA-Address: 10.11.0.1
+ Flags: used up
+
+The same applies to the rest of the devices and works with the same logic.
+As we've already confirmed successfull connectivity between Hub and Spoke
+devices, let's check failover process.
+
+- Failover on the health-check failure on Hub-1:
+
+.. code-block:: none
+
+ # disabling interface towards Hub-1 on ISP router
+ vyos@ISP1:~$ configure
+ [edit]
+ vyos@ISP1# set interfaces ethernet eth0 disable
+ [edit]
+ vyos@ISP1# commit
+ [edit]
+ vyos@ISP1#
+
+
+ # checking VRRP state and eBGP configuration on Hub-1:
+ vyos@Hub-1:~$ show vrrp
+ Name Interface VRID State Priority Last Transition
+ ------ ----------- ------ ------- ---------- -----------------
+ HQ eth1v1 1 FAULT 200 1m15s
+
+ vyos@Hub-1:~$ show configuration commands | match bgp
+ set protocols bgp 65000 address-family ipv4-unicast network 192.168.0.0/24
+ set protocols bgp 65000 neighbor 172.16.253.131 peer-group 'DMVPN'
+ set protocols bgp 65000 neighbor 172.16.253.131 remote-as '65001'
+ set protocols bgp 65000 neighbor 172.16.253.132 peer-group 'DMVPN'
+ set protocols bgp 65000 neighbor 172.16.253.132 remote-as '65002'
+ set protocols bgp 65000 neighbor 172.16.253.133 peer-group 'DMVPN'
+ set protocols bgp 65000 neighbor 172.16.253.133 remote-as '65003'
+ set protocols bgp 65000 parameters log-neighbor-changes
+ set protocols bgp 65000 peer-group DMVPN address-family ipv4-unicast route-map export 'AS65000-PREP'
+ set protocols bgp 65000 peer-group DMVPN bfd
+
+
+ # consecutive pings check from Spoke-1 to the HQ local network during the failure
+ --- 192.168.0.10 ping statistics ---
+ 223 packets transmitted, 219 received, 1.79372% packet loss, time 679ms
+ rtt min/avg/max/mdev = 0.918/2.191/2.957/0.364 ms
+ vyos@Spoke-1:~$
+
+
+ # consecutive pings check from Spoke-3 to the Spoke-2 local network during the failure
+ --- 192.168.2.1 ping statistics ---
+ 265 packets transmitted, 265 received, 0% packet loss, time 690ms
+ rtt min/avg/max/mdev = 0.663/1.128/2.272/0.285 ms
+ vyos@Spoke-3:~$
+
+**Note**: After bringing ISP interface towards Hub-1 back to UP state,
+VRRP state will remain unchanged due to "no-preempt" option enabled
+under the VRRP configuration on the Hub-1 and Hub-2 and will be changed
+only during link/device failure on Hub-2.
+
+- Failover during Hub-2 device failure:
+
+.. code-block:: none
+
+ # Checking VRRP state and eBGP configuration on Hub-2 before reboot
+ vyos@Hub-2:~$ show vrrp
+ Name Interface VRID State Priority Last Transition
+ ------ ----------- ------ ------- ---------- -----------------
+ HQ eth1v1 1 MASTER 100 20m22s
+
+ vyos@Hub-2:~$ show configuration commands | match bgp
+ set protocols bgp 65000 address-family ipv4-unicast network 192.168.0.0/24
+ set protocols bgp 65000 neighbor 172.16.254.131 peer-group 'DMVPN'
+ set protocols bgp 65000 neighbor 172.16.254.131 remote-as '65001'
+ set protocols bgp 65000 neighbor 172.16.254.132 peer-group 'DMVPN'
+ set protocols bgp 65000 neighbor 172.16.254.132 remote-as '65002'
+ set protocols bgp 65000 neighbor 172.16.254.133 peer-group 'DMVPN'
+ set protocols bgp 65000 neighbor 172.16.254.133 remote-as '65003'
+ set protocols bgp 65000 parameters log-neighbor-changes
+ set protocols bgp 65000 peer-group DMVPN address-family ipv4-unicast route-map
+ set protocols bgp 65000 peer-group DMVPN bfd
+
+
+ # Rebooting Hub-2
+ vyos@Hub-2:~$ reboot
+ Are you sure you want to reboot this system? [y/N] y
+
+
+ # Checking VRRP state and eBGP configuration on Hub-1
+ vyos@Hub-1:~$ show vrrp
+ Name Interface VRID State Priority Last Transition
+ ------ ----------- ------ ------- ---------- -----------------
+ HQ eth1v1 1 MASTER 200 1m57s
+
+ vyos@Hub-1:~$ show configuration commands | match bgp
+ set protocols bgp 65000 address-family ipv4-unicast network 192.168.0.0/24
+ set protocols bgp 65000 neighbor 172.16.253.131 peer-group 'DMVPN'
+ set protocols bgp 65000 neighbor 172.16.253.131 remote-as '65001'
+ set protocols bgp 65000 neighbor 172.16.253.132 peer-group 'DMVPN'
+ set protocols bgp 65000 neighbor 172.16.253.132 remote-as '65002'
+ set protocols bgp 65000 neighbor 172.16.253.133 peer-group 'DMVPN'
+ set protocols bgp 65000 neighbor 172.16.253.133 remote-as '65003'
+ set protocols bgp 65000 parameters log-neighbor-changes
+ set protocols bgp 65000 peer-group DMVPN address-family ipv4-unicast route-map
+ set protocols bgp 65000 peer-group DMVPN bfd
+
+
+ # Checking VRRP state and eBGP configuration on Hub-2 after reboot completed
+ vyos@Hub-2:~$ show vrrp
+ Name Interface VRID State Priority Last Transition
+ ------ ----------- ------ ------- ---------- -----------------
+ HQ eth1v1 1 BACKUP 100 1m46s
+
+ vyos@Hub-2:~$ show configuration commands | match bgp
+ set protocols bgp 65000 address-family ipv4-unicast network 192.168.0.0/24
+ set protocols bgp 65000 neighbor 172.16.254.131 peer-group 'DMVPN'
+ set protocols bgp 65000 neighbor 172.16.254.131 remote-as '65001'
+ set protocols bgp 65000 neighbor 172.16.254.132 peer-group 'DMVPN'
+ set protocols bgp 65000 neighbor 172.16.254.132 remote-as '65002'
+ set protocols bgp 65000 neighbor 172.16.254.133 peer-group 'DMVPN'
+ set protocols bgp 65000 neighbor 172.16.254.133 remote-as '65003'
+ set protocols bgp 65000 parameters log-neighbor-changes
+ set protocols bgp 65000 peer-group DMVPN address-family ipv4-unicast route-map export 'AS65000-PREP'
+ set protocols bgp 65000 peer-group DMVPN bfd
+
+
+ # consecutive pings check from Spoke-1 to the HQ local network during the failure
+ --- 192.168.0.10 ping statistics ---
+ 1182 packets transmitted, 1182 received, 0% packet loss, time 1921ms
+ rtt min/avg/max/mdev = 0.890/1.692/3.305/0.503 ms
+ vyos@Spoke-1:~$
+
+
+ # consecutive pings check from Spoke-3 to the Spoke-2 local network during the failure
+ --- 192.168.2.1 ping statistics ---
+ 1186 packets transmitted, 1186 received, 0% packet loss, time 2100ms
+ rtt min/avg/max/mdev = 0.506/1.236/8.497/0.369 ms
+ vyos@Spoke-3:~$
+
+From the results, we can see that the switchover performed as expected with
+0 packets loss both from Spoke-1 to HQ and Spoke-3 to Spoke-2 networks.