Operation and Maintenance
Linux Operation and Maintenance
How to set up a VPN server on Linux with OpenVPN? (Step-by-Step)
How to set up a VPN server on Linux with OpenVPN? (Step-by-Step)
OpenVPN服务器搭建需安装OpenVPN与easy-rsa,构建CA并生成密钥证书,配置server.conf、启用IP转发与防火墙规则,最后分发安全的client.ovpn文件。

Setting up an OpenVPN server on Linux is straightforward if you follow the right steps—especially with modern tools like openvpn-install or manual configuration using easy-rsa. The key is generating secure certificates, configuring the server correctly, and enabling network forwarding so clients can reach other devices or the internet.
Install OpenVPN and easy-rsa
Start by updating your system and installing OpenVPN plus the certificate management toolkit:
- On Debian/Ubuntu:
sudo apt update && sudo apt install openvpn easy-rsa - On CentOS/RHEL/Rocky:
sudo dnf install epel-release && sudo dnf install openvpn easy-rsa
Easy-RSA helps create a private PKI (public key infrastructure) — essential for authenticating clients and the server securely.
Set up the CA and generate server/client certificates
Copy the Easy-RSA scripts to a working directory and initialize the PKI:
make-cadir ~/openvpn-ca && cd ~/openvpn-ca- Edit
varsto set your country, organization, etc., then runsource vars,./clean-all, and./build-ca - Build the server cert:
./build-key-server server - Build a client cert:
./build-key client1 - Generate Diffie-Hellman params:
./build-dh - Optionally add TLS auth:
openvpn --genkey --secret keys/ta.key
Keep the keys/ folder safe — it contains all private keys and certs needed for your setup.
Configure the OpenVPN server
Create /etc/openvpn/server.conf with these core settings:
-
port 1194(or another port if 1194 is blocked) -
proto udp(UDP is faster; usetcponly if UDP is filtered) -
dev tun(layer 3 tunneling — preferred overtapfor most use cases) - Point to your keys:
ca /home/youruser/openvpn-ca/keys/ca.crt,cert /home/youruser/openvpn-ca/keys/server.crt,key /home/youruser/openvpn-ca/keys/server.key,dh /home/youruser/openvpn-ca/keys/dh2048.pem,tls-auth /home/youruser/openvpn-ca/keys/ta.key 0 - Add
server 10.8.0.0 255.255.255.0to define the VPN subnet - Push DNS:
push "dhcp-option DNS 8.8.8.8" - Enable client-to-client traffic if needed:
client-to-client - Keep logs clean:
log /var/log/openvpn.log,verb 3
Then enable IP forwarding: edit /etc/sysctl.conf and set net.ipv4.ip_forward = 1, then run sudo sysctl -p.
Start the service and configure firewall
Enable and start OpenVPN:
sudo systemctl enable openvpn@serversudo systemctl start openvpn@server- Check status:
sudo systemctl status openvpn@server
Allow traffic through your firewall:
- UFW (Ubuntu):
sudo ufw allow 1194/udpandsudo ufw route allow in on eth0 out on tun0 - firewalld (RHEL/CentOS):
sudo firewall-cmd --add-port=1194/udp --permanent, thensudo firewall-cmd --add-masquerade --permanent, and reload
Finally, create a client config file (client1.ovpn) combining the client cert, key, CA cert, and TLS auth key — and distribute it securely to users.
Basically, that’s it — no need for third-party services or paid tools. It’s not complex but easy to misconfigure if you skip certificate hygiene or NAT rules. Test with one client first, check logs, and verify routing before scaling up.
The above is the detailed content of How to set up a VPN server on Linux with OpenVPN? (Step-by-Step). For more information, please follow other related articles on the PHP Chinese website!
Hot AI Tools
Undress AI Tool
Undress images for free
AI Clothes Remover
Online AI tool for removing clothes from photos.
Undresser.AI Undress
AI-powered app for creating realistic nude photos
ArtGPT
AI image generator for creative art from text prompts.
Stock Market GPT
AI powered investment research for smarter decisions
Hot Article
Popular tool
Notepad++7.3.1
Easy-to-use and free code editor
SublimeText3 Chinese version
Chinese version, very easy to use
Zend Studio 13.0.1
Powerful PHP integrated development environment
Dreamweaver CS6
Visual web development tools
SublimeText3 Mac version
God-level code editing software (SublimeText3)
Hot Topics
20518
7
13631
4
How to manage software packages using Dnf and Rpm in Linux?
Mar 07, 2026 am 01:50 AM
dnfinstall prompts packagenotfound because it queries the enabled warehouse rather than the local installation status; rpm-q queries the local RPM database, and the scopes of the two are different.
How to monitor system performance and resources in Linux? (Top & Htop)
Mar 06, 2026 am 01:04 AM
The total top CPU usage is not 100% because it is calculated based on a single core, and the maximum is 800% for an 8-core system; the htop terminal size error needs to be fixed with eval$(resize); the real memory pressure is available rather than used; top command line truncation can be solved with the -c parameter.
How to setup file sharing using Samba on Linux? (SMB Protocol)
Mar 13, 2026 am 12:33 AM
The main reason why Windows cannot see the Samba share is that the firewall blocks UDP137–139/TCP445 or NetBIOS name resolution fails; it is necessary to confirm that the workgroup is consistent, the interfaces are configured correctly, the file permissions match forceuser/forcegroup, and set doscharset=UTF-8 to solve Chinese garbled characters.
How to extend a Logical Volume (LVM) in Linux without downtime?
Mar 13, 2026 am 12:53 AM
Logical volumes and file systems can be expanded online. You need to expand the LV first and then the file system. It is recommended to use lvextend-r for automatic synchronization adjustment, but you must ensure that the LVM and file system tool versions are compatible.
How to check open ports and listening services in Linux? (Netstat & SS)
Mar 10, 2026 am 01:08 AM
Netstat displays fewer LISTEN ports than ss because it does not display process information by default that non-root users do not have access to; ss can read all listening sockets by default without process names, and sudonetstat-tulpn is required to display them completely.
How to set up SSH key authentication on Linux? (Passwordless Login)
Mar 11, 2026 am 12:46 AM
It is recommended to use ssh-keygen-ted25519 to generate a key pair, because it is faster, more secure, and has a shorter key than the default RSA; it is necessary to strictly set the ~/.ssh directory permissions to 700 and authorized_keys to 600, and use ssh-v to confirm whether the client is Offering public key and whether the server rejects it.
How to format disk partitions using the command line in Linux?
Mar 15, 2026 am 12:01 AM
When fdisk is stuck at the Command prompt, it is normally waiting for input. Enter q to exit safely; you must umount before mkfs, otherwise it may fail silently; partedmkpart does not support the specified file system type, and mkfs needs to be executed separately.
How to configure a static IP address on Linux? (Netplan & NetworkManager)
Mar 14, 2026 am 12:02 AM
Netplan reports "InvalidYAML" when configuring a static IP due to indentation errors, missing spaces after colons, or mixed tabs; gateway4 has been deprecated and routes to:default must be used instead; NetworkManager needs to be modified before down/up takes effect; the renderer field is used to determine the backend during coexistence; incorrect DNS configuration will cause ping to succeed but curl to fail.





