Difference between revisions of "DMVPN with IPsec Phase 3"

From Teltonika Networks Wiki
m
Line 63: Line 63:
 
5. Set IPsec Pre-shared key (we used simple 123456 for this example)
 
5. Set IPsec Pre-shared key (we used simple 123456 for this example)
  
<br>[[File:HUB main.png|alt=|border]]
+
<br>[[File:HUB main.png|border|class=tlt-border]]
 
----
 
----
 
<b>Step 2</b>: configure '''DMVPN Phase 1''' parameters:
 
<b>Step 2</b>: configure '''DMVPN Phase 1''' parameters:
Line 73: Line 73:
 
3. DH group - MODP3072
 
3. DH group - MODP3072
  
<br>[[File:Hub phase1.png|alt=|border]]
+
<br>[[File:Hub phase1.png|border|class=tlt-border]]
 
----
 
----
 
<b>Step 3</b>: configure '''DMVPN Phase 2''' parameters:
 
<b>Step 3</b>: configure '''DMVPN Phase 2''' parameters:
Line 83: Line 83:
 
3. PFS group -MODP3072
 
3. PFS group -MODP3072
  
<br>[[File:Hub phase2 fix.png|alt=|border]]
+
<br>[[File:Hub phase2 fix.png|border|class=tlt-border]]
 
----
 
----
 
<b>Step 4</b>: configure '''DMVPN NHRP''' parameters:
 
<b>Step 4</b>: configure '''DMVPN NHRP''' parameters:
Line 89: Line 89:
 
In the NHRP parameters section, it is important to enable '''REDIRECT''' option, which is essential to our Phase 3 configuration.
 
In the NHRP parameters section, it is important to enable '''REDIRECT''' option, which is essential to our Phase 3 configuration.
  
<br>[[File:Redirect.png|alt=|border]]
+
<br>[[File:Redirect.png|border|class=tlt-border]]
 
----
 
----
 
<b>Step 5</b>: save changes
 
<b>Step 5</b>: save changes
Line 109: Line 109:
 
5. "NHRP routes" selection should be applied under the "Redistribution options" section
 
5. "NHRP routes" selection should be applied under the "Redistribution options" section
  
<br>[[File:Hub bgp.png|alt=|border]]
+
<br>[[File:Hub bgp.png|border|class=tlt-border]]
 
----
 
----
  
Line 119: Line 119:
 
- Leave other settings as default.
 
- Leave other settings as default.
  
<br>[[File:Bgp peer grp.png|alt=|border]]
+
<br>[[File:Bgp peer grp.png|border|class=tlt-border]]
 
----
 
----
  
Line 141: Line 141:
 
We will keep other settings as their default values for this configuration example.
 
We will keep other settings as their default values for this configuration example.
  
<br>[[File:Bgp peer1.png|alt=|border]]
+
<br>[[File:Bgp peer1.png|border|class=tlt-border]]
 
----
 
----
[[File:Bgp peer2.png|alt=|border]]
+
[[File:Bgp peer2.png|border|class=tlt-border]]
 
----
 
----
  
Line 167: Line 167:
 
6.  Set Local identifier (For setups behind NAT), Remote identifier as %any and input the same Pre-shared key (This will determine how other devices will be identified for authentication)
 
6.  Set Local identifier (For setups behind NAT), Remote identifier as %any and input the same Pre-shared key (This will determine how other devices will be identified for authentication)
  
<br>[[File:Spoke dmvpn.png|alt=|border]]
+
<br>[[File:Spoke dmvpn.png|border|class=tlt-border]]
 
----
 
----
  
Line 179: Line 179:
 
3.  Select DH group MODP3072
 
3.  Select DH group MODP3072
  
<br>[[File:Hub phase1.png|alt=spoke phase1|border]]
+
<br>[[File:Hub phase1.png|border|class=tlt-border]]
 
----
 
----
  
Line 191: Line 191:
 
3.  Select PFS group MODP3072
 
3.  Select PFS group MODP3072
  
<br>[[File:Hub phase2 fix.png|alt=spoke phase2|border]]
+
<br>[[File:Hub phase2 fix.png|border|class=tlt-border]]
 
----
 
----
  
Line 201: Line 201:
 
- Leave everything by default
 
- Leave everything by default
  
