In this guide, we’ll walk you through the process of configuring a VPN Site-to-Site from your home network to AWS, enabling seamless and secure communication between the two environments.
data:image/s3,"s3://crabby-images/f139d/f139d1edf8e3675267c1f3ac13beb2dec4460155" alt="VPN Site-to-Site from Home Network to AWS"
Table of Contents
Understanding VPN Site-to-Site
Before diving into the setup process, let’s briefly understand what a VPN Site-to-Site connection entails.
A VPN Site-to-Site connection establishes a secure, encrypted tunnel between two networks, allowing them to communicate as if they were directly connected. In our case, we’ll be connecting our home network to an AWS Virtual Private Cloud (VPC), effectively extending our network infrastructure to the cloud.
Prerequisites
Before proceeding, ensure you have the following prerequisites in place:
- An AWS account with appropriate permissions to create VPC resources.
- public IP (find public IP of home network at link )
Configure AWS
- Create VPC with a private subnet
- Create a EC2 and config inboud for SG
- Creating a virtual private gateway
- Setting route table
- Site to Site VPN settings and download vendor config file
Create a new VPC with a CIDR block that does not conflict with your home network.
IPv4 CIDR: 10.0.0.0/16
Subnet private :subnet-09ea90bc4428089cc / subnet-private-1a, 10.0.32.0/20
data:image/s3,"s3://crabby-images/3806b/3806be35da075f140016341dfcfae7f77d89db81" alt="image 1"
Create a new EC2 in subnet-private-1 for test if you have not
Private IP : 10.0.44.45
data:image/s3,"s3://crabby-images/a3220/a3220ad611c3358a28617ddc7e92249c6cb1af59" alt="image 24"
EC2 sercurity group inboud setting(allow ping test only)
data:image/s3,"s3://crabby-images/8856b/8856bb09cb539251a8cdc9051737495adc02b083" alt="image 26"
Creating a virtual private gateway
data:image/s3,"s3://crabby-images/bcfc1/bcfc15cc7eea837cc64965a245182a69f01fc387" alt="image 2"
Attach to the VPC that will be the Site to Site VPN connection destination.
data:image/s3,"s3://crabby-images/262f1/262f1b21c0061002790cab32494e156c1181b327" alt="image 3"
Edit route table
In the route table of the private subnet connection destination VPN, configure routing for the local network segment with the virtual private gateway as the destination.
data:image/s3,"s3://crabby-images/f206f/f206fc01307844389ae5b254cfb5a18478b2b5d2" alt="image 4"
Site to Site VPN settings
IP address : Your public IP adress
Static IP prefixes : Local network segment(192.168.0.0/16)
data:image/s3,"s3://crabby-images/f4174/f4174ff63ed5a6db58d61ec869e205d2461acaec" alt="VPN Site-to-Site"
data:image/s3,"s3://crabby-images/79172/79172222bf1b99eae149c3800e51daae7bab23de" alt="image 7"
data:image/s3,"s3://crabby-images/b038c/b038c2d37bb1a870832f72661b9cda370616b803" alt="image 10"
VPN config download
Chose Vendor is Strongwan and IKE version is ikev2
data:image/s3,"s3://crabby-images/c1b93/c1b93cf74074e022dde3bbe4c18e6e5ac3e5fdcc" alt="image 11"
Configure the following settings according to the downloaded file.
Configure Local network
- Stop firewall
- Kernel parameter setting
- strongswan installation
- strongswan settings
- strongswan start
- Verify Connectivity
My Ubuntu server IP : 192.168.0.120
VPN server setting
Stop firewall
data:image/s3,"s3://crabby-images/f9c22/f9c226ee8daec4c5d3d339f0d403a13d3d302819" alt="image 12"
Kernel parameter setting
sudo vi /etc/sysctl.conf
net.ipv4.ip_forward = 1
net.ipv6.conf.all.forwarding = 1
net.ipv4.conf.all.accept_redirects = 0
net.ipv4.conf.all.send_redirects = 0
data:image/s3,"s3://crabby-images/2d88e/2d88eefa07b353c86e3206b02401a30abaeb2163" alt="image 13"
sudo sysctl -p
data:image/s3,"s3://crabby-images/9a823/9a823ff01a030b926ea23e5c5f0f8c15eb3f65fb" alt="image 14"
strongswan installation
Install with the following command.
sudo apt update
sudo apt install -y strongswan
strongswan settings (/etc/ipsec.conf)
Create a new file at /etc/ipsec.conf if doesn’t already exist, and then open it. Add the following under the ‘config setup’ section:
sudo vi /etc/ipsec.conf
charondebug="all"
uniqueids=yes
strictcrlpolicy=no
data:image/s3,"s3://crabby-images/efce8/efce8fea86849ae3316d86c6bc70b25ba162d567" alt="image 15"
Append the following configuration to the end of the file:
conn Tunnel1
type=tunnel
auto=start
keyexchange=ikev2
authby=psk
leftid=<Global IP address of connection source>
leftsubnet= <On-premises CIDR Range>
right=<Connection destination global IP address/Tunnel 1>
rightsubnet= <VPC CIDR range>
aggressive=no
ikelifetime=28800s
lifetime=3600s
margintime=270s
rekey=yes
rekeyfuzz=100%
fragmentation=yes
replay_window=1024
dpddelay=30s
dpdtimeout=120s
dpdaction=restart
ike=aes128-sha1-modp1024
esp=aes128-sha1-modp1024
keyingtries=%forever
conn Tunnel2
type=tunnel
auto=start
keyexchange=ikev2
authby=psk
leftid=<Global IP address of connection source>
leftsubnet= <On-premises CIDR Range>
right=<Connection destination global IP address/Tunnel 2>
rightsubnet= <VPC CIDR range>
aggressive=no
ikelifetime=28800s
lifetime=3600s
margintime=270s
rekey=yes
rekeyfuzz=100%
fragmentation=yes
replay_window=1024
dpddelay=30s
dpdtimeout=120s
dpdaction=restart
ike=aes128-sha1-modp1024
esp=aes128-sha1-modp1024
keyingtries=%forever
data:image/s3,"s3://crabby-images/3f1da/3f1da50577fcba2cf8157c75c819c9f2a7b915a0" alt="image 21"
strongswan setting(/etc/ipsec.secrets)
Create a new file at /etc/ipsec.secrets if it doesn’t already exist, and append this line to the file. This value authenticates the tunnel endpoints:
sudo vi /etc/ipsec.secrets
data:image/s3,"s3://crabby-images/3aa5b/3aa5bf9cbd9ab32fd7dd4e2ed12c08faebe0ba3b" alt="image 18"
strongswan start
sudo ipsec restart
sudo ipsec status
data:image/s3,"s3://crabby-images/5f8c1/5f8c174bcaebf35bef15da642a9630de12e2d68d" alt="image 22"
data:image/s3,"s3://crabby-images/c57e6/c57e66fad0b5c7814f8e22a56891d80146cb53ed" alt="image 23"
Verify Connectivity
ping IP of private EC2 from local Ubuntu server
ping 10.0.44.45
data:image/s3,"s3://crabby-images/4de9f/4de9fddfe9cc0594a50ec50475f5334575b554ff" alt="image 25"
To test connect from EC2 private instance to local ubuntu server, you can install SSM-agent for EC2
data:image/s3,"s3://crabby-images/8de91/8de91ad9e8f613ce14a212878d2fa388a5aacf2a" alt="image 27"
Conclusion
By following these steps, you’ve successfully set up a VPN Site-to-Site connection from your home network to AWS, enabling secure communication between the two environments. This setup enhances security by encrypting traffic over the internet and facilitates seamless access to cloud resources from the comfort of your home network. Experiment with different configurations and explore additional AWS networking features to optimize performance and security based on your specific requirements.
Thank you for reading the DevopsRoles page!