Domovská stránka Proton VPN
ProtonVPN

How to manually configure OpenVPN for Proton VPN in Linux

Reading
6 mins
Category
Linux

OpenVPN is a battle-tested, open-source VPN protocol used by our Linux VPN app and Linux CLI. 

It’s also possible to manually configure OpenVPN on Linux using third-party clients. In this guide, we’ll show you how to configure OpenVPN on any Linux distribution using the command line or NetworkManager (for those who prefer a GUI).

In addition to OpenVPN, you can manually configure WireGuard on Linux. 

An advantage of manually configuring OpenVPN or WireGuard on Linux is that our OpenVPN and WireGuard configuration files support port forwarding. However, our all-new Linux app supports port forwarding and also includes a kill switch

Preparing for OpenVPN

Before we start, you’ll need two things:

1. An OpenVPN configuration file

Sign in to account.protonvpn.com, go to DownloadsOpenVPN configuration files, and download an OpenVPN configuration file for Linux.

Learn how to download an OpenVPN configuration file from Proton VPN

2. Your OpenVPN username and password

While still signed in to account.protonvpn.com, go to AccountOpenVPN / IKEv2 username to view your OpenVPN username and password. Note that these are not your regular Proton Account username and password.

Learn how to access your Proton VPN OpenVPN username and password

How to use OpenVPN with NetworkManager

This is the recommended way to manually configure OpenVPN if your distribution supports NetworkManager(new window).

This guide was created using Ubuntu 22.04, but the instructions are very similar on any system that supports NetworkManager. If your desktop environment uses NetworkManager, there’s a good chance that it already supports OpenVPN. If it doesn’t, you can easily install OpenVPN support in NetworkManager:

On Debian and Ubuntu-based distributions, enter:

sudo apt-get install network-manager-openvpn-gnome

On Fedora, enter:

sudo dnf -y install NetworkManager-openvpn NetworkManager-openvpn-gnome 

On Arch, enter:

sudo pacman -S networkmanager-openvpn

Log out of your Linux session, then log in again for the changes to take effect. 

Once NetworkManager supports OpenVPN, you can configure it. To do this:

1. Go to SettingsNetworkVPN+.

Open NetworkManager

2. Select Import from file… and use your default file manager to Open the OpenVPN configuration file you downloaded earlier

Import from file...

3. Go to Authentication and enter your OpenVPN Username and Password into the relevant fields. Click Add when you’re done 

Enter your OpenVPN Username and Password

4. Back at SettingsNetworkVPN, toggle the switch next to the OpenVPN connection you just set up to on. You can configure as many connections as you like. 

Toggle the VPN connection on

You’re now connected to Proton VPN. To verify this, visit ip.me(new window). Since this is a manual connection, you should also check DNS leaks.

To disconnect from Proton VPN, simply toggle the switch off

How to manually configure OpenVPN CLI

This method is more complicated than using NetworkManager, and is only recommended for very specific use cases. Note also that newer distributions (including the latest version of Ubuntu) don’t support openresolv, and so the following method won’t work with them. We’ll update this guide soon, but in the meantime, the NetworkManager method described above will work on most distros.

OpenVPN and the other packages discussed here should be available for almost all Linux distributions. In this guide, we’ll show you how to set up OpenVPN on Debian and Ubuntu-based systems, Fedora, and Arch (including Manjaro). 

1. Install OpenVPN

Open a terminal window and:

On Debian and Ubuntu-based distributions, enter:

sudo apt install openvpn 

On Fedora, enter:

sudo dnf install openvpn

On Arch, enter:

sudo pacman -S openvpn
Install OpenVPN

2. Install openresolv 

You need openresolv (an open-source implementation of resolvconf(new window)) to properly configure DNS and prevent DNS leaks.

Learn more about DNS and DNS leaks

On Debian and Ubuntu-based distributions, enter:

sudo apt install openresolv

On Fedora, enter:

sudo dnf install openresolv

On Arch, enter:

sudo pacman -S openresolv

Install openresolv

3. Download the following DNS update script

Again, this is needed to ensure that DNS is configured correctly. Wget is pre-installed on most Linux distros. Run:

sudo wget "https://raw.githubusercontent.com/ProtonVPN/scripts/master/update-resolv-conf.sh" -O "/etc/openvpn/update-resolv-conf"

Followed by:

sudo chmod +x "/etc/openvpn/update-resolv-conf"
Download our DNS update script

4. Change the directory to where you downloaded your OpenVPN configuration file

Enter 

cd <path>

For example:

cd ~/Downloads

5. Connect to a VPN server using OpenVPN

Run:

sudo openvpn <config.ovpn>

Where <config.ovpn> is the name of the OpenVPN configuration file you downloaded earlier

For example:

sudo openvpn node-ch-02.protonvpn.net.udp.ovpn

Enter your OpenVPN username and password when prompted.

Run OpenVPN

You should see a message saying Initialization Sequence Completed. This means you’re successfully connected to Proton VPN. You can verify this by visiting ip.me(new window). Since this is a manual connection, you should also check for DNS leaks.

Visit ip.me

To disconnect from the VPN server, simply close the terminal window. 

How to check for DNS leaks

After visiting ip.me, go to www.dnsleaktest.com(new window) and run the Standard test.

When the test is complete, look at the first three sets of numbers of the returned IP addresses. These should all match the first three sets of numbers of your IP address, as shown on ip.me. 

If they don’t, then you have a DNS leak. 

Didn’t find what you were looking for?

General contactcontact@proton.me
Media contactmedia@proton.me
Legal contactlegal@proton.me
Partnerships contactpartners@proton.me