<br>[[File:Redirect.png|alt=Redirect|border]]
+
<br>[[File:Redirect.png|border|class=tlt-border]]
 
----
 
----
 
<b>Step 5</b>: save changes
 
<b>Step 5</b>: save changes
Line 217: Line 217:
 
3. Set Network to 192.168.10.0/24
 
3. Set Network to 192.168.10.0/24
  
<br>[[File:Spoke bgp.png|alt=|border]]
+
<br>[[File:Spoke bgp.png|border|class=tlt-border]]
 
----
 
----
  
Line 229: Line 229:
 
- Leave everything else as default value
 
- Leave everything else as default value
  
<br>[[File:Spoke bgp peer.png|alt=|border]]
+
<br>[[File:Spoke bgp peer.png|border|class=tlt-border]]
  
 
===Spoke 2 configuration: DMVPN===
 
===Spoke 2 configuration: DMVPN===
Line 249: Line 249:
 
6. Set Local identifier (For setups behind NAT), Remote identifier as %any and input the same Pre-shared key (This will determine how other devices will be identified for authentication)
 
6. Set Local identifier (For setups behind NAT), Remote identifier as %any and input the same Pre-shared key (This will determine how other devices will be identified for authentication)
  
<br>[[File:Spoke2 dmvpn.png|alt=|border]]
+
<br>[[File:Spoke2 dmvpn.png|border|class=tlt-border]]
 
----
 
----
  
Line 261: Line 261:
 
3. Select DH group MODP3072
 
3. Select DH group MODP3072
  
<br>[[File:Hub phase1.png|alt=spoke phase1|border]]
+
<br>[[File:Hub phase1.png|border|class=tlt-border]]
 
----
 
----
 
<b>Step 3</b>: configure '''DMVPN Phase 2''' parameters:
 
<b>Step 3</b>: configure '''DMVPN Phase 2''' parameters:
Line 271: Line 271:
 
3. Select PFS group MODP3072
 
3. Select PFS group MODP3072
  
<br>[[File:Hub phase2 fix.png|alt=spoke phase2|border]]
+
<br>[[File:Hub phase2 fix.png|border|class=tlt-border]]
 
----
 
----
  
Line 281: Line 281:
 
- Leave everything by default
 
- Leave everything by default
  
<br>[[File:Redirect.png|alt=Redirect|border]]
+
<br>[[File:Redirect.png|border|class=tlt-border]]
 
----
 
----
 
<b>Step 5</b>: save changes
 
<b>Step 5</b>: save changes
Line 297: Line 297:
 
3.  Set Network to 192.168.20.0/24
 
3.  Set Network to 192.168.20.0/24
  
<br>[[File:Spoke2 bgp peer.png|alt=|border]]
+
<br>[[File:Spoke2 bgp peer.png|border|class=tlt-border]]
 
----
 
----
  
Line 309: Line 309:
 
- Leave everything else as default value
 
- Leave everything else as default value
  
<br>[[File:Spoke bgp peer.png|alt=Spoke bgp peer|border]]
+
<br>[[File:Spoke bgp peer.png|border|class=tlt-border]]
  
 
----
 
----
Line 318: Line 318:
 
For '''HUB''' in Network -> Firewall GRE zone change from '''REJECT''' to '''ACCEPT''' on '''FORWARD.'''
 
For '''HUB''' in Network -> Firewall GRE zone change from '''REJECT''' to '''ACCEPT''' on '''FORWARD.'''
  
[[File:Firewall.png|alt=|border]]
+
[[File:Firewall.png|border|class=tlt-border]]
  
 
===Testing configuration===
 
===Testing configuration===

Revision as of 16:38, 26 January 2023

Main Page > General Information > Configuration Examples > VPN > DMVPN with IPsec Phase 3

The information in this page is updated in accordance with 00.07.03.2 firmware version. .

Introduction

DMVPN (Dynamic Multipoint Virtual Private Network) is a dynamic tunneling form of a virtual private network capable of creating a VPN network without having pre-configure all possible tunnel end-point peers. DMVPN is initially configured to build out a HUB and SPOKE network, where each new SPOKE can join the network with minimal effort. The main benefits of DMVPN would be that it simplifies router configuration, has high scalability, good performance with better bandwidth, and secure routing when used in combination with IPsec.


DMVPN has three phases that route data differently:

Phase 1: All traffic goes from the spoke to and through the hub.

Phase 2: Starts with Phase 1 and after it allows spoke-to-spoke tunnels. Phase 2 has different routing, where packet forwarding is being done using the IP routing table. Spokes reach other spokes networks based on the next-hop tunnel IP address of the other spoke for a particular network.

Phase 3: Improves the scalability and has fewer restrictions than Phase 2. Phase 3 allows the summarization of routes from hub to spokes. Spokes don’t even need routes, they can use the default gateway toward the hub router.


This article contains instructions on how to configure DMVPN Phase 3 between a "Hub" and two "Spokes" using Teltonika devices.

Prerequisites and overview

You will need:

  • 2 Teltonika Routers for SPOKES
  • 1 Teltonika Router for HUB with a public IP address
  • A PC to configure the routers

Configuration scheme

DMVPN phase3 topology.png


The SETUP

The following section contains information on how to configure DMVPN HUB. Firstly, we'll configure the DMVPN instance to make the connection possible. Then we'll set the Border Gateway Protocol (BGP) parameters as our dynamic routing solution.

Notes:

- At the moment, BGP is the only stable dynamic routing solution that can work with DMVPN.

- If you are using non RUTX device, BGP and DMVPN have to be installed manually from the Services → Package Manager tab before continuing.

- If you're having trouble finding any page or some of the parameters described here on your device's WebUI, you should turn on "Advanced WebUI" mode. You can do that by clicking the "Basic" button under "Mode," which is located at the top-right corner of the WebUI.

HUB configuration: DMVPN


Navigate to the Services → VPN → DMVPN page and follow the instructions provided below.

Step 1: create a new DMVPN instance:

1. Select your HUB interface in the Tunnel source field

2. Set Local GRE interface IP address (for example, 10.0.0.254)

3. Set GRE interface netmask to 255.255.255.255

4. Set GRE MTU value to 1420 (or even slightly lower - 1400 if a mobile interface is used)

- Outbound/inbound keys are optional, for this example we will leave it at default

5. Set IPsec Pre-shared key (we used simple 123456 for this example)


HUB main.png


Step 2: configure DMVPN Phase 1 parameters:

1. Encryption algorithm - AES 128

2. Authentication SHA256

3. DH group - MODP3072


Hub phase1.png


Step 3: configure DMVPN Phase 2 parameters:

1. Encryption algorithm - AES 128

2. Hash algorithm - SHA256

3. PFS group -MODP3072


Hub phase2 fix.png


Step 4: configure DMVPN NHRP parameters:

In the NHRP parameters section, it is important to enable REDIRECT option, which is essential to our Phase 3 configuration.


Redirect.png


Step 5: save changes

Hub configuration: BGP

Navigate to the Network → Routing → Dynamic Routes → BGP Protocol page and follow the instructions provided below.

Step 1: enable BGP and configure General section:

1. Enable vty

2. Set AS to 65000

3. Set BGP router ID for easier management.

4. Set announcement network(s). Routes to these networks will be shared over BGP. We used 192.168.1.0/24

5. "NHRP routes" selection should be applied under the "Redistribution options" section


Hub bgp.png



Step 2: Create BGP Peer Group:

- Add a Neighbor address for SPOKE 1 and SPOKE 2 (We used 10.0.0.1 and 10.0.0.2 which will be in the same subnet as our hub 10.0.0.254)

- Leave other settings as default.


Bgp peer grp.png



Step 3: Add two BGP peers for each spoke:

Now let's create BGP peers for Spokes on the same page. Add two new BGP peers with the following parameters:

Peer 1.

- Set Remote AS to 65001

- Set Remote address as 10.0.0.1

Peer 2.

- Set Remote AS to 65002

- Set Remote address as 10.0.0.2

We will keep other settings as their default values for this configuration example.


Bgp peer1.png


Bgp peer2.png



Spoke 1 configuration: DMVPN



Navigate to the Services → VPN → DMVPN page and follow the instructions provided below.

Step 1: create a new DMVPN instance:

1. Add HUB address (this is the public IP address of the previously configured hub device)

2. Select Tunnel source (this is the egress interface, which will be able to reach the hub device's public IP address over the internet)

3. Add Local GRE interface IP address (this is the GRE IP address of "Spoke 1". It should be unique in the entire VPN network)

4. Add Remote GRE interface IP address (this is the GRE IP address of the previously configured hub device)

5. Set GRE MTU to 1420 (this value should be set to the same value that was configured on the hub device. In our case, it is "1420")

6. Set Local identifier (For setups behind NAT), Remote identifier as %any and input the same Pre-shared key (This will determine how other devices will be identified for authentication)


Spoke dmvpn.png



Step 2: configure DMVPN Phase 1 parameters:

1. Select the Encryption algorithm - AES 128

2. Select Authentication SHA256

3. Select DH group MODP3072


Hub phase1.png



Step 3: configure DMVPN Phase 2 parameters:

1. Select the Encryption algorithm AES 128

2. Select Hash algorithm SHA256

3. Select PFS group MODP3072


Hub phase2 fix.png



Step 4: configure DMVPN NHRP parameters:

- In the NHRP parameters section, it is important to enable REDIRECT option, which is essential to our Phase 3 configuration.

- Leave everything by default


Redirect.png


Step 5: save changes

Spoke 1 configuration: BGP

Navigate to the Network → Routing → Dynamic Routes → BGP Protocol page and follow the instructions provided below.

Step 1: enable BGP and configure General section:

1. Enable vty

2. Set AS to 65001

3. Set Network to 192.168.10.0/24


Spoke bgp.png



Step 2: Create BGP Peer:

- Set Remote AS to 65000

- Set the Remote address to 10.0.0.254

- Leave everything else as default value


Spoke bgp peer.png

Spoke 2 configuration: DMVPN

Navigate to the Services → VPN → DMVPN page and follow the instructions provided below.

Step 1: create a new DMVPN instance:

1. Add HUB address (this is the public IP address of the previously configured hub device)

2. Select Tunnel source (this is the egress interface, which will be able to reach the hub device's public IP address over the internet)

3. Add Local GRE interface IP address (this is the GRE IP address of "Spoke 2". It should be unique in the entire VPN network)

4. Add Remote GRE interface IP address (this is the GRE IP address of the previously configured hub device)

5. Set GRE MTU to 1420 (this value should be set to the same value that was configured on the hub device. In our case, it is "1420")

6. Set Local identifier (For setups behind NAT), Remote identifier as %any and input the same Pre-shared key (This will determine how other devices will be identified for authentication)


Spoke2 dmvpn.png



Step 2: configure DMVPN Phase 1 parameters:

1. Select Encryption algorithm - AES 128

2. Select Authentication SHA256

3. Select DH group MODP3072


Hub phase1.png


Step 3: configure DMVPN Phase 2 parameters:

1. Select Encryption algorithm AES 128

2. Select Hash algorithm SHA256

3. Select PFS group MODP3072


Hub phase2 fix.png



Step 4: configure DMVPN NHRP parameters:

- In the NHRP parameters section, it is important to enable REDIRECT option, which is essential to our Phase 3 configuration.

- Leave everything by default


Redirect.png


Step 5: save changes

Spoke 2 configuration: BGP

Navigate to the Network → Routing → Dynamic Routes → BGP Protocol page and follow the instructions provided below.

Step 1: enable BGP and configure General section:

1. Enable vty

2. Set AS to 65002

3. Set Network to 192.168.20.0/24


Spoke2 bgp peer.png



Step 2: Create BGP Peer:

- Set Remote AS to 65000

- Set Remote address to 10.0.0.254

- Leave everything else as default value


Spoke bgp peer.png


Important Note

For HUB in Network -> Firewall GRE zone change from REJECT to ACCEPT on FORWARD.

Firewall.png

Testing configuration

- ipsec statusall command can be used in the CLI/SSH for testing the tunnel. It will return detailed status information either on connection or if the argument is lacking, on all connections. If everything was done correctly, it should display that tunnel has been established.

- ping command can be used to check if the HUB and SPOKES can reach each other.

- Check routes in the HUB by executing command vtysh -c "show ip nhrp"

- If you need to reboot tunnel, execute /etc/init.d/ipsec retart

Summary

References

VPN configuration Examples

DMVPN configuration example

IPsec configuration example

BGP routing

strongSwan Documentation