OpenVPN server installer for Ubuntu, Debian, AlmaLinux, Rocky Linux, CentOS, Fedora, openSUSE, Amazon Linux 2 and Raspberry Pi OS
Go to file
2022-10-11 01:31:40 -05:00
.github/workflows Update tests 2022-10-04 23:50:36 -05:00
docs Update docs 2022-10-11 01:31:40 -05:00
LICENSE.txt Update license 2022-05-20 00:15:57 -05:00
openvpn-install.sh Cleanup 2022-10-09 16:16:34 -05:00
README-zh.md Update docs 2022-10-11 01:31:40 -05:00
README.md Update docs 2022-10-11 01:31:40 -05:00

English | 中文 | Vídeo en Español

OpenVPN Server Auto Setup Script

Build Status  License: MIT

OpenVPN server installer for Ubuntu, Debian, AlmaLinux, Rocky Linux, CentOS, Fedora and Amazon Linux 2.

This script will let you set up your own VPN server in just a few minutes, even if you haven't used OpenVPN before. OpenVPN is an open-source, robust and highly flexible VPN protocol.

See the script in action (terminal recording).

Note: This recording is for demo purposes only. VPN credentials in this recording are NOT valid.

» See also: WireGuard VPN Server Auto Setup Script

Installation

Run the script on your Linux server* and follow the prompts.

First, download the script:

wget -O openvpn.sh https://get.vpnsetup.net/ovpn

Option 1: Auto install OpenVPN using default options.

sudo bash openvpn.sh --auto
List of default options.
Protocol: UDP
Port: UDP/1194
Client name: client
Client DNS: Google Public DNS

For servers with an external firewall (e.g. EC2/GCE), open UDP port 1194 for the VPN.

Option 2: Interactive install using custom options.

sudo bash openvpn.sh
Click here if you are unable to download.

You may also use curl to download:

curl -fL -o openvpn.sh https://get.vpnsetup.net/ovpn

Then follow the instructions above to install.

Alternative setup URLs:

https://github.com/hwdsl2/openvpn-install/raw/master/openvpn-install.sh
https://gitlab.com/hwdsl2/openvpn-install/-/raw/master/openvpn-install.sh

If you are unable to download, open openvpn-install.sh, then click the Raw button on the right. Press Ctrl/Cmd+A to select all, Ctrl/Cmd+C to copy, then paste into your favorite editor.

* A cloud server, virtual private server (VPS) or dedicated server.

Next steps

After setup, you can run the script again to manage users or uninstall OpenVPN.

Get your computer or device to use the VPN. Please refer to:

Configure OpenVPN Clients

Enjoy your very own VPN! 🎉🚀

Like this project? You can show your support or appreciation.

Buy Me a Coffee at ko-fi.com   Coindrop.to me

Supporter-only content is available. Click to see details.

Credits

This script is based on the great work of Nyr and contributors, with enhancements and changes for compatibility with the Setup IPsec VPN project.

List of enhancements over Nyr/openvpn-install.
  • Improved compatibility with Setup IPsec VPN
  • Improved script reliability, user input and output
  • Supports auto install using default options
  • Added support for Amazon Linux 2
  • Supports exporting configuration for an existing VPN client
  • Supports listing existing VPN clients
  • Supports custom DNS server(s) for VPN clients
  • Optimized sysctl settings for improved VPN performance
  • Improved creation of client config files when using sudo

...and more!

License

MIT