summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--docs/_static/images/L3VPN_hub_and_spoke.pngbin0 -> 134458 bytes
-rw-r--r--docs/configexamples/index.rst3
-rw-r--r--docs/configexamples/l3vpn-hub-and-spoke.rst1130
3 files changed, 1132 insertions, 1 deletions
diff --git a/docs/_static/images/L3VPN_hub_and_spoke.png b/docs/_static/images/L3VPN_hub_and_spoke.png
new file mode 100644
index 00000000..d442cc1a
--- /dev/null
+++ b/docs/_static/images/L3VPN_hub_and_spoke.png
Binary files differ
diff --git a/docs/configexamples/index.rst b/docs/configexamples/index.rst
index b1f34801..3a3c2849 100644
--- a/docs/configexamples/index.rst
+++ b/docs/configexamples/index.rst
@@ -18,6 +18,7 @@ This chapter contains various configuration examples:
ha
wan-load-balancing
pppoe-ipv6-basic
+ l3vpn-hub-and-spoke
Configuration Blueprints (autotest)
@@ -45,4 +46,4 @@ The process will do the following steps:
:maxdepth: 1
autotest/L3VPN_EVPN/L3VPN_EVPN
- autotest/Wireguard/Wireguard \ No newline at end of file
+ autotest/Wireguard/Wireguard
diff --git a/docs/configexamples/l3vpn-hub-and-spoke.rst b/docs/configexamples/l3vpn-hub-and-spoke.rst
new file mode 100644
index 00000000..ad85ef0e
--- /dev/null
+++ b/docs/configexamples/l3vpn-hub-and-spoke.rst
@@ -0,0 +1,1130 @@
+
+##############################################
+L3VPN for Hub-and-Spoke connectivity with VyOS
+##############################################
+
+IP/MPLS technology is widely used by various service providers and large
+enterprises in order to achieve better network scalability, manageability
+and flexibility. It also provides the possibility to deliver different
+services for the customers in a seamless manner.
+Layer 3 VPN (L3VPN) is a type of VPN mode that is built and delivered
+through OSI layer 3 networking technologies. Often the border gateway
+protocol (BGP) is used to send and receive VPN-related data that is
+responsible for the control plane. L3VPN utilizes virtual routing and
+forwarding (VRF) techniques to receive and deliver user data as well as
+separate data planes of the end-users. It is built using a combination of
+IP- and MPLS-based information. Generally, L3VPNs are used to send data
+on back-end VPN infrastructures, such as for VPN connections between data
+centres, HQs and branches.
+
+An L3VPN consists of multiple access links, multiple VPN routing and
+forwarding (VRF) tables, and multiple MPLS paths or multiple P2MP LSPs.
+An L3VPN can be configured to connect two or more customer sites.
+In hub-and-spoke MPLS L3VPN environments, the spoke routers need to have
+unique Route Distinguishers (RDs). In order to use the hub site as a
+transit point for connectivity in such an environment, the spoke sites
+export their routes to the hub. Spokes can talk to hubs, but never have
+direct paths to other spokes. All traffic between spokes is controlled
+and delivered over the hub site.
+
+
+To deploy a Layer3 VPN with MPLS on VyOS, we should meet a couple
+requirements in order to properly implement the solution.
+We'll use the following nodes in our LAB environment:
+
+* 2 x Route reflectors (VyOS-RRx)
+* 4 x Provider routers (VyOS-Px)
+* 3 x Provider Edge (VyOs-PEx)
+* 3 x Customer Edge (VyOS-CEx)
+
+The following software was used in the creation of this document:
+
+* Operating system: VyOS
+* Version: 1.4-rolling-202110310317
+* Image name: vyos-1.4-rolling-202110310317-amd64.iso
+
+**NOTE:** VyOS Router (tested with VyOS 1.4-rolling-202110310317)
+– The configurations below are specifically for VyOS 1.4.x.
+
+General information can be found in the :ref:`l3vpn-vrfs` chapter.
+
+
+
+********
+Topology
+********
+.. image:: /_static/images/L3VPN_hub_and_spoke.png
+ :width: 80%
+ :align: center
+ :alt: Network Topology Diagram
+
+
+
+*****************
+How does it work?
+*****************
+
+As we know the main assumption of L3VPN “Hub and Spoke” is, that the traffic
+between spokes have to pass via hub, in our scenario VyOS-PE2 is the Hub PE
+and the VyOS-CE1-HUB is the central customer office device that is responsible
+for controlling access between all spokes and announcing its network prefixes
+(10.0.0.100/32). VyOS-PE2 has the main VRF (its name is BLUE_HUB), its
+own Route-Distinguisher(RD) and route-target import/export lists.
+Multiprotocol-BGP(MP-BGP) delivers L3VPN related control-plane information to
+the nodes across network where PEs Spokes import the route-target 60535:1030
+(this is export route-target of vrf BLUE_HUB) and export its own route-target
+60535:1011(this is vrf BLUE_SPOKE export route-target). Therefore, the
+Customer edge nodes can only learn the network prefixes of the HUB site
+[10.0.0.100/32]. For this example VyOS-CE1 has network prefixes
+[10.0.0.80/32] / VyOS-CE2 has network prefixes [10.0.0.90/32].
+Route-Reflector devices VyOS-RR1 and VyOS-RR2 are used to simplify network
+routes exchange and minimize iBGP peerings between devices.
+
+L3VPN configuration parameters table:
+
++----------+-------+------------+-----------------+-------------+-------------+
+| Node | Role | VRF | RD | RT import | RT export |
++----------+-------+------------+-----------------+-------------+-------------+
+| VyOS-PE2 | Hub | BLUE_HUB | 10.80.80.1:1011 | 65035:1011 | 65035:1030 |
+| | | | | 65035:1030 | |
++----------+-------+------------+-----------------+-------------+-------------+
+| VyOS-PE1 | Spoke | BLUE_SPOKE | 10.50.50.1:1011 | 65035:1030 | 65035:1011 |
++----------+-------+------------+-----------------+-------------+-------------+
+| VyOS-PE3 | Spoke | BLUE_SPOKE | 10.60.60.1:1011 | 65035:1030 | 65035:1011 |
++----------+-------+------------+-----------------+-------------+-------------+
+
+
+
+*************
+Configuration
+*************
+
+
+
+Step-1: Configuring IGP and enabling MPLS LDP
+=============================================
+
+At the first step we need to configure the IP/MPLS backbone network using OSPF as
+IGP protocol and LDP as label-switching protocol for the base connectivity between
+**P** (rovider), **P** (rovider) **E** (dge) and **R** (oute) **R** (eflector) nodes:
+
+- VyOS-P1:
+
+.. code-block:: none
+
+ # interfaces
+ set interfaces dummy dum10 address '10.0.0.3/32'
+ set interfaces ethernet eth0 address '172.16.30.1/24'
+ set interfaces ethernet eth1 address '172.16.40.1/24'
+ set interfaces ethernet eth2 address '172.16.90.1/24'
+ set interfaces ethernet eth3 address '172.16.10.1/24'
+ set interfaces ethernet eth5 address '172.16.100.1/24'
+
+ # protocols ospf+ldp
+ set protocols mpls interface 'eth1'
+ set protocols mpls interface 'eth2'
+ set protocols mpls interface 'eth3'
+ set protocols mpls interface 'eth5'
+ set protocols mpls interface 'eth0'
+ set protocols mpls ldp discovery transport-ipv4-address '10.0.0.3'
+ set protocols mpls ldp interface 'eth0'
+ set protocols mpls ldp interface 'eth1'
+ set protocols mpls ldp interface 'eth2'
+ set protocols mpls ldp interface 'eth3'
+ set protocols mpls ldp interface 'eth5'
+ set protocols mpls ldp router-id '10.0.0.3'
+ set protocols ospf area 0 network '0.0.0.0/0'
+ set protocols ospf parameters abr-type 'cisco'
+ set protocols ospf parameters router-id '10.0.0.3
+
+
+- VyOS-P2:
+
+.. code-block:: none
+
+ # interfaces
+ set interfaces dummy dum10 address '10.0.0.4/32'
+ set interfaces ethernet eth0 address '172.16.30.2/24'
+ set interfaces ethernet eth1 address '172.16.20.1/24'
+ set interfaces ethernet eth2 address '172.16.120.1/24'
+ set interfaces ethernet eth3 address '172.16.60.1/24'
+
+ # protocols ospf+ldp
+ set protocols mpls interface 'eth1'
+ set protocols mpls interface 'eth2'
+ set protocols mpls interface 'eth3'
+ set protocols mpls interface 'eth0'
+ set protocols mpls ldp discovery transport-ipv4-address '10.0.0.4'
+ set protocols mpls ldp interface 'eth0'
+ set protocols mpls ldp interface 'eth1'
+ set protocols mpls ldp interface 'eth2'
+ set protocols mpls ldp interface 'eth3'
+ set protocols mpls ldp router-id '10.0.0.4'
+ set protocols ospf area 0 network '0.0.0.0/0'
+ set protocols ospf parameters abr-type 'cisco'
+ set protocols ospf parameters router-id '10.0.0.4'
+
+- VyOS-P3:
+
+.. code-block:: none
+
+ # interfaces
+ set interfaces dummy dum10 address '10.0.0.5/32'
+ set interfaces ethernet eth0 address '172.16.110.1/24'
+ set interfaces ethernet eth1 address '172.16.40.2/24'
+ set interfaces ethernet eth2 address '172.16.50.1/24'
+ set interfaces ethernet eth3 address '172.16.70.1/24'
+
+ # protocols ospf + ldp
+ set protocols mpls interface 'eth1'
+ set protocols mpls interface 'eth2'
+ set protocols mpls interface 'eth3'
+ set protocols mpls interface 'eth0'
+ set protocols mpls ldp discovery transport-ipv4-address '10.0.0.5'
+ set protocols mpls ldp interface 'eth0'
+ set protocols mpls ldp interface 'eth1'
+ set protocols mpls ldp interface 'eth2'
+ set protocols mpls ldp interface 'eth3'
+ set protocols mpls ldp router-id '10.0.0.5'
+ set protocols ospf area 0 network '0.0.0.0/0'
+ set protocols ospf parameters abr-type 'cisco'
+ set protocols ospf parameters router-id '10.0.0.5'
+
+- VyOS-P4:
+
+.. code-block:: none
+
+ # interfaces
+ set interfaces dummy dum10 address '10.0.0.6/32'
+ set interfaces ethernet eth0 address '172.16.80.2/24'
+ set interfaces ethernet eth1 address '172.16.130.1/24'
+ set interfaces ethernet eth2 address '172.16.50.2/24'
+ set interfaces ethernet eth3 address '172.16.60.2/24'
+ set interfaces ethernet eth5 address '172.16.140.1/24'
+
+
+ # protocols ospf + ldp
+ set protocols mpls interface 'eth1'
+ set protocols mpls interface 'eth2'
+ set protocols mpls interface 'eth3'
+ set protocols mpls interface 'eth0'
+ set protocols mpls interface 'eth5'
+ set protocols mpls ldp discovery transport-ipv4-address '10.0.0.6'
+ set protocols mpls ldp interface 'eth0'
+ set protocols mpls ldp interface 'eth1'
+ set protocols mpls ldp interface 'eth2'
+ set protocols mpls ldp interface 'eth3'
+ set protocols mpls ldp interface 'eth5'
+ set protocols mpls ldp router-id '10.0.0.6'
+ set protocols ospf area 0 network '0.0.0.0/0'
+ set protocols ospf parameters abr-type 'cisco'
+ set protocols ospf parameters router-id '10.0.0.6'
+
+- VyOS-PE1:
+
+.. code-block:: none
+
+ # interfaces
+ set interfaces dummy dum10 address '10.0.0.7/32'
+ set interfaces ethernet eth0 address '172.16.90.2/24'
+
+ # protocols ospf + ldp
+ set protocols mpls interface 'eth0'
+ set protocols mpls ldp discovery transport-ipv4-address '10.0.0.7'
+ set protocols mpls ldp interface 'eth0'
+ set protocols mpls ldp router-id '10.0.0.7'
+ set protocols ospf area 0 network '0.0.0.0/0'
+ set protocols ospf parameters abr-type 'cisco'
+ set protocols ospf parameters router-id '10.0.0.7'
+
+- VyOS-PE2:
+
+.. code-block:: none
+
+ # interfaces
+ set interfaces dummy dum10 address '10.0.0.8/32'
+ set interfaces ethernet eth0 address '172.16.110.2/24'
+ set interfaces ethernet eth1 address '172.16.100.2/24'
+ set interfaces ethernet eth2 address '172.16.80.1/24'
+
+ # protocols ospf + ldp
+ set protocols mpls interface 'eth0'
+ set protocols mpls interface 'eth1'
+ set protocols mpls ldp discovery transport-ipv4-address '10.0.0.8'
+ set protocols mpls ldp interface 'eth0'
+ set protocols mpls ldp interface 'eth1'
+ set protocols mpls ldp router-id '10.0.0.8'
+ set protocols ospf area 0 network '0.0.0.0/0'
+ set protocols ospf parameters abr-type 'cisco'
+ set protocols ospf parameters router-id '10.0.0.8'
+
+- VyOS-PE3:
+
+.. code-block:: none
+
+ # interfaces
+ set interfaces dummy dum10 address '10.0.0.10/32'
+ set interfaces ethernet eth0 address '172.16.140.2/24'
+
+ # protocols ospf + ldp
+ set protocols mpls interface 'eth0'
+ set protocols mpls ldp discovery transport-ipv4-address '10.0.0.10'
+ set protocols mpls ldp interface 'eth0'
+ set protocols mpls ldp router-id '10.0.0.10'
+ set protocols ospf area 0 network '0.0.0.0/0'
+ set protocols ospf parameters abr-type 'cisco'
+ set protocols ospf parameters router-id '10.0.0.10'
+
+- VyOS-RR1:
+
+.. code-block:: none
+
+ # interfaces
+ set interfaces ethernet eth1 address '172.16.20.2/24'
+ set interfaces ethernet eth2 address '172.16.10.2/24'
+ set interfaces dummy dum10 address '10.0.0.1/32'
+
+ # protocols ospf + ldp
+ set protocols mpls interface 'eth1'
+ set protocols mpls interface 'eth2'
+ set protocols mpls ldp discovery transport-ipv4-address '10.0.0.1'
+ set protocols mpls ldp interface 'eth1'
+ set protocols mpls ldp interface 'eth2'
+ set protocols mpls ldp router-id '10.0.0.1'
+ set protocols ospf area 0 network '0.0.0.0/0'
+ set protocols ospf parameters abr-type 'cisco'
+ set protocols ospf parameters router-id '10.0.0.1'
+
+- VyOS-RR2:
+
+.. code-block:: none
+
+ # interfaces
+ set interfaces ethernet eth0 address '172.16.80.1/24'
+ set interfaces ethernet eth1 address '172.16.70.2/24'
+ set interfaces dummy dum10 address '10.0.0.2/32'
+
+ # protocols ospf + ldp
+ set protocols mpls interface 'eth0'
+ set protocols mpls interface 'eth1'
+ set protocols mpls ldp discovery transport-ipv4-address '10.0.0.2'
+ set protocols mpls ldp interface 'eth1'
+ set protocols mpls ldp interface 'eth0'
+ set protocols mpls ldp router-id '10.0.0.2'
+ set protocols ospf area 0 network '0.0.0.0/0'
+ set protocols ospf parameters abr-type 'cisco'
+ set protocols ospf parameters router-id '10.0.0.2'
+
+
+
+Step-2: Configuring iBGP for L3VPN control-plane
+================================================
+
+At this step we are going to enable iBGP protocol on MPLS nodes and
+Route Reflectors (two routers for redundancy) that will deliver IPv4
+VPN (L3VPN) routes between them:
+
+- VyOS-RR1:
+
+.. code-block:: none
+
+ set protocols bgp local-as '65001'
+ set protocols bgp neighbor 10.0.0.7 address-family ipv4-vpn route-reflector-client
+ set protocols bgp neighbor 10.0.0.7 peer-group 'RR_VPNv4'
+ set protocols bgp neighbor 10.0.0.8 address-family ipv4-vpn route-reflector-client
+ set protocols bgp neighbor 10.0.0.8 peer-group 'RR_VPNv4'
+ set protocols bgp neighbor 10.0.0.9 address-family ipv4-vpn route-reflector-client
+ set protocols bgp neighbor 10.0.0.9 peer-group 'RR_VPNv4'
+ set protocols bgp neighbor 10.0.0.10 address-family ipv4-vpn route-reflector-client
+ set protocols bgp neighbor 10.0.0.10 peer-group 'RR_VPNv4'
+ set protocols bgp parameters cluster-id '10.0.0.1'
+ set protocols bgp parameters default no-ipv4-unicast
+ set protocols bgp parameters log-neighbor-changes
+ set protocols bgp parameters router-id '10.0.0.1'
+ set protocols bgp peer-group RR_VPNv4 remote-as '65001'
+ set protocols bgp peer-group RR_VPNv4 update-source 'dum10'
+
+- VyOS-RR2:
+
+.. code-block:: none
+
+ set protocols bgp local-as '65001'
+ set protocols bgp neighbor 10.0.0.7 address-family ipv4-vpn route-reflector-client
+ set protocols bgp neighbor 10.0.0.7 peer-group 'RR_VPNv4'
+ set protocols bgp neighbor 10.0.0.8 address-family ipv4-vpn route-reflector-client
+ set protocols bgp neighbor 10.0.0.8 peer-group 'RR_VPNv4'
+ set protocols bgp neighbor 10.0.0.9 address-family ipv4-vpn route-reflector-client
+ set protocols bgp neighbor 10.0.0.9 peer-group 'RR_VPNv4'
+ set protocols bgp neighbor 10.0.0.10 address-family ipv4-vpn route-reflector-client
+ set protocols bgp neighbor 10.0.0.10 peer-group 'RR_VPNv4'
+ set protocols bgp parameters cluster-id '10.0.0.1'
+ set protocols bgp parameters default no-ipv4-unicast
+ set protocols bgp parameters log-neighbor-changes
+ set protocols bgp parameters router-id '10.0.0.2'
+ set protocols bgp peer-group RR_VPNv4 remote-as '65001'
+ set protocols bgp peer-group RR_VPNv4 update-source 'dum10'
+
+- VyOS-PE1:
+
+.. code-block:: none
+
+ set protocols bgp local-as '65001'
+ set protocols bgp neighbor 10.0.0.1 address-family ipv4-vpn nexthop-self
+ set protocols bgp neighbor 10.0.0.1 peer-group 'RR_VPNv4'
+ set protocols bgp neighbor 10.0.0.2 address-family ipv4-vpn nexthop-self
+ set protocols bgp neighbor 10.0.0.2 peer-group 'RR_VPNv4'
+ set protocols bgp parameters default no-ipv4-unicast
+ set protocols bgp parameters log-neighbor-changes
+ set protocols bgp parameters router-id '10.0.0.7'
+ set protocols bgp peer-group RR_VPNv4 remote-as '65001'
+ set protocols bgp peer-group RR_VPNv4 update-source 'dum10'
+
+- VyOS-PE2:
+
+.. code-block:: none
+
+ set protocols bgp local-as '65001'
+ set protocols bgp neighbor 10.0.0.1 address-family ipv4-vpn nexthop-self
+ set protocols bgp neighbor 10.0.0.1 peer-group 'RR_VPNv4'
+ set protocols bgp neighbor 10.0.0.2 address-family ipv4-vpn nexthop-self
+ set protocols bgp neighbor 10.0.0.2 peer-group 'RR_VPNv4'
+ set protocols bgp parameters default no-ipv4-unicast
+ set protocols bgp parameters log-neighbor-changes
+ set protocols bgp parameters router-id '10.0.0.8'
+ set protocols bgp peer-group RR_VPNv4 remote-as '65001'
+ set protocols bgp peer-group RR_VPNv4 update-source 'dum10'
+
+- VyOS-PE3:
+
+.. code-block:: none
+
+ set protocols bgp local-as '65001'
+ set protocols bgp neighbor 10.0.0.1 address-family ipv4-vpn nexthop-self
+ set protocols bgp neighbor 10.0.0.1 peer-group 'RR_VPNv4'
+ set protocols bgp neighbor 10.0.0.2 address-family ipv4-vpn nexthop-self
+ set protocols bgp neighbor 10.0.0.2 peer-group 'RR_VPNv4'
+ set protocols bgp parameters default no-ipv4-unicast
+ set protocols bgp parameters log-neighbor-changes
+ set protocols bgp parameters router-id '10.0.0.10'
+ set protocols bgp peer-group RR_VPNv4 remote-as '65001'
+ set protocols bgp peer-group RR_VPNv4 update-source 'dum10'
+
+
+
+Step-3: Configuring L3VPN VRFs on PE nodes
+==========================================
+
+This section provides configuration steps for setting up VRFs on our
+PE nodes including CE facing interfaces, BGP, rd and route-target
+import/export based on the pre-defined parameters.
+
+- VyOS-PE1:
+
+.. code-block:: none
+
+ # VRF settings
+ set vrf name BLUE_SPOKE table '200'
+ set vrf name BLUE_SPOKE protocols bgp address-family ipv4-unicast export vpn
+ set vrf name BLUE_SPOKE protocols bgp address-family ipv4-unicast import vpn
+ set vrf name BLUE_SPOKE protocols bgp address-family ipv4-unicast label vpn export 'auto'
+ set vrf name BLUE_SPOKE protocols bgp address-family ipv4-unicast network 10.50.50.0/24
+ set vrf name BLUE_SPOKE protocols bgp address-family ipv4-unicast rd vpn export '10.50.50.1:1011'
+ set vrf name BLUE_SPOKE protocols bgp address-family ipv4-unicast redistribute connected
+ set vrf name BLUE_SPOKE protocols bgp address-family ipv4-unicast route-target vpn export '65035:1011'
+ set vrf name BLUE_SPOKE protocols bgp address-family ipv4-unicast route-target vpn import '65035:1030'
+ set vrf name BLUE_SPOKE protocols bgp local-as '65001'
+ set vrf name BLUE_SPOKE protocols bgp neighbor 10.50.50.2 address-family ipv4-unicast as-override
+ set vrf name BLUE_SPOKE protocols bgp neighbor 10.50.50.2 remote-as '65035'
+
+ # interfaces
+ set interfaces ethernet eth3 address '10.50.50.1/24'
+ set interfaces ethernet eth3 vrf 'BLUE_SPOKE'
+
+- VyOS-PE2:
+
+.. code-block:: none
+
+ # VRF settings
+ set vrf name BLUE_HUB table '400'
+ set vrf name BLUE_HUB protocols bgp address-family ipv4-unicast export vpn
+ set vrf name BLUE_HUB protocols bgp address-family ipv4-unicast import vpn
+ set vrf name BLUE_HUB protocols bgp address-family ipv4-unicast label vpn export 'auto'
+ set vrf name BLUE_HUB protocols bgp address-family ipv4-unicast network 10.80.80.0/24
+ set vrf name BLUE_HUB protocols bgp address-family ipv4-unicast rd vpn export '10.80.80.1:1011'
+ set vrf name BLUE_HUB protocols bgp address-family ipv4-unicast redistribute connected
+ set vrf name BLUE_HUB protocols bgp address-family ipv4-unicast route-target vpn export '65035:1030'
+ set vrf name BLUE_HUB protocols bgp address-family ipv4-unicast route-target vpn import '65035:1011 65050:2011 65035:1030'
+ set vrf name BLUE_HUB protocols bgp local-as '65001'
+ set vrf name BLUE_HUB protocols bgp neighbor 10.80.80.2 address-family ipv4-unicast as-override
+ set vrf name BLUE_HUB protocols bgp neighbor 10.80.80.2 remote-as '65035'
+
+ # interfaces
+ set interfaces ethernet eth3 address '10.80.80.1/24'
+ set interfaces ethernet eth3 vrf 'BLUE_HUB'
+
+- VyOS-PE3:
+
+.. code-block:: none
+
+ # VRF settings
+ set vrf name BLUE_SPOKE table '200'
+ set vrf name BLUE_SPOKE protocols bgp address-family ipv4-unicast export vpn
+ set vrf name BLUE_SPOKE protocols bgp address-family ipv4-unicast import vpn
+ set vrf name BLUE_SPOKE protocols bgp address-family ipv4-unicast label vpn export 'auto'
+ set vrf name BLUE_SPOKE protocols bgp address-family ipv4-unicast network 10.60.60.0/24
+ set vrf name BLUE_SPOKE protocols bgp address-family ipv4-unicast rd vpn export '10.60.60.1:1011'
+ set vrf name BLUE_SPOKE protocols bgp address-family ipv4-unicast redistribute connected
+ set vrf name BLUE_SPOKE protocols bgp address-family ipv4-unicast route-target vpn export '65035:1011'
+ set vrf name BLUE_SPOKE protocols bgp address-family ipv4-unicast route-target vpn import '65035:1030'
+ set vrf name BLUE_SPOKE protocols bgp local-as '65001'
+ set vrf name BLUE_SPOKE protocols bgp neighbor 10.60.60.2 address-family ipv4-unicast as-override
+ set vrf name BLUE_SPOKE protocols bgp neighbor 10.60.60.2 remote-as '65035'
+
+ # interfaces
+ set interfaces ethernet eth3 address '10.60.60.1/24'
+ set interfaces ethernet eth3 vrf 'BLUE_SPOKE'
+
+
+
+Step-4: Configuring CE nodes
+============================
+
+Dynamic routing used between CE and PE nodes and eBGP peering
+established for the route exchanging between them. All routes
+received by PEs are then exported to L3VPN and delivered from
+Spoke sites to Hub and vise-versa based on previously
+configured L3VPN parameters.
+
+- VyOS-CE1-SPOKE:
+
+.. code-block:: none
+
+ # interfaces
+ set interfaces dummy dum20 address '10.0.0.80/32'
+ set interfaces ethernet eth0 address '10.50.50.2/24'
+
+ # BGP for peering with PE
+ set protocols bgp 65035 address-family ipv4-unicast network 10.0.0.80/32
+ set protocols bgp 65035 neighbor 10.50.50.1 ebgp-multihop '2'
+ set protocols bgp 65035 neighbor 10.50.50.1 remote-as '65001'
+ set protocols bgp 65035 neighbor 10.50.50.1 update-source 'eth0'
+ set protocols bgp 65035 parameters default no-ipv4-unicast
+ set protocols bgp 65035 parameters log-neighbor-changes
+ set protocols bgp 65035 parameters router-id '10.50.50.2'
+
+- VyOS-CE1-HUB:
+
+.. code-block:: none
+
+ # interfaces
+ set interfaces dummy dum20 address '10.0.0.100/32'
+ set interfaces ethernet eth0 address '10.80.80.2/24'
+
+ # BGP for peering with PE
+ set protocols bgp 65035 address-family ipv4-unicast network 10.0.0.100/32
+ set protocols bgp 65035 address-family ipv4-unicast redistribute connected
+ set protocols bgp 65035 neighbor 10.80.80.1 ebgp-multihop '2'
+ set protocols bgp 65035 neighbor 10.80.80.1 remote-as '65001'
+ set protocols bgp 65035 neighbor 10.80.80.1 update-source 'eth0'
+ set protocols bgp 65035 parameters default no-ipv4-unicast
+ set protocols bgp 65035 parameters log-neighbor-changes
+ set protocols bgp 65035 parameters router-id '10.80.80.2'
+
+- VyOS-CE2-SPOKE:
+
+.. code-block:: none
+
+ # interfaces
+ set interfaces dummy dum20 address '10.0.0.90/32'
+ set interfaces ethernet eth0 address '10.60.60.2/24'
+
+ # BGP for peering with PE
+ set protocols bgp 65035 address-family ipv4-unicast network 10.0.0.90/32
+ set protocols bgp 65035 neighbor 10.60.60.1 ebgp-multihop '2'
+ set protocols bgp 65035 neighbor 10.60.60.1 remote-as '65001'
+ set protocols bgp 65035 neighbor 10.60.60.1 update-source 'eth0'
+ set protocols bgp 65035 parameters default no-ipv4-unicast
+ set protocols bgp 65035 parameters log-neighbor-changes
+ set protocols bgp 65035 parameters router-id '10.60.60.2'
+
+
+
+Step-5: Verification
+====================
+
+This section describes verification commands for MPLS/BGP/LDP
+protocols and L3VPN related routes as well as diagnosis and
+reachability checks between CE nodes.
+
+Let’s check IPv4 routing and MPLS information on provider nodes
+(same procedure for all P nodes):
+
+- “show ip ospf neighbor” for checking ospf relationship
+
+.. code-block:: none
+
+ vyos@VyOS-P1:~$ show ip ospf neighbor
+
+ Neighbor ID Pri State Dead Time Address Interface RXmtL RqstL DBsmL
+ 10.0.0.4 1 Full/Backup 34.718s 172.16.30.2 eth0:172.16.30.1 0 0 0
+ 10.0.0.5 1 Full/Backup 35.132s 172.16.40.2 eth1:172.16.40.1 0 0 0
+ 10.0.0.7 1 Full/Backup 34.764s 172.16.90.2 eth2:172.16.90.1 0 0 0
+ 10.0.0.1 1 Full/Backup 35.642s 172.16.10.2 eth3:172.16.10.1 0 0 0
+ 10.0.0.8 1 Full/Backup 35.484s 172.16.100.2 eth5:172.16.100.1 0 0 0
+
+- “show mpls ldp neighbor “ for checking ldp neighbors
+
+.. code-block:: none
+
+ vyos@VyOS-P1:~$ show mpls ldp neighbor
+ AF ID State Remote Address Uptime
+ ipv4 10.0.0.1 OPERATIONAL 10.0.0.1 07w5d06h
+ ipv4 10.0.0.4 OPERATIONAL 10.0.0.4 09w3d00h
+ ipv4 10.0.0.5 OPERATIONAL 10.0.0.5 09w2d23h
+ ipv4 10.0.0.7 OPERATIONAL 10.0.0.7 03w0d01h
+ ipv4 10.0.0.8 OPERATIONAL 10.0.0.8 01w3d02h
+
+- “show mpls ldp binding” for checking mpls label assignment
+
+.. code-block:: none
+
+ vyos@VyOS-P1:~$ show mpls ldp discovery
+ AF Destination Nexthop Local Label Remote Label In Use
+ ipv4 10.0.0.1/32 10.0.0.1 23 imp-null yes
+ ipv4 10.0.0.1/32 10.0.0.4 23 20 no
+ ipv4 10.0.0.1/32 10.0.0.5 23 17 no
+ ipv4 10.0.0.1/32 10.0.0.7 23 16 no
+ ipv4 10.0.0.1/32 10.0.0.8 23 16 no
+ ipv4 10.0.0.2/32 10.0.0.1 20 16 no
+ ipv4 10.0.0.2/32 10.0.0.4 20 22 no
+ ipv4 10.0.0.2/32 10.0.0.5 20 24 yes
+ ipv4 10.0.0.2/32 10.0.0.7 20 17 no
+ ipv4 10.0.0.2/32 10.0.0.8 20 17 no
+ ipv4 10.0.0.3/32 10.0.0.1 imp-null 17 no
+ ipv4 10.0.0.3/32 10.0.0.4 imp-null 16 no
+ ipv4 10.0.0.3/32 10.0.0.5 imp-null 18 no
+ ipv4 10.0.0.3/32 10.0.0.7 imp-null 18 no
+ ipv4 10.0.0.3/32 10.0.0.8 imp-null 18 no
+ ipv4 10.0.0.4/32 10.0.0.1 16 18 no
+ ipv4 10.0.0.4/32 10.0.0.4 16 imp-null yes
+ ipv4 10.0.0.4/32 10.0.0.5 16 19 no
+ ipv4 10.0.0.4/32 10.0.0.7 16 19 no
+ ipv4 10.0.0.4/32 10.0.0.8 16 19 no
+ ipv4 10.0.0.5/32 10.0.0.1 21 19 no
+ ipv4 10.0.0.5/32 10.0.0.4 21 17 no
+ ipv4 10.0.0.5/32 10.0.0.5 21 imp-null yes
+ ipv4 10.0.0.5/32 10.0.0.7 21 20 no
+ ipv4 10.0.0.5/32 10.0.0.8 21 20 no
+ ipv4 10.0.0.6/32 10.0.0.1 17 20 no
+ ipv4 10.0.0.6/32 10.0.0.4 17 23 yes
+ ipv4 10.0.0.6/32 10.0.0.5 17 21 yes
+ ipv4 10.0.0.6/32 10.0.0.7 17 21 no
+ ipv4 10.0.0.6/32 10.0.0.8 17 21 no
+ ipv4 10.0.0.7/32 10.0.0.1 22 21 no
+ ipv4 10.0.0.7/32 10.0.0.4 22 18 no
+ ipv4 10.0.0.7/32 10.0.0.5 22 20 no
+ ipv4 10.0.0.7/32 10.0.0.7 22 imp-null yes
+ ipv4 10.0.0.7/32 10.0.0.8 22 22 no
+ ipv4 10.0.0.8/32 10.0.0.1 24 22 no
+ ipv4 10.0.0.8/32 10.0.0.4 24 19 no
+ ipv4 10.0.0.8/32 10.0.0.5 24 16 no
+ ipv4 10.0.0.8/32 10.0.0.7 24 22 no
+ ipv4 10.0.0.8/32 10.0.0.8 24 imp-null yes
+ ipv4 10.0.0.9/32 10.0.0.1 18 23 no
+ ipv4 10.0.0.9/32 10.0.0.4 18 21 yes
+ ipv4 10.0.0.9/32 10.0.0.5 18 22 no
+ ipv4 10.0.0.9/32 10.0.0.7 18 23 no
+ ipv4 10.0.0.9/32 10.0.0.8 18 23 no
+ ipv4 10.0.0.10/32 10.0.0.1 19 24 no
+ ipv4 10.0.0.10/32 10.0.0.4 19 24 yes
+ ipv4 10.0.0.10/32 10.0.0.5 19 23 yes
+ ipv4 10.0.0.10/32 10.0.0.7 19 24 no
+ ipv4 10.0.0.10/32 10.0.0.8 19 24 no
+
+Now we’re checking iBGP status and routes from route-reflector
+nodes to other devices:
+
+- “show bgp ipv4 vpn summary” for checking BGP VPNv4 neighbors:
+
+.. code-block:: none
+
+ vyos@VyOS-RR1:~$ show bgp ipv4 vpn summary
+ BGP router identifier 10.0.0.1, local AS number 65001 vrf-id 0
+ BGP table version 0
+ RIB entries 9, using 1728 bytes of memory
+ Peers 4, using 85 KiB of memory
+ Peer groups 1, using 64 bytes of memory
+
+ Neighbor V AS MsgRcvd MsgSent TblVer InQ OutQ Up/Down State/PfxRcd PfxSnt
+ 10.0.0.7 4 65001 7719 7733 0 0 0 5d07h56m 2 10
+ 10.0.0.8 4 65001 7715 7724 0 0 0 5d08h28m 4 10
+ 10.0.0.9 4 65001 7713 7724 0 0 0 5d08h28m 2 10
+ 10.0.0.10 4 65001 7713 7724 0 0 0 5d08h28m 2 10
+
+ Total number of neighbors 4
+
+- “show bgp ipv4 vpn” for checking all VPNv4 prefixes information:
+
+.. code-block:: none
+
+ vyos@VyOS-RR1:~$ show bgp ipv4 vpn
+ BGP table version is 2, local router ID is 10.0.0.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
+ Route Distinguisher: 10.50.50.1:1011
+ *>i10.50.50.0/24 10.0.0.7 0 100 0 i
+ UN=10.0.0.7 EC{65035:1011} label=80 type=bgp, subtype=0
+ *>i80.80.80.80/32 10.0.0.7 0 100 0 65035 i
+ UN=10.0.0.7 EC{65035:1011} label=80 type=bgp, subtype=0
+ Route Distinguisher: 10.60.60.1:1011
+ *>i10.60.60.0/24 10.0.0.10 0 100 0 i
+ UN=10.0.0.10 EC{65035:1011} label=80 type=bgp, subtype=0
+ *>i90.90.90.90/32 10.0.0.10 0 100 0 65035 i
+ UN=10.0.0.10 EC{65035:1011} label=80 type=bgp, subtype=0
+ Route Distinguisher: 10.80.80.1:1011
+ *>i10.80.80.0/24 10.0.0.8 0 100 0 i
+ UN=10.0.0.8 EC{65035:1030} label=80 type=bgp, subtype=0
+ *>i100.100.100.100/32
+ 10.0.0.8 0 100 0 65035 i
+ UN=10.0.0.8 EC{65035:1030} label=80 type=bgp, subtype=0
+ Route Distinguisher: 172.16.80.1:2011
+ *>i10.110.110.0/24 10.0.0.8 0 100 0 65050 i
+ UN=10.0.0.8 EC{65050:2011} label=81 type=bgp, subtype=0
+ *>i172.16.80.0/24 10.0.0.8 0 100 0 i
+ UN=10.0.0.8 EC{65050:2011} label=81 type=bgp, subtype=0
+ Route Distinguisher: 172.16.100.1:2011
+ *>i10.210.210.0/24 10.0.0.9 0 100 0 65050 i
+ UN=10.0.0.9 EC{65050:2011} label=80 type=bgp, subtype=0
+ *>i172.16.100.0/24 10.0.0.9 0 100 0 i
+ UN=10.0.0.9 EC{65050:2011} label=80 type=bgp, subtype=0
+
+- “show bgp ipv4 vpn x.x.x.x/x” for checking best path selected
+ for specific VPNv4 destination
+
+.. code-block:: none
+
+ vyos@VyOS-RR1:~$ show bgp ipv4 vpn 10.0.0.100/32
+ BGP routing table entry for 10.80.80.1:1011:10.0.0.100/32
+ not allocated
+ Paths: (1 available, best #1)
+ Advertised to non peer-group peers:
+ 10.0.0.7 10.0.0.8 10.0.0.9 10.0.0.10
+ 65035, (Received from a RR-client)
+ 10.0.0.8 from 10.0.0.8 (10.0.0.8)
+ Origin incomplete, metric 0, localpref 100, valid, internal, best (First path received)
+ Extended Community: RT:65035:1030
+ Remote label: 80
+ Last update: Tue Oct 19 13:45:32 202
+
+Also we can verify how PE devices receives VPNv4 networks from the RRs
+and installing them to the specific customer VRFs:
+
+- “show bgp ipv4 vpn summary” for checking iBGP neighbors against
+ route-reflector devices:
+
+.. code-block:: none
+
+ vyos@VyOS-PE1:~$ show bgp ipv4 vpn summary
+ BGP router identifier 10.0.0.7, local AS number 65001 vrf-id 0
+ BGP table version 0
+ RIB entries 9, using 1728 bytes of memory
+ Peers 2, using 43 KiB of memory
+ Peer groups 1, using 64 bytes of memory
+
+ Neighbor V AS MsgRcvd MsgSent TblVer InQ OutQ Up/Down State/PfxRcd PfxSnt
+ 10.0.0.1 4 65001 8812 8794 0 0 0 01:18:42 8 2
+ 10.0.0.2 4 65001 8800 8792 0 0 0 6d02h27m 8 2
+
+- “show bgp vrf all” for checking all the prefix learning on BGP
+ within VRFs:
+
+.. code-block:: none
+
+ vyos@VyOS-PE1:~$ show bgp vrf all
+
+ Instance default:
+ No BGP prefixes displayed, 0 exist
+
+ Instance BLUE_SPOKE:
+ BGP table version is 8, local router ID is 10.50.50.1, vrf id 6
+ 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
+ * 10.50.50.0/24 0.0.0.0 0 32768 ?
+ *> 0.0.0.0 0 32768 i
+ *> 10.80.80.0/24 10.0.0.8@0< 0 100 0 i
+ * 10.0.0.8@0< 0 100 0 i
+ *> 10.0.0.80/32 10.50.50.2 0 0 65035 i
+ *> 10.0.0.100/32
+ 10.0.0.8@0< 0 100 0 65035 ?
+ * 10.0.0.8@0< 0 100 0 65035 ?
+
+- “show bgp vrf BLUE_SPOKE summary” for checking EBGP neighbor
+ information between PE and CE:
+
+.. code-block:: none
+
+ vyos@VyOS-PE1:~$ show bgp vrf BLUE_SPOKE summary
+
+
+ IPv4 Unicast Summary:
+ BGP router identifier 10.50.50.1, local AS number 65001 vrf-id 6
+ BGP table version 8
+ RIB entries 7, using 1344 bytes of memory
+ Peers 1, using 21 KiB of memory
+
+ Neighbor V AS MsgRcvd MsgSent TblVer InQ OutQ Up/Down State/PfxRcd PfxSnt
+ 10.50.50.2 4 65035 9019 9023 0 0 0 6d06h12m 1 4
+
+ Total number of neighbors 1
+
+- “show ip route vrf BLUE_SPOKE” for viewing the RIB in our Spoke PE.
+ Using this command we are also able to check the transport and
+ customer label (inner/outer) for Hub network prefix (10.0.0.100/32):
+
+.. code-block:: none
+
+ vyos@VyOS-PE1:~$ show ip route vrf BLUE_SPOKE
+
+ Codes: K - kernel route, C - connected, S - static, R - RIP,
+ O - OSPF, I - IS-IS, B - BGP, E - EIGRP, N - NHRP,
+ T - Table, v - VNC, V - VNC-Direct, A - Babel, D - SHARP,
+ F - PBR, f - OpenFabric,
+ > - selected route, * - FIB route, q - queued, r - rejected, b - backup
+
+ VRF BLUE_SPOKE:
+ K>* 0.0.0.0/0 [255/8192] unreachable (ICMP unreachable), 03w0d23h
+ C>* 10.50.50.0/24 is directly connected, eth3, 03w0d23h
+ B> 10.80.80.0/24 [200/0] via 10.0.0.8 (vrf default) (recursive), label 80, weight 1, 04:22:00
+ * via 172.16.90.1, eth0 (vrf default), label 24/80, weight 1, 04:22:00
+ B>* 10.0.0.80/32 [20/0] via 10.50.50.2, eth3, weight 1, 6d05h30m
+ B> 10.0.0.100/32 [200/0] via 10.0.0.8 (vrf default) (recursive), label 80, weight 1, 04:22:00
+ * via 172.16.90.1, eth0 (vrf default), label 24/80, weight 1, 04:22:00
+
+- “show bgp ipv4 vpn x.x.x.x/32” for checking the best-path to the
+ specific VPNv4 destination including extended community and
+ remotelabel information. This procedure is the same on all Spoke nodes:
+
+.. code-block:: none
+
+ vyos@VyOS-PE1:~$ show bgp ipv4 vpn 10.0.0.100/32
+ BGP routing table entry for 10.80.80.1:1011:10.0.0.100/32
+ not allocated
+ Paths: (2 available, best #1)
+ Not advertised to any peer
+ 65035
+ 10.0.0.8 from 10.0.0.1 (10.0.0.8)
+ Origin incomplete, metric 0, localpref 100, valid, internal, best (Neighbor IP)
+ Extended Community: RT:65035:1030
+ Originator: 10.0.0.8, Cluster list: 10.0.0.1
+ Remote label: 80
+ Last update: Tue Oct 19 13:45:26 2021
+ 65035
+ 10.0.0.8 from 10.0.0.2 (10.0.0.8)
+ Origin incomplete, metric 0, localpref 100, valid, internal
+ Extended Community: RT:65035:1030
+ Originator: 10.0.0.8, Cluster list: 10.0.0.1
+ Remote label: 80
+ Last update: Wed Oct 13 12:39:34 202
+
+Now, let’s check routing information on out Hub PE:
+- “show bgp ipv4 vpn summary” for checking iBGP neighbors again
+ VyOS-RR1/RR2
+
+.. code-block:: none
+
+ vyos@VyOS-PE2:~$ show bgp ipv4 vpn summary
+ BGP router identifier 10.0.0.8, local AS number 65001 vrf-id 0
+ BGP table version 0
+ RIB entries 9, using 1728 bytes of memory
+ Peers 2, using 43 KiB of memory
+ Peer groups 1, using 64 bytes of memory
+
+ Neighbor V AS MsgRcvd MsgSent TblVer InQ OutQ Up/Down State/PfxRcd PfxSnt
+ 10.0.0.1 4 65001 15982 15949 0 0 0 05:41:28 6 4
+ 10.0.0.2 4 65001 9060 9054 0 0 0 6d06h47m 6 4
+
+ Total number of neighbors
+
+- “show bgp vrf all” for checking all the prefixes learning on BGP
+
+.. code-block:: none
+
+ vyos@VyOS-PE2:~$ show bgp vrf all
+
+ Instance default:
+ No BGP prefixes displayed, 0 exist
+
+ Instance BLUE_HUB:
+ BGP table version is 50, local router ID is 10.80.80.1, vrf id 8
+ 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
+ *> 10.50.50.0/24 10.0.0.7@0< 0 100 0 i
+ * 10.0.0.7@0< 0 100 0 i
+ *> 10.60.60.0/24 10.0.0.10@0< 0 100 0 i
+ * 10.0.0.10@0< 0 100 0 i
+ * 10.80.80.0/24 10.80.80.2 0 0 65035 ?
+ * 0.0.0.0 0 32768 i
+ *> 0.0.0.0 0 32768 ?
+ *> 10.110.110.0/24 172.16.80.2@9< 0 0 65050 i
+ *> 10.210.210.0/24 10.0.0.9@0< 0 100 0 65050 i
+ * 10.0.0.9@0< 0 100 0 65050 i
+ *> 10.0.0.80/32 10.0.0.7@0< 0 100 0 65035 i
+ * 10.0.0.7@0< 0 100 0 65035 i
+ *> 10.0.0.90/32 10.0.0.10@0< 0 100 0 65035 i
+ * 10.0.0.10@0< 0 100 0 65035 i
+ *> 10.0.0.100/32
+ 10.80.80.2 0 0 65035 ?
+ *> 172.16.80.0/24 0.0.0.0@9< 0 32768 ?
+ 0.0.0.0@9< 0 32768 i
+ *> 172.16.100.0/24 10.0.0.9@0< 0 100 0 i
+ * 10.0.0.9@0< 0 100 0 i
+
+- “show bgp vrf BLUE_HUB summary” for checking EBGP neighbor
+ CE Hub device
+
+.. code-block:: none
+
+ vyos@VyOS-PE2:~$ show bgp vrf BLUE_HUB summary
+
+ IPv4 Unicast Summary:
+ BGP router identifier 10.80.80.1, local AS number 65001 vrf-id 8
+ BGP table version 50
+ RIB entries 19, using 3648 bytes of memory
+ Peers 1, using 21 KiB of memory
+
+ Neighbor V AS MsgRcvd MsgSent TblVer InQ OutQ Up/Down State/PfxRcd PfxSnt
+ 10.80.80.2 4 65035 15954 15972 0 0 0 01w4d01h 2 10
+
+- “show ip route vrf BLUE_HUB” to view the RIB in our Hub PE.
+ With this command we are able to check the transport and
+ customer label (inner/outer) for network spokes prefixes
+ 10.0.0.80/32 - 10.0.0.90/32
+
+.. code-block:: none
+
+ vyos@VyOS-PE2:~$ show ip route vrf BLUE_HUB
+ Codes: K - kernel route, C - connected, S - static, R - RIP,
+ O - OSPF, I - IS-IS, B - BGP, E - EIGRP, N - NHRP,
+ T - Table, v - VNC, V - VNC-Direct, A - Babel, D - SHARP,
+ F - PBR, f - OpenFabric,
+ > - selected route, * - FIB route, q - queued, r - rejected, b - backup
+ VRF BLUE_HUB:
+ K>* 0.0.0.0/0 [255/8192] unreachable (ICMP unreachable), 01w4d01h
+ B> 10.50.50.0/24 [200/0] via 10.0.0.7 (vrf default) (recursive), label 144, weight 1, 05:53:15
+ * via 172.16.100.1, eth1 (vrf default), label 22/144, weight 1, 05:53:15
+ B> 10.60.60.0/24 [200/0] via 10.0.0.10 (vrf default) (recursive), label 144, weight 1, 05:53:15
+ * via 172.16.110.1, eth0 (vrf default), label 23/144, weight 1, 05:53:15
+ C>* 10.80.80.0/24 is directly connected, eth3, 01w4d01h
+ B>* 10.110.110.0/24 [200/0] via 172.16.80.2, eth2 (vrf GREEN), weight 1, 01w4d01h
+ B> 10.210.210.0/24 [200/0] via 10.0.0.9 (vrf default) (recursive), label 144, weight 1, 05:53:15
+ * via 172.16.100.1, eth1 (vrf default), label 18/144, weight 1, 05:53:15
+ * via 172.16.110.1, eth0 (vrf default), label 22/144, weight 1, 05:53:15
+ B> 10.0.0.80/32 [200/0] via 10.0.0.7 (vrf default) (recursive), label 144, weight 1, 05:53:15
+ * via 172.16.100.1, eth1 (vrf default), label 22/144, weight 1, 05:53:15
+ B> 10.0.0.90/32 [200/0] via 10.0.0.10 (vrf default) (recursive), label 144, weight 1, 05:53:15
+ * via 172.16.110.1, eth0 (vrf default), label 23/144, weight 1, 05:53:15
+ B>* 10.0.0.100/32 [20/0] via 10.80.80.2, eth3, weight 1, 01w4d01h
+ B>* 172.16.80.0/24 [200/0] is directly connected, eth2 (vrf GREEN), weight 1, 01w4d01h
+ B> 172.16.100.0/24 [200/0] via 10.0.0.9 (vrf default) (recursive), label 144, weight 1, 05:53:15
+ * via 172.16.100.1, eth1 (vrf default), label 18/144, weight 1, 05:53:15
+ * via 172.16.110.1, eth0 (vrf default), label 22/144, weight 1, 05:53:15
+
+- “show bgp ipv4 vpn x.x.x.x/32” for checking best-path,
+ extended community and remote label of specific destination
+
+.. code-block:: none
+
+ vyos@VyOS-PE2:~$ show bgp ipv4 vpn 10.0.0.80/32
+ BGP routing table entry for 10.50.50.1:1011:10.0.0.80/32
+ not allocated
+ Paths: (2 available, best #1)
+ Not advertised to any peer
+ 65035
+ 10.0.0.7 from 10.0.0.1 (10.0.0.7)
+ Origin IGP, metric 0, localpref 100, valid, internal, best (Neighbor IP)
+ Extended Community: RT:65035:1011
+ Originator: 10.0.0.7, Cluster list: 10.0.0.1
+ Remote label: 144
+ Last update: Tue Oct 19 13:45:30 2021
+ 65035
+ 10.0.0.7 from 10.0.0.2 (10.0.0.7)
+ Origin IGP, metric 0, localpref 100, valid, internal
+ Extended Community: RT:65035:1011
+ Originator: 10.0.0.7, Cluster list: 10.0.0.1
+ Remote label: 144
+ Last update: Wed Oct 13 12:39:37 2021
+
+ vyos@VyOS-PE2:~$ show bgp ipv4 vpn 10.0.0.90/32
+ BGP routing table entry for 10.60.60.1:1011:10.0.0.90/32
+ not allocated
+ Paths: (2 available, best #1)
+ Not advertised to any peer
+ 65035
+ 10.0.0.10 from 10.0.0.1 (10.0.0.10)
+ Origin IGP, metric 0, localpref 100, valid, internal, best (Neighbor IP)
+ Extended Community: RT:65035:1011
+ Originator: 10.0.0.10, Cluster list: 10.0.0.1
+ Remote label: 144
+ Last update: Tue Oct 19 13:45:30 2021
+ 65035
+ 10.0.0.10 from 10.0.0.2 (10.0.0.10)
+ Origin IGP, metric 0, localpref 100, valid, internal
+ Extended Community: RT:65035:1011
+ Originator: 10.0.0.10, Cluster list: 10.0.0.1
+ Remote label: 144
+ Last update: Wed Oct 13 12:45:44 2021
+
+Finally, let’s check the reachability between CEs:
+
+- VyOS-CE1-SPOKE -----> VyOS-CE-HUB
+
+
+.. code-block:: none
+
+ # check rib
+ vyos@VyOS-CE1-SPOKE:~$ show ip route
+ Codes: K - kernel route, C - connected, S - static, R - RIP,
+ O - OSPF, I - IS-IS, B - BGP, E - EIGRP, N - NHRP,
+ T - Table, v - VNC, V - VNC-Direct, A - Babel, D - SHARP,
+ F - PBR, f - OpenFabric,
+ > - selected route, * - FIB route, q - queued, r - rejected, b - backup
+
+ B 10.50.50.0/24 [20/0] via 10.50.50.1 inactive, weight 1, 6d07h53m
+ C>* 10.50.50.0/24 is directly connected, eth0, 09w0d00h
+ B>* 10.80.80.0/24 [20/0] via 10.50.50.1, eth0, weight 1, 6d07h53m
+ C>* 10.0.0.80/32 is directly connected, dum20, 09w0d00h
+ B>* 10.0.0.100/32 [20/0] via 10.50.50.1, eth0, weight 1, 6d07h53m
+
+ # check icmp
+ vyos@VyOS-CE1-SPOKE:~$ ping 10.0.0.100 interface 10.0.0.80
+ PING 10.0.0.100 (10.0.0.100) from 10.0.0.80 : 56(84) bytes of data.
+ 64 bytes from 10.0.0.100: icmp_seq=1 ttl=62 time=6.52 ms
+ 64 bytes from 10.0.0.100: icmp_seq=2 ttl=62 time=4.13 ms
+ 64 bytes from 10.0.0.100: icmp_seq=3 ttl=62 time=4.04 ms
+ 64 bytes from 10.0.0.100: icmp_seq=4 ttl=62 time=4.03 ms
+ ^C
+ --- 10.0.0.100 ping statistics ---
+ 4 packets transmitted, 4 received, 0% packet loss, time 8ms
+ rtt min/avg/max/mdev = 4.030/4.680/6.518/1.064 ms
+
+ # check network path
+ vyos@VyOS-CE1-SPOKE:~$ traceroute 10.0.0.100
+ traceroute to 10.0.0.100 (10.0.0.100), 30 hops max, 60 byte packets
+ 1 10.50.50.1 (10.50.50.1) 1.041 ms 1.252 ms 1.835 ms
+ 2 * * *
+ 3 10.0.0.100 (10.0.0.100) 9.225 ms 9.159 ms 9.121 m
+
+- VyOS-CE-HUB -------> VyOS-CE1-SPOKE
+- VyOS-CE-HUB -------> VyOS-CE2-SPOKE
+
+.. code-block:: none
+
+ # check rib
+ vyos@VyOS-CE-HUB:~$ show ip route
+ Codes: K - kernel route, C - connected, S - static, R - RIP,
+ O - OSPF, I - IS-IS, B - BGP, E - EIGRP, N - NHRP,
+ T - Table, v - VNC, V - VNC-Direct, A - Babel, D - SHARP,
+ F - PBR, f - OpenFabric,
+ > - selected route, * - FIB route, q - queued, r - rejected, b - backup
+
+ B>* 10.50.50.0/24 [20/0] via 10.80.80.1, eth0, weight 1, 6d08h04m
+ B>* 10.60.60.0/24 [20/0] via 10.80.80.1, eth0, weight 1, 6d08h35m
+ C>* 10.80.80.0/24 is directly connected, eth0, 01w6d07h
+ B>* 10.110.110.0/24 [20/0] via 10.80.80.1, eth0, weight 1, 01w4d02h
+ B>* 10.210.210.0/24 [20/0] via 10.80.80.1, eth0, weight 1, 6d08h35m
+ B>* 10.0.0.80/32 [20/0] via 10.80.80.1, eth0, weight 1, 6d08h04m
+ B>* 10.0.0.90/32 [20/0] via 10.80.80.1, eth0, weight 1, 6d08h35m
+ C>* 10.0.0.100/32 is directly connected, dum20, 01w6d07h
+ B>* 172.16.80.0/24 [20/0] via 10.80.80.1, eth0, weight 1, 01w4d02h
+ B>* 172.16.100.0/24 [20/0] via 10.80.80.1, eth0, weight 1, 6d08h35m
+
+ # check icmp
+ vyos@VyOS-CE-HUB:~$ ping 10.0.0.80 interface 10.0.0.100 c 4
+ PING 10.0.0.80 (10.0.0.80) from 10.0.0.100 : 56(84) bytes of data.
+ 64 bytes from 10.0.0.80: icmp_seq=1 ttl=62 time=3.31 ms
+ 64 bytes from 10.0.0.80: icmp_seq=2 ttl=62 time=4.23 ms
+ 64 bytes from 10.0.0.80: icmp_seq=3 ttl=62 time=3.89 ms
+ 64 bytes from 10.0.0.80: icmp_seq=4 ttl=62 time=3.22 ms
+
+ --- 10.0.0.80 ping statistics ---
+ 4 packets transmitted, 4 received, 0% packet loss, time 9ms
+ rtt min/avg/max/mdev = 3.218/3.661/4.226/0.421 ms
+
+ vyos@VyOS-CE-HUB:~$ ping 10.0.0.90 interface 10.0.0.100 c 4
+ PING 10.0.0.90 (10.0.0.90) from 10.0.0.100 : 56(84) bytes of data.
+ 64 bytes from 10.0.0.90: icmp_seq=1 ttl=62 time=7.46 ms
+ 64 bytes from 10.0.0.90: icmp_seq=2 ttl=62 time=4.43 ms
+ 64 bytes from 10.0.0.90: icmp_seq=3 ttl=62 time=4.60 ms
+ ^C
+ --- 10.0.0.90 ping statistics ---
+ 3 packets transmitted, 3 received, 0% packet loss, time 6ms
+ rtt min/avg/max/mdev = 4.430/5.498/7.463/1.391 ms
+
+ # check network path
+ vyos@VyOS-CE-HUB:~$ traceroute 10.0.0.80
+ traceroute to 10.0.0.80 (10.0.0.80), 30 hops max, 60 byte packets
+ 1 10.80.80.1 (10.80.80.1) 1.563 ms 1.341 ms 1.075 ms
+ 2 * * *
+ 3 10.0.0.80 (10.0.0.80) 8.125 ms 8.019 ms 7.781 ms
+
+ vyos@VyOS-CE-HUB:~$ traceroute 10.0.0.90
+ traceroute to 10.0.0.90 (10.0.0.90), 30 hops max, 60 byte packets
+ 1 10.80.80.1 (10.80.80.1) 1.305 ms 1.137 ms 1.097 ms
+ 2 * * *
+ 3 * * *
+ 4 10.0.0.90 (10.0.0.90) 9.358 ms 9.325 ms 9.292 ms
+
+- VyOS-CE2-SPOKE -------> VyOS-CE-HUB
+
+.. code-block:: none
+
+ # check rib
+ vyos@rt-ce2-SPOKE:~$ show ip route
+ Codes: K - kernel route, C - connected, S - static, R - RIP,
+ O - OSPF, I - IS-IS, B - BGP, E - EIGRP, N - NHRP,
+ T - Table, v - VNC, V - VNC-Direct, A - Babel, D - SHARP,
+ F - PBR, f - OpenFabric,
+ > - selected route, * - FIB route, q - queued, r - rejected, b - backup
+
+ B 10.60.60.0/24 [20/0] via 10.60.60.1 inactive, weight 1, 02w6d00h
+ C>* 10.60.60.0/24 is directly connected, eth0, 02w6d00h
+ B>* 10.80.80.0/24 [20/0] via 10.60.60.1, eth0, weight 1, 6d08h46m
+ C>* 10.0.0.90/32 is directly connected, dum20, 02w6d00h
+ B>* 10.0.0.100/32 [20/0] via 10.60.60.1, eth0, weight 1, 6d08h46m
+
+ # check icmp
+ vyos@rt-ce2-SPOKE:~$ ping 10.0.0.100 interface 10.0.0.90 c 4
+ PING 10.0.0.100 (10.0.0.100) from 10.0.0.90 : 56(84) bytes of data.
+ 64 bytes from 10.0.0.100: icmp_seq=1 ttl=62 time=4.97 ms
+ 64 bytes from 10.0.0.100: icmp_seq=2 ttl=62 time=4.45 ms
+ 64 bytes from 10.0.0.100: icmp_seq=3 ttl=62 time=4.20 ms
+ 64 bytes from 10.0.0.100: icmp_seq=4 ttl=62 time=4.29 ms
+
+ --- 10.0.0.100 ping statistics ---
+ 4 packets transmitted, 4 received, 0% packet loss, time 9ms
+ rtt min/avg/max/mdev = 4.201/4.476/4.971/0.309 ms
+
+ # check network path
+ vyos@rt-ce2-SPOKE:~$ traceroute 10.0.0.100
+ traceroute to 10.0.0.100 (10.0.0.100), 30 hops max, 60 byte packets
+ 1 10.60.60.1 (10.60.60.1) 1.343 ms 1.190 ms 1.152 ms
+ 2 * * *
+ 3 * * *
+ 4 10.0.0.100 (10.0.0.100) 7.504 ms 7.480 ms 7.488 ms
+
+**Note:** At the moment, trace mpls doesn’t show labels/paths. So we’ll see * * * for the transit routers of the mpls backbone.