Table of Contents
Intro
This guide will walk you through the process of setting up a site-to-site VPN in AWS between two networks.
When configuring a VPN, one end of the connection will be on your on-premises network or another cloud provider, and the other end will be on the AWS cloud. To simulate the AWS and the on-prem sides, we’ll create two VPCs in different regions – us-east-1
and us-east-2
in this case.
We’ll use strongSwan to emulate the customer gateway on the on-premises side. strongSwan is an open-source IPsec-based VPN solution used to establish secure site-to-site connections. Essentially, it ensures that data transmitted between these two points is private and secure.
Visually, the final solution will look like this:
data:image/s3,"s3://crabby-images/6681c/6681cbe978a0eede1a3494879a0649331b64536f" alt=""
Let’s get going!
This project was completed as part of the Udemy course AWS VPC and Networking in depth: Learn practically in 8 hrs.
Setting up VPC-A and its Networking Components
The bullets in this section outline the network setup for the AWS side of the VPN connection. I’ll create the VPC in us-east-1
, but you can use any region you see fit.
1. Create VPC-A
data:image/s3,"s3://crabby-images/83029/830292ca107ff70f3acbccaa56cbc4a4eb322e82" alt=""
VPC Name: VPC-A
CIDR block: 10.100.0.0/16
2. Create an Internet Gateway for VPC-A
The initial setup and establishment of the VPN connection occurs over the public internet so we need an Internet Gateway.
Let’s create one like this:
data:image/s3,"s3://crabby-images/bdd5c/bdd5caeaa3a12778cc3277cd6732c98efefa42a0" alt=""
Internet Gateway Name: VPC-A-IGW
3. Attach IGW to VPC-A
data:image/s3,"s3://crabby-images/a3448/a3448e3f1c17f8bf2a8b86fd1de7800668773ff9" alt=""
4. Create a Public Subnet in VPC-A
data:image/s3,"s3://crabby-images/24f7d/24f7d146b6d452a79a26af93c59ddf4d1fcdb889" alt=""
Name: VPC-A-Public-Subnet
CIDR block: 10.100.0.0/24
5. Set Up Routing for VPC-A
5.1 Create a Route Table
data:image/s3,"s3://crabby-images/52537/5253700c41e80d6b61ecc1c2eb5bfe6b3e7211c5" alt=""
Name: VPC-A-Public-RT
5.2 Add route to the Internet Gateway
data:image/s3,"s3://crabby-images/8935c/8935c5bee12b3f8d7f2305d8b7375d310851778c" alt=""
5.3 Associate the route table with the public subnet
data:image/s3,"s3://crabby-images/64fb3/64fb351c4a14d1a8d5265250d9d6ef4fb4b54ac7" alt=""
Setting up VPC-B and its Networking Components
The process of creating the VPC for simulating the on-prem side of the VPN connection is similar to the previous section, so I’ll just mark the steps again.
1. Switch to another region (I’ll be using us-east-2
)
2. Create VPC-B
VPC Name: VPC-B
CIDR block: 10.200.0.0/16
3. Create and Attach IGW to VPC-B
Internet Gateway Name: IGW-B
4. Define and Setup VPC-B
’s Public Subnet
Name: VPC-B-Public-Subnet
CIDR block: 10.200.0.0/24
5. Set Up Routing for VPC-B
5.1 Create a Route Table
Name: VPC-B-Public-RT
5.2 Add route to the Internet Gateway
5.3 Associate the route table with the public subnet
EC2-A Instance Setup
Let’s create an EC2 instance in VPC-A
. This instance acts as a representative node within VPC-A
to showcase that resources within this VPC can communicate with resources in VPC-B
via the VPN connection.
1. Select AMI and Instance Type
I’ll be using an Ubuntu instance. If you’re following along, you can select any free tier eligible instance type.
data:image/s3,"s3://crabby-images/1eb2f/1eb2f077c780499bcb0ea731d9fdfb7ace42d009" alt=""
Name: EC2-A
2. Creating Key Pair KP-A
data:image/s3,"s3://crabby-images/6881a/6881a56565d5986582898c3c3ac39fce072a15af" alt=""
3. Setting up Security Group SG-A
Here is a sample configuration for the Security Group:
- SSH access from my public IP so I can connect to the instance
- Allow all TCP traffic for the CIDR of the VPC on the other end of the VPN connection – that is
10.200.0.0/16
- Allow ICMP from the other side of the VPN as well – we’ll use that to ping the servers to ensure the VPN connection is working
data:image/s3,"s3://crabby-images/94e22/94e224f621de02ff01785c9c80c363d734f814a5" alt=""
EC2-B Instance Setup
The purpose of the EC2 instance in VPC-B
that we’re about to configure is not only to represent a client machine on the on-prem side of the VPN. With strongSwan installed, this instance acts as the VPN endpoint for VPC-B
. It establishes and maintains the VPN connection to VPC-A
. This enables resources in VPC-B
to securely communicate with resources in VPC-A
through IPsec tunnels.
1. Launch EC2-B
in VPC-B
This process is identical to the setup of EC2-A
. For the security group, make sure to allow TCP and ICMP access from the AWS side of the VPN with CIDR block 10.100.0.0/16
We’ll need to configure a bunch of network settings on the instance, but first, let’s create the VPN connection itself and related components.
Creating the Site-to-Site VPN in AWS
1. Virtual Private Gateway Setup in VPC-A
A Virtual Private Gateway is the VPN endpoint on the AWS side of the Site-to-Site VPN connection.
Go ahead and create a VPG and attach it to VPC-A
:
data:image/s3,"s3://crabby-images/b69ac/b69ac207e65e979b61950b532a7f151eeea0f33e" alt=""
Name: VPC-A-VPC-B-VGW
2. Attach the VPG to VPC-A
data:image/s3,"s3://crabby-images/89cab/89cabadb7400b9727222f0657799a9b4199a9ae1" alt=""
3. Customer Gateway Configuration
A Customer Gateway represents the gateway device on the on-premises network. When you create a customer gateway, you provide information about your device to AWS.
Here are the details for the CG for our setup:
data:image/s3,"s3://crabby-images/689ff/689ff6fcd327b23cc1c64addd76f5e7a11611b92" alt=""
Name: VPC-B-CGW
The IP address here should correspond to the public IP of the EC2 instance in VPC-B
.
4. Creating the site-to-site VPN connection
Now, it’s time to create the VPN connection itself. Go to the VPN section of the VPC dashboard and click “Create VPN connection”:
data:image/s3,"s3://crabby-images/a9f67/a9f6714fe8e9db5b50260fb07853b4f9b614fcdb" alt=""
Populate the required fields:
data:image/s3,"s3://crabby-images/fa3cf/fa3cfefaad219adfbdf5cb61f1c555fa72c441d4" alt=""
Name: VPC-A-VPC-B-VPN-Connection
Make sure to select the Virtual Private Gateway and Customer Gateway we’ve just created. For the Static IP prefixes, you need to specify the CIDR block of VPC-B
(10.200.0.0/16
).
Once done, you’ll see the VPN connection was created with two tunnels for redundancy. For this demo we’ll use only Tunnel 1.
data:image/s3,"s3://crabby-images/96854/96854b11f2533a1186fca9d4bc1abfc7828a8e79" alt=""
5. Download the VPN tunnel configuration
We’ll need that to set up the VPN parameters in EC2-B
. Go ahead and click the “Download configuration” button on the VPN connection:
data:image/s3,"s3://crabby-images/34bdb/34bdba32da4e4cc0f632de64f0f3144dee4de6ab" alt=""
You can select a generic configuration:
data:image/s3,"s3://crabby-images/dab9a/dab9a2032f6b4d82415bc8cb8decf9c5657b011f" alt=""
Now, inspect the downloaded files. You will find connection details for both tunnels.
For each tunnel, there are sections:
– Internet Key Exchange Configuration
– IPSec Configuration
– Tunnel Interface Configuration
– Static Routing Configuration
Here’s how these look in our case:
data:image/s3,"s3://crabby-images/ffdca/ffdca8cf5f079b0e0dcfeef1547667b7529d5641" alt=""
data:image/s3,"s3://crabby-images/9638b/9638b699ba729c589f10af01d55054ab7f87a75b" alt=""
data:image/s3,"s3://crabby-images/c83e3/c83e35f00e9f52e22c14ca94d9dc9ae609a99398" alt=""
data:image/s3,"s3://crabby-images/c67e9/c67e9b91cc6ee35e4b05c4472f2dc947e45053e9" alt=""
In a later section, we’ll see where we need to specify these values when setting up the on-premise side of the VPN.
6. Enabling route propagation
Go to the Route Table VPC-A-Public-RT
:
data:image/s3,"s3://crabby-images/87400/874007eb6e6717cd9bde4fd0bd584ba93a67afbf" alt=""
Then, enable route propagation through the Virtual Private Gateway:
data:image/s3,"s3://crabby-images/f9d20/f9d20457c84aecd89dfc39dde8c761f01ebabc63" alt=""
VPN Configuration on EC2-B
It’s time to configure the VPN connection on the on-premises side, that is, on the EC2 instance in VPC-B
.
1. SSH into EC2-B
2. Install strongSwan
sudo apt update sudo apt install strongswan
3. Configuring EC2-B to function as a router
Update /etc/sysctl.conf
to have the following:
net.ipv4.ip_forward = 1 net.ipv4.conf.all.accept_redirects = 0 net.ipv4.conf.all.send_redirects = 0
data:image/s3,"s3://crabby-images/187d8/187d89255c7e4d12b34a0c0289424d57ba93fa8d" alt=""
Once you’ve updated the file, you can apply the changes with:
sudo sysctl -p
4. Configure an IPsec connection for the VPN tunnel
Open the ipsec.conf
file:
sudo nano /etc/ipsec.confg
You need to add a configuration that looks similar to this one (I will provide details of the main fields below):
conn Tunnel1 authby=secret auto=start left=%defaultroute leftid=3.145.217.88 right=52.7.200.169 type=tunnel ikelifetime=8h keylife=1h esp=aes128-sha1-modp1024 ike=aes128-sha1-modp1024 keyingtries=%forever keyexchange=ike leftsubnet=10.200.0.0/16 rightsubnet=10.100.0.0/16 dpddelay=10 dpdtimeout=30
data:image/s3,"s3://crabby-images/e8c52/e8c5245331337008bc9b4997add9f5d41c094a35" alt=""
Here are the main bits you need to tweak for your use case:
leftid = EC2-B public ID (on-prem end of the VPN)
right = Public IP attached to the Virtual Private Gateway
Left subnet = Customer end of VPN CIDR Right subnet = AWS end of VPN CIDR
Right subnet = AWS end of VPN CIDR
You can get the leftid
and right
values from the VPN config file you downloaded:
data:image/s3,"s3://crabby-images/f6650/f66501ba21090ce99a324e904e86fc44aace921c" alt=""
5. Specify the shared secret in the IPsec secrets file
Open the ipsec.conf
file:
sudo nano /etc/ipsec.secrets
You need to add a line with the following format to the file:
<customer public ip> <aws vpc public ip> : PSK "<shared secret>"
The shared secret can be retrieved from the VPN config file:
data:image/s3,"s3://crabby-images/cc67b/cc67bafdf974c322baadb5627d24ee8837210abe" alt=""
Here is what the config looks like for me after the change:
data:image/s3,"s3://crabby-images/cddcb/cddcbe23a14c9fa663185b9657c064f15dfab2f8" alt=""
6. Reload the IPsec configuration to take effect
sudo ipsec restart
7. Check the IPsec status
sudo ipsec statusall
data:image/s3,"s3://crabby-images/8435d/8435d8de43c17f7b82a0698d6cef04b007bbec41" alt=""
You can see the Tunnel1 connection is successfully established. This means the VPN is up and running but let’s make a few more checks anyway.
Testing the VPN connection
1. Verify the Tunnel is up in the AWS Console:
data:image/s3,"s3://crabby-images/4aa6c/4aa6ced0f8a97e89f8fff638ffc3fa85bba129b1" alt=""
2. Ensure you can ping the machines from both sides of the VPN
For example, let’s ping the EC2-A
machine from EC2-B
on it’s private IP
data:image/s3,"s3://crabby-images/35813/3581313293d344650c82b40ae48f11500bc3389d" alt=""
Summary
By following this comprehensive guide, you should be able to successfully establish a secure communication bridge between your on-premise and AWS networks using strongSwan.
Thanks for reading, and see you next time!