Installing OpenVPN
Go to OpenVPN official website here to download last installer.
data:image/s3,"s3://crabby-images/3186b/3186bf747ca559e940890868e592e897aeea2a9b" alt="OpenVPN Download Webpage"
- As we want to install OpenVPN as server we will choose Customize :
data:image/s3,"s3://crabby-images/43573/4357353f7fd4ef204be917e4f551c30dda65ea04" alt="OpenVPN Windows Installer"
- We enable OpenVPN Service in order to make it work at boot :
data:image/s3,"s3://crabby-images/372ee/372eeefe152e1d4f3a782d2599cebbec5d80e37e" alt="OpenVPN Windows Installer"
- And we install EasyRsa in order to be able to create server and clients certificates :
data:image/s3,"s3://crabby-images/6d8d9/6d8d924284ba64c3806602be402595bbb303e54e" alt="OpenVPN Windows Installer"
- Once done click Close :
data:image/s3,"s3://crabby-images/be7e4/be7e489a83feb8819893b7a5d60c17b213008061" alt="OpenVPN Windows Installer"
Setting up Certificate Authority (CA) and generating certificates and keys for server and clients
Here we will set up a pki to be able to create our server and clients certificates.
- Open a Command Prompt as administrator :
data:image/s3,"s3://crabby-images/20e51/20e5131310967fef5b1a52582a87f18929a66020" alt="Windows command run as administrator"
- And type the following commands to enter inside EasyRSA shell :
C:\Windows\system32>cd C:\Program Files\OpenVPN\easy-rsa
C:\Program Files\OpenVPN\easy-rsa>EasyRSA-Start.bat
- Remove existing configuration, just for good measure :
# ./easyrsa clean-all
- Initialize pki, and type yes to confirm :
# ./easyrsa init-pki
data:image/s3,"s3://crabby-images/295bf/295bf909d44b5c645aafcecbb60684771265a2ab" alt="OpenVPN on Windows Easy RSA Shell init-pki"
- Build certificate authority :
# ./easyrsa build-ca nopass
[…]
Common Name (eg: your user, host, or server name) [Easy-RSA CA]:ovpn
- Build server certificate and key :
# ./easyrsa build-server-full server nopass
- Generate Diffie Hellman parameters :
# ./easyrsa gen-dh
- Generating client certificates :
# ./easyrsa build-client-full client01 nopass
Certificates
- Put this files (from C:\Program Files\OpenVPN\easy-rsa\pki, C:\Program Files\OpenVPN\easy-rsa\pki\issued and C:\Program Files\OpenVPN\easy-rsa\pki\private) :
- ca.crt
- dh.pem
- server.crt
- server.key
- To C:\Program Files\OpenVPN\config-auto and C:\Program Files\OpenVPN\config folders.
data:image/s3,"s3://crabby-images/55e09/55e095ce2b5eb98b203d37cc1994150beaeb1894" alt="OpenVPN on Windows config-auto folder"
Add a Windows Firewall Rule
We need to open 1194 udp port to allow OpenVPN clients connections. Use the Windows Firewall Management Console or this command inside a Administrator command line console to do that.
C:\Windows\system32>netsh advfirewall firewall add rule name="OpenVPN" dir=in localport=1194 remoteport=0-65535 protocol=UDP action=allow remoteip=any localip=any
C:\Program Files\OpenVPN\config-auto\server.ovpn
As administrator, edit C:\Program Files\OpenVPN\config-auto\server.ovpn file :
port 1194 proto udp dev tun ca ca.crt cert server.crt key server.key dh dh.pem server 10.50.8.0 255.255.255.0 ifconfig-pool-persist ipp.txt keepalive 10 120 comp-lzo persist-key persist-tun status openvpn-status.log verb 3
Then, restart the OpenVPN service :
- From, services management console :
data:image/s3,"s3://crabby-images/a8ae3/a8ae3f84c356580ea36ccf35edc54e6a51188ff5" alt="Windows Run, services.msc"
- Right click OpenVPNService then Restart :
data:image/s3,"s3://crabby-images/d9e45/d9e4502204c9d4be8a4d9324b39bb1f96c386157" alt="Windows services management console, restart openvpnservice."
- Or from an administrator Command Prompt :
C:\Windows\system32>net stop openvpnservice
C:\Windows\system32>net start openvpnservice
Client configuration
- OpenVPN Client :
- OS : Windows 10
- Role : OpenVPN Client
Installing OpenVPN
We will download the same package, and here install with default parameters.
Copy certificates from the Server
- From the Server get the following files (from C:\Program Files\OpenVPN\easy-rsa\pki, C:\Program Files\OpenVPN\easy-rsa\pki\issued and C:\Program Files\OpenVPN\easy-rsa\pki\private) :
- ca.crt
- client01.crt
- client01.key
- And paste them to C:\Program Files\OpenVPN\config.
data:image/s3,"s3://crabby-images/5f5fb/5f5fbda234f5ab8253549c54f3cc9970bb631aa2" alt="Client files Windows 10, OpenVPN certificates."
- C:\Program Files\OpenVPN\config\client.ovpn
Edit the client.ovpn file with administrator rights :
client
dev tun
proto udp
remote OPENVPN_IP 1194
resolv-retry infinite
nobind
persist-key
persist-tun
ca ca.crt
cert client01.crt
key client01.key
comp-lzo
verb 3
Establishing the connection
- Run as administrator
data:image/s3,"s3://crabby-images/08505/085050815e9e7c2cdfa89ace94479c4696e4cd5b" alt="Windows 10, OpenVPN certificates."
- Start the connection
data:image/s3,"s3://crabby-images/f17d0/f17d086ee3757a9b83c03e7c7bbc348216373d28" alt="Windows 10, OpenVPN certificates."
- A pop up will confim that we are connected
data:image/s3,"s3://crabby-images/e6ea9/e6ea9ae0799c1888b73174a47e21fddc5fe00328" alt="Windows 10, OpenVPN certificates."