Last time I’ve worked with configuring two sites using OpenSwan was more than 10 years ago. Had a good success deploying that solution with good throughput using commodity hardware and leveraging Open Source solutions. This time I wanted to test if I could do the same using Raspberry Pi.
In this post I want to show how I was able to configure Google Compute Engine VPN and connect my home network.
Under Networking – click VPN. Click Create VPN connection. This will open up a page which will guide you on creating a VPN connection.
Under the Create a VPN connection form, we must first create a static IP Address that can be used by our VPN Gateway. Under the IP Address dropdown list box, select Create IP Address.
Put in a name to distinguish this IP Address and click RESERVE.
Complete the form by giving it a Name and selecting a Region where we could deploy this VPN Gateway. Here I am using us-central-1.
Put in your VPN Gateway IP Address in the Remote peer IP address. This is the IP Address of your home network VPN Gateway. I am currently using a Raspberry Pi installed with OpenSwan. I am using port forwarding (udp 500/4500) since this gateway is behind my router. (Installation and configuration of OpenSwan/IPSec on Raspberry Pi deserves a separate post)
Select the IKE version. Mine is using IKEv1.
In the Remote network IP ranges, enter your home network range. Select the Local subnetworks (Google Cloud side) which you want to associate this tunnel to.
Click Create. Deploying this could take a minute or two to complete.
Once done, you should be able to see that the Remote peer IP address is up with a green check icon.
In one of my compute instance, I can verify that the tunnel is up by pinging my home network.
Or by running TCP dump on my local VPN gateway
We now have a secure way of connecting our on-premise network to our Virtual Private Cloud network.
One thing to note, if you are deleting the VPN Connection, you must also release the IP Address you allocated to the VPN Gateway so as not to incur additional cost since that is a Static IP Address.