Fork me 🍴

Willian Antunes

OpenVPN Community on Azure with Terraform

• 1 minute read

openvpn, point-to-site-vpn, terraform

Warning: This is a note, so don't expect much 😅!

I've been creating an entire infrastructure from scratch on Azure. All components are private. One convenient way to access the private resources is through the bastion. However, it's costly. Another interesting way to access the environment is through a VPN server using P2S.

I found an excellent project provided by dumrauf where you can quickly create an OpenVPN server using Terraform, focused on AWS, though 😨. I've adapted the code to work on Azure 😛. Here are important notes if you want to use it:

  • The OpenVPN server is installed using Virtual Machine Extension. It uses the script openvpn.sh.
  • The installation script provides the file openvpn-management.sh to manage the OpenVPN server. It's available in the user's home directory.
  • When you access the VPN server, for example, through the serial console, you can generate OVPN files, list what has been generated, and revoke them through the management script. Just execute sudo ./openvpn-management.sh.
  • AKS is provisioned. If you don't need it, remove it before applying the Terraform script.
  • Terraform provisions a hub-spoke network topology. I used it for a test I had been doing. It's another thing that can be removed unless you want to test it.

Check out the whole project on GitHub if you have any further questions.

I hope this may help you. See you 😄!


Have you found any mistakes 👀? Feel free to submit a PR editing this blog entry 😄